1、华为C语言不管怎么说,华电每年都有几个人进华为,相对来说钱少活累。不到万不得已还是不要选华为。不过还是努力学习,先获得进华为的实力再说。华为笔试题搜集1.static有什么用途?(请至少说明两种) 1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。 2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。它是一个本地的全局变量。 3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。那就是,这个函数被限制在声明它的模块的本地范围内使用2.引用与指针有什么区别? 1) 引用必须被初始化,指针不必。 2) 引
2、用初始化以后不能被改变,指针可以改变所指的对象。 3) 不存在指向空值的引用,但是存在指向空值的指针。3.描述实时系统的基本特性 在特定时间内完成特定的任务,实时性与可靠性。4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态数据库,局部变量在堆栈。5.什么是平衡二叉树? 左右子树都是平衡二叉树 且左右子树的深度差值的绝对值不大于1。6.堆栈溢出一般是由什么原因导致的? 没有回收垃圾资源。7.什么函数不能声明为虚函数? constructor函数不能声明为虚函数。8.冒泡排序算法的时间复杂度是什么? 时间复杂度是O(n2)。9.写出float x 与“零值”比较的
3、if语句。 if(x0.000001&x-0.000001)10.Internet采用哪种网络协议?该协议的主要层次结构? Tcp/Ip协议 主要层次结构为: 应用层/传输层/网络层/数据链路层/物理层。11.Internet物理地址和IP地址转换采用什么协议? ARP (Address Resolution Protocol)(地址解析協議)12.IP地址的编码分为哪俩部分? IP地址由两部分组成,网络号和主机号。不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。13.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。写出C程序。 循环链表,用取
4、余操作做14.不能做switch()的参数类型是: switch的参数不能为实型。上海华为的一道关于指针方面的编程题int AnSize,其中隐藏着若干0,其余非0整数,写一个函数int Func(int* A, int nSize),使A把0移至后面,非0整数移至数组前面并保持有序,返回值为原数据中第一个元素为0的下标。(尽可能不使用辅助空间且考虑效率及异常问题,注释规范且给出设计思路)华为笔试题含答案 软件工程题写一个程序, 要求功能:求出用1,2,5这三个数不同个数组合的和为100的组合个数。如:100个1是一个组合,5个1加19个5是一个组合。 请用C+语言写。答案:最容易想到的算法是
5、:设x是1的个数,y是2的个数,z是5的个数,number是组合数注意到0=x=100,0=y=50,0=z=20,所以可以编程为:number=0;for (x=0; x=100; x+)for (y=0; y=50; y+)for (z=0; z=20; z+)if (x+2*y+5*z)=100)number+;coutnumberendl;上面这个程序一共要循环100*50*20次,效率实在是太低了事实上,这个题目是一道明显的数学问题,而不是单纯的编程问题。我的解法如下:因为x+2y+5z=100所以x+2y=100-5z,且z=20 x=100 y=50所以(x+2y)=100,且(
6、x+5z)是偶数对z作循环,求x的可能值如下:z=0, x=100, 98, 96, . 0z=1, x=95, 93, ., 1z=2, x=90, 88, ., 0z=3, x=85, 83, ., 1z=4, x=80, 78, ., 0.z=19, x=5, 3, 1z=20, x=0因此,组合总数为100以内的偶数+95以内的奇数+90以内的偶数+.+5以内的奇数+1,即为:(51+48)+(46+43)+(41+38)+(36+33)+(31+28)+(26+23)+(21+18)+(16+13)+(11+8)+(6+3)+1某个偶数m以内的偶数个数(包括0)可以表示为m/2+1=
7、(m+2)/2某个奇数m以内的奇数个数也可以表示为(m+2)/2所以,求总的组合次数可以编程为:number=0;for (int m=0;m=100;m+=5)number+=(m+2)/2;coutnumbernext = NULL;p=h;for(i=0;inext = s;printf(Please input the information of the student: name sex no age n);scanf(%s %c %d %d,s-name,&s-sex,&s-no,&s-age);s-next = NULL;p = s;printf(Create successf
8、ul!);return(h);void deletelist(struct stu *s,int a)struct stu *p;while(s-age!=a)p = s;s = s-next;if(s=NULL)printf(The record is not exist.);elsep-next = s-next;printf(Delete successful!);void display(struct stu *s)s = s-next;while(s!=NULL)printf(%s %c %d %dn,s-name,s-sex,s-no,s-age);s = s-next;int m
9、ain()struct stu *s;int n,age;printf(Please input the length of seqlist:n);scanf(%d,&n);s = creatlist(n);display(s);printf(Please input the age:n);scanf(%d,&age);deletelist(s,age);display(s);return 0;2、实现一个函数,把一个字符串中的字符从小写转为大写。#include stdio.h#include conio.hvoid uppers(char *s,char *us)for(;*s!=0;s+
10、,us+)if(*s=a&*s=z)*us = *s-32;else*us = *s;*us = 0;int main()char *s,*us;char ss20;printf(Please input a string:n);scanf(%s,ss);s = ss;uppers(s,us);printf(The result is:n%sn,us);getch();随机输入一个数,判断它是不是对称数(回文数)(如3,121,12321,45254)。不能用字符串库函数/*1.函数名称:Symmetry功能: 判断一个数时候为回文数(121,35653)输入: 长整型的数输出: 若为回文数返
11、回值为1 esle 0*/unsigned char Symmetry (long n)long i,temp;i=n; temp=0;while(i) /不用出现长度问题,将数按高低位掉换temp=temp*10+i%10;i/=10;return(temp=n);方法一/* -功能:判断字符串是否为回文数字实现:先将字符串转换为正整数,再将正整数逆序组合为新的正整数,两数相同则为回文数字输入:char *s:待判断的字符串输出:无返回:0:正确;1:待判断的字符串为空;2:待判断的字符串不为数字;3:字符串不为回文数字;4:待判断的字符串溢出- */unsigned IsSymmetry(
12、char *s)char *p = s;long nNumber = 0;long n = 0;long nTemp = 0;/*判断输入是否为空*/if (*s = 0)return 1;/*将字符串转换为正整数*/while (*p != 0)/*判断字符是否为数字*/if (*p9)return 2;/*判断正整数是否溢出*/if (*p-0) (4294967295-(nNumber*10)return 4;nNumber = (*p-0) + (nNumber * 10);p+;/*将数字逆序组合,直接抄楼上高手的代码,莫怪,呵呵*/n = nNumber;while(n)/*判断正
13、整数是否溢出*/if (n%10) (4294967295-(nTemp*10)return 3;nTemp = nTemp*10 + n%10;n /= 10;/*比较逆序数和原序数是否相等*/if (nNumber != nTemp)return 3;return 0;方法二/* -功能:判断字符串是否为回文数字实现:先得到字符串的长度,再依次比较字符串的对应位字符是否相同输入:char *s:待判断的字符串输出:无返回:0:正确;1:待判断的字符串为空;2:待判断的字符串不为数字;3:字符串不为回文数字- */unsigned IsSymmetry_2(char *s)char *p =
14、 s;int nLen = 0;int i = 0;/*判断输入是否为空*/if (*s = 0)return 1;/*得到字符串长度*/while (*p != 0)/*判断字符是否为数字*/if (*p9)return 2;nLen+;p+;/*长度不为奇数,不为回文数字*/if (nLen%2 = 0)return 4;/*长度为1,即为回文数字*/if (nLen = 1)return 0;/*依次比较对应字符是否相同*/p = s;i = nLen/2 - 1;while (i)if (*(p+i) != *(p+nLen-i-1)return 3;i-;return 0;求2200
15、0的所有素数.有足够的内存,要求尽量快答案:int findvalue2000=2;static int find=1;bool adjust(int value)assert(value=2);if(value=2) return true;for(int i=0;i=find;i+)if(value%findvaluei=0)return false;findvaluefind+;return true;华为最后三个大题1.A,B,C,D四个进程,A向buf里面写数据,B,C,D向buf里面读数据,当A写完,且B,C,D都读一次后,A才能再写。用P,V操作实现。2.将单向链表reverse
16、,如ABCD变成DCBA,只能搜索链表一次。3.将二叉树的两个孩子换位置,即左变右,右变左。不能用递规(变态!)华为笔试题:2007.03.31华为笔试题之一二给大家说几个:(感觉华为不过如此,虽然我的分不高,因为很多题我做给他实在是侮辱我的智商)1。大意如下:38头牛中选出3头跑得最快的,使用一个每次只能供6头比赛的场地,要求用最快的方法。(我给一个最傻瓜的答案,因为我发现一起笔试的有且恰好有38个人,不知道*什么意思?)2。大意如下:公司职员知道老板的年龄,不知道他女儿的年龄,老板3个女儿的年龄相加为13,相乘为老板年龄,且只有一个女儿的年龄大于5岁,求这4个的年龄?(网上有一大堆答案!)
17、3。原题是2002年以前的一道大学生数学建模竞赛的题,是说一个学生冒雨从宿舍去食堂吃饭,200米的距离内,问是走着少淋雨还是跑着少?(该题简化了大部分的假设,只剩下一点点问题要你解决,做着没劲!)华为最新笔试题及其分析1.printf的输出问题printf(%d,total);/this is rightprintf(total);/this is wrongprintf(hello);/but this is right2.整数类型的长度char 1个子节,8位unsigned short intsigned short intshort 2个字节,16位signed intunsigned
18、 intint 型在vc里是4个子节,32位,也可能是16位,2个字节long intunsigned long intlong型都是32位,4个字节float 32 ,4double 64,8long double 128,16char 8,一个字节,存放的实际上是字符的ascii码3、找出错误并改正char *my_cpy(char* src, int len)char dest1024;memcpy(dest, src, len);return dest;上面的函数是否有问题,如果有指出其所在,如果没有,给出函数功能描述。答案:1。数组应该初始化2。memcpy不判断是否越界,所以调用前
19、应该判断是否越界3。不应该返回rest,因为这个数组是在函数内部申请的,所以函数结束之后就会消失,指针也会变成“野指针”,所以指向非法地址最后一个比较隐蔽char *memcpy( char *dest, const char *src,int len )char* pDest = (char*)dest;char* pSrc = (char*)src;int pos;for(pos=0;pos=pbFrom+size | pbFrom=pbTo+size);while(size-0)*pbTo+ = *pbFrom+;return(pvTo);-常见函数编程:char *strcpy(cha
20、r *strDest, const char *strSrc)ASSERT(strDest != NULL & strSrc != NULL);char *addr = strDest;while(*strDest+=*strSrc+)NULL; /NULL可以省略,但更有利于编译器发现错误return addr;void *memcpy(void *dest, const void *src, int count)ASSERT(dest!= NULL & src!= NULL);for(int i=0; i cout; i+)dest = src;int strcmp(const char*
21、str1, const char *str2)while (str1 != NULL & str2 != NULL)if(*str1 *str2) return 1;else str1+; str2+;if(str1 = NULL & str2 != NULL)return -1;else if(str1 != NULL & str2 = NULL)return 1;else return 0;/way2: more compactint strcmp(const char*str1, const char *str2)int i = strlen( str1 );int j;for(j=0; j str2j) return 1; /if str2 terminates, then str2j=0, str1jstr2j, return 1;else if(str1j str2j) return -1;else if(str1j = ) return 0;/way3: optimize
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1