华为笔试题库.docx
《华为笔试题库.docx》由会员分享,可在线阅读,更多相关《华为笔试题库.docx(23页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、 华为笔试题库 1.第一题的题目也许是输入整型数组求数组的最小数和最大数之和,例如输入1,2,3,4则输出为5,当输入只有一个数的时候,则最小数和最大数都是该数,例如只输入1,则输出为2;另外数组的长度不超过50 #include main() intnum50=0; inti,n; printf(请输入整型数组的长度(150):); scanf(%d,n); printf(请输入整型数组的元素:); for(i=0;i scanf(%d,numi); intmin_num=num0; intmax_num=num0; for(intj=0;j if(max_num max_num=numj;
2、 elseif(min_numnumj) min_num=numj; intsum=min_num+max_num; printf(数组中最大与最小值之和:%dn,sum); return0; 2.求两个长长整型的数据的和并输出,例如输入1233333333333333。 3111111111111111111111111.。,则输出。 #include #include #include main() char*num1,*num2; /两个长长整型数据 char*sum; / inttemp; int len_num1,len_num2; / 两个长长整型数据的长度 intlen_max,
3、len_min; num1=(char*)malloc(sizeof(char); num2=(char*)malloc(sizeof(char); printf(输入两个长长整型数据:); scanf(%s,num1); printf(输入两个长长整型数据:); scanf(%s,num2); len_num1=strlen(num1); len_num2=strlen(num2); len_max=(len_num1=len_num2)?len_num1:len_num2; len_min=(len_num1=len_num2)?len_num1:len_num2; int len_max
4、1=len_max; sum=(char*)malloc(sizeof(char)*len_max); memset(sum,0x00,len_max+1);/切忌初始化 for(;len_num10len_num20;len_num1-,len_num2-) sumlen_max-=(num1len_num1-1-0)+(num2len_num2-1-0); if(len_num10) sumlen_max-=num1len_num1- 1 -0; len_num1-; if(len_num20) sumlen_max-=num1len_num2- 1-0; len_num2-; for(i
5、ntj=len_max1;j=0;j-) /实现进位操作 / temp=sumj-0; if(sumj=10) sumj-1+=sumj/10; sumj%=10; char*outsum=(char*)malloc(sizeof(char)*len_max1); j=0; while(sumj=0) /跳出头部0元素 j+; for(int m=0;m outsumm=sumj+0; outsumm=0; printf(输出两长长整型数据之和:%sn,outsum); return0; 3.通过键盘输入一串小写字母(az)组成的字符串。请编写一个字符串过滤程序,若字符串中消失多个一样的字符,
6、将非首次消失的字符过滤掉。 比方字符串“abacacde”过滤结果为“abcde”。 要求实现函数: void stringFilter(const char *pInputStr,long lInputLen, char *pOutputStr); 【输入】 pInputStr:输入字符串 lInputLen: 输入字符串长度 【输出】 pOutputStr:输出字符串,空间已经开拓好,与输入字符串等长; #include #include #include void stringFilter(const char *p_str, longlen, char *p_outstr) intar
7、ray256=0; const char *tmp = p_str; for(int j=0;j if(arraytmpj=0) *p_outstr+=tmpj; arraytmpj+; *p_outstr= 0; void main() char *str = cccddecc; intlen = strlen(str); char* outstr = (char *)malloc(len*sizeof(char); stringFilter(str,len,outstr); printf(%sn,outstr); free(outstr); outstr= NULL; 4.通过键盘输入一串
8、小写字母(az)组成的字符串。请编写一个字符串压缩程序,将字符串中连续出席的重复字母进展压缩,并输出压缩后的字符串。 压缩规章: 1. 仅压缩连续重复消失的字符。比方字符串abcbc由于无连续重复字符,压缩后的字符串还是abcbc. 2. 压缩字段的格式为字符重复的次数+字符。例如:字符串xxxyyyyyyz压缩后就成为3x6yz 要求实现函数: void stringZip(const char*pInputStr, long lInputLen, char *pOutputStr); 【输入】 pInputStr: 输入字符串 lInputLen: 输入字符串长度 【输出】 pOutput
9、Str: 输出字符串,空间已经开拓好,与输入字符串等长; #include #include #include void stringZip(const char *p_str, long len,char *p_outstr) intcount=1; for(inti=0;i if(p_stri=p_stri+1) count+; else if(count1) *p_outstr+= count +0; *p_outstr+=p_stri; else *p_outstr+=p_stri; count = 1;/留意其位置 *p_outstr= 0; void main() char*str
10、 = cccddecc; printf(压缩之前的字符串为:%sn,str); intlen = strlen(str); char* outstr = (char*)malloc(len*sizeof(char); stringZip(str,len,outstr); printf(压缩之后的字符串为:%sn,outstr); free(outstr); outstr= NULL; 5.通过键盘输入100以内正整数的加、减运算式,请编写一个程序输出运算结果字符串。 输入字符串的格式为:“操作数1 运算符 操作数2”,“操作数”与“运算符”之间以一个空格隔开。 补充说明: 1. 操作数为正整数
11、,不需要考虑计算结果溢出的状况。 2. 若输入算式格式错误,输出结果为“0”。 要求实现函数: void arithmetic(const char*pInputStr, long lInputLen, char *pOutputStr); 【输入】 pInputStr: 输入字符串 lInputLen: 输入字符串长度 【输出】 pOutputStr: 输出字符串,空间已经开拓好,与输入字符串等长; #include #include #include void arithmetic(const char *input, longlen, char *output) chars110; ch
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 华为 笔试 题库
限制150内