華為上機(jī)試題匯總
華為上機(jī)試題匯總
華為上機(jī)考試有哪些考點呢?下面跟小編一起來看看吧!希望這些上機(jī)試題能幫助大家順利通過考試!
地區(qū)一:
1. 編寫函數(shù)string deletestring(string str,string sub_str)從str中查找匹配的字符串sub_str,采用最左匹配,且輸出形式為str+"_"+匹配的次數(shù)
題目一的意思應(yīng)該是求解字符串str中子字符串sub_str的個數(shù),同時輸出形式采用原字符串+"_"匹配次數(shù)
相信大家第一反應(yīng)應(yīng)該是采用kmp,那么下面給出常規(guī)優(yōu)化kmp程序如下(采用字符串?dāng)?shù)組形式):
#include
using namespace std;
int next[100];
void getnext(char b[])
{
int i=1,j=0; //ij
next[1]=0;
while(i<=strlen(b))
{
if(j==0||b[i-1]==b[j-1])
{
i++;
j++;
next[i]=j;
}
else j=next[j]; //
}
}
int kmp(char a[],char b[])
{
int i=1,j=1; //i j
while(i<=strlen(a)&&j<=strlen(b))
{
if(j==0||a[i-1]==b[j-1])
{
i++;
j++;
}
else j=next[j];
}
if(j>strlen(b))
return i-strlen(b);
else return 0;
}
2. 高精度數(shù)相加,string addBigInt(string num1,string num2) 需要考慮正負(fù)數(shù)相加
這道題是高精度計算中的最最簡單的一題:
目的是模擬人手工運算的過程,進(jìn)而進(jìn)行結(jié)果的現(xiàn)實;
參考代碼(編譯環(huán)境:Visual Studio 6):
地區(qū)二:
第一題:鑒定回文數(shù)組
給定一個數(shù)組判斷是否是回文,這題沒什么好說明,直接看代碼:
1 #include
2 using namespace std;
3
4 bool isHuiWen(string s)
5 {
6 int length_s=s.length();
7 int i=0;
8 for(i=0;i<(length_s>>1);i++)
9 {
10 if(s.at(i)!=s.at(length_s-1-i))
11 return false;
12 }
13 return true;
14 }
15
16 int main()
17 {
18 string ss="iloveevolis";
19 if(isHuiWen(ss))
20 {
21 cout<<"Huiwen"<
22 }
23 else
24 {
25 cout<<"No"<
26 }
27 return 1;
28 }
第二題:求兩個整型數(shù)組的異集,即A+B-(A與B的交集)。
這里只是提供我的一個思路:
這個問題的求解可以簡化為統(tǒng)計數(shù)組A B中任何字符的個數(shù),A+B-(A與B的交集)的結(jié)果就是統(tǒng)計僅僅出現(xiàn)過一次的數(shù)字:
但是題目中沒有限制是字符,而是整形,數(shù)據(jù)量太大,這里借用了map操作,進(jìn)行簡化內(nèi)存:
針對這個思路程序如下:
1 #include
2 #include
3 using namespace std;
4
5 map mi;
6 map::iterator mit;
7 int A[10]={1,2,3,4,5,6,3,2,8,9};
8 int B[10]={8,7,6,5,9,0,3,4,8,40};
9 int R[20];
10 int RC=0;
11
12
13 void getAB(int* a,int na,int* b,int nb)
14 {
15 string re;
16 mi.clear();
17 for(int i=0;i
18 {
19 mit=mi.find(a[i]);
20 if(mit!=mi.end())
21 {
22 mit->second++;
23 }
24 else
25 {
26 mi.insert(make_pair(a[i],1));
27 }
28 }
29
30 for(i=0;i
31 {
32 mit=mi.find(b[i]);
33 if(mit!=mi.end())
34 {
35 mit->second++;
36 }
37 else
38 {
39 mi.insert(make_pair(b[i],1));
40 }
41 }
42
43 for(mit=mi.begin(),i=0;mit!=mi.end();mit++)
44 {
45 if(mit->second==1)
46 {
47 R[i++]=mit->first;
48 }
49 }
50 RC=i;
51 }
52
53 int main()
54 {
55 getAB(A,10,B,10);
56 for(int i=0;i
57 {
58 cout<
59 }
60 return 1;
61 }
第三題:判定德州撲克的牌型。給5張牌,返回它的牌型,4個的,3個+對子,順子,3個+2個單張,2對,1對,其他。
德州撲克我還是很喜歡玩的`,其中牌型牌型可以有近10中結(jié)果,題目僅僅讓我們判斷七種。但是這七種結(jié)果不具有繼承性,所以我們設(shè)計一個好的程序。
那么就要統(tǒng)一他們的表現(xiàn)形式,下面是我的思路:
版權(quán)聲明:本文內(nèi)容由互聯(lián)網(wǎng)用戶自發(fā)貢獻(xiàn),該文觀點僅代表作者本人。本站僅提供信息存儲空間服務(wù),不擁有所有權(quán),不承擔(dān)相關(guān)法律責(zé)任。如發(fā)現(xiàn)本站有涉嫌抄襲侵權(quán)/違法違規(guī)的內(nèi)容, 請發(fā)送郵件至 yyfangchan@163.com (舉報時請帶上具體的網(wǎng)址) 舉報,一經(jīng)查實,本站將立刻刪除