2019华为校园招聘面试

上传人:cl****1 文档编号:431608191 上传时间:2023-09-05 格式:DOC 页数:86 大小:140KB
返回 下载 相关 举报
2019华为校园招聘面试_第1页
第1页 / 共86页
2019华为校园招聘面试_第2页
第2页 / 共86页
2019华为校园招聘面试_第3页
第3页 / 共86页
2019华为校园招聘面试_第4页
第4页 / 共86页
2019华为校园招聘面试_第5页
第5页 / 共86页
点击查看更多>>
资源描述

《2019华为校园招聘面试》由会员分享,可在线阅读,更多相关《2019华为校园招聘面试(86页珍藏版)》请在金锄头文库上搜索。

1、word1输入整型数组求数组的最小数和最大数之和,例如输入1,2,3,4如此输出为5,当输入只有一个数的时候,如此最小数和最大数都是该数,例如只输入1,如此输出为2;另外数组的长度不超过50参考代码:#includemain()int num50=0;int i,n;printf(“请输入整型数组的长度(150):);scanf(“%d,&n);printf(“请输入整型数组的元素:);for (i=0;in;i+)scanf(“%d,&numi);int min_num=num0;int max_num=num0;for(int j=0;jn;j+)if(max_numnumj)min_nu

2、m=numj;int sum=min_num+max_num;printf(“数组中最大与最小值之和:%dn,sum);return 0;#include#include#includemain()char *num1,*num2; /两个长长整型数据char *sum;/int temp;int len_num1,len_num2; / 两个长长整型数据的长度int len_max,len_min;num1=(char*)malloc(sizeof(char);num2=(char*)malloc(sizeof(char);printf(“输入两个长长整型数据:);scanf(“%s,num

3、1);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_num10&len_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)sumle

4、n_max-=num1len_num2 - 1-0;len_num2;for(int j=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;mlen_max1;j+,m+)outsumm=sumj+0;outsumm=0;printf(“输出两长长整型数据之和:%sn,outsum);return 0;3.通过键盘输入一串

5、小写字母(az)组成的字符串。请编写一个字符串过滤程序,假如字符串中出现多个一样的字符,将非首次出现的字符过滤掉。比如字符串abacacde过滤结果为abcde。要某某现函数:void stringFilter(const char *pInputStr, long lInputLen, char *pOutputStr);【输入】 pInputStr:输入字符串lInputLen:输入字符串长度【输出】 pOutputStr:输出字符串,空间已经开辟好,与输入字符串等长;参考代码:#include #include#includevoid stringFilter(const char *p

6、_str, long len, char *p_outstr)int array256=0;const char *tmp = p_str;for(int j=0;jlen;j+)if(arraytmpj=0)*p_outstr+= tmpj;arraytmpj+;*p_outstr = 0;void main()char *str = “cccddecc;int len = strlen(str);char * outstr = (char *)malloc(len*sizeof(char);stringFilter(str,len,outstr);printf(“%sn,outstr);f

7、ree(outstr);outstr = NULL;5.通过键盘输入100以内正整数的加、减运算式,请编写一个程序输出运算结果字符串。输入字符串的格式为:操作数1 运算符 操作数2,操作数与运算符之间以一个空格隔开。补充说明:1. 操作数为正整数,不需要考虑计算结果溢出的情况。2. 假如输入算式格式错误,输出结果为0。要某某现函数:void arithmetic(const char *pInputStr, long lInputLen, char *pOutputStr);【输入】 pInputStr: 输入字符串lInputLen: 输入字符串长度【输出】 pOutputStr: 输出字符

8、串,空间已经开辟好,与输入字符串等长;#include #include#includevoid arithmetic(const char *input, long len, char *output)char s110;char s210;char s310;int t = 0;int len_input=strlen(input);for(int i=0;ilen_input;+i)if(inputi= )t+;if(t!=2)*output+ = 0;*output = 0;return;sscanf(input,%s %s %s,s1,s2,s3);if(strlen(s2)!=1|

9、(s20!=+&s20!=-)*output+ = 0;*output = 0;return;int len_s1=strlen(s1);for(i=0;ilen_s1;i+)if(s1i9)*output+ = 0;*output = 0;return;int len_s3=strlen(s3);for(i=0;ilen_s3;i+)if(s3i9)*output+ = 0;*output = 0;return;int x = atoi(s1);int y = atoi(s3);if(s20=+)int result = x+y;itoa(result,output,10);else if(

10、s20=-)int result = x-y;itoa(result,output,10);else*output+ = 0;*output = 0;return;void main()char str = “10 23;char outstr10;int len = strlen(str);arithmetic(str,len,outstr);printf(“%sn,str);printf(“%sn,outstr);6.一组人n个,围成一圈,从某人开始数到第三个的人出列,再接着从下一个人开始数,最终输出最终出列的人约瑟夫环是一个数学的应用问题:n个人以编号1,2,3n分别表示围坐在一X圆桌周围。从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。#include #includes

展开阅读全文
相关资源
正为您匹配相似的精品文档
相关搜索

最新文档


当前位置:首页 > 建筑/环境 > 施工组织

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号