C语言 2010 华为 网络面试题汇总-2

合集下载

华为C语言机试题面试题汇总

华为C语言机试题面试题汇总

1.第一题的题目大概是输入整型数组求数组的最小数和最大数之和,例如输入1,2,3,4则输出为5,当输入只有一个数的时候,则最小数和最大数都是该数,例如只输入1,则输出为2;另外数组的长度不超过50#include<stdio.h>main(){int num[50]={0};int i,n;printf("请输入整型数组的长度(1~50):");scanf("%d",&n);printf("请输入整型数组的元素:");for (i=0;i<n;i++){scanf("%d",&num[i]);}int min_num=num[0];int max_num=num[0];for(int j=0;j<n;j++){if(max_num<num[j])max_num=num[j];else if(min_num>num[j])min_num=num[j];}int sum=min_num+max_num;printf("数组中最大与最小值之和:%d\n",sum);return 0;}2.求两个长长整型的数据的和并输出,例如输入1233333333333333 。

3111111111111111111111111.。

,则输出。

#include<stdio.h>#include<string.h>#include<malloc.h>main(){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",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_max1=len_max;sum=(char*)malloc(sizeof(char)*len_max);memset(sum,0x00,len_max+1);//切忌初始化for(;len_num1>0&&len_num2>0;len_num1--,len_num2--){sum[len_max--]=((num1[len_num1-1]-'0')+(num2[len_num2-1]-'0'));}if(len_num1>0){sum[len_max--]=num1[len_num1 - 1 ]-'0';len_num1--;}if(len_num2>0){sum[len_max--]=num1[len_num2 - 1]-'0';len_num2--;}for(int j=len_max1;j>=0;j--) //实现进位操作{// temp=sum[j]-'0';if(sum[j]>=10){sum[j-1]+=sum[j]/10;sum[j]%=10;}}char *outsum=(char*)malloc(sizeof(char)*len_max1);j=0;while(sum[j]==0) //跳出头部0元素j++;for(int m=0;m<len_max1;j++,m++)outsum[m]=sum[j]+'0';outsum[m]='\0';printf("输出两长长整型数据之和:%s\n",outsum);return 0;}3.通过键盘输入一串小写字母(a~z)组成的字符串。

c语言经典面试题

c语言经典面试题

C语言面试题大汇总之华为面试题1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。

要用全局变量,需要使用"::";局部变量可以与全局变量同名,在函数引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数可以定义多个同名的局部变量,比如在两个循环体都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体。

2、如何引用一个已经定义过的全局变量?答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。

可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错.4、请写出下列代码的输出容#include <stdio.h>int main(void){int a,b,c,d;a=10;b=a++;c=++a;d=10*a++;printf("b,c,d:%d,%d,%d",b,c,d);return 0;}答:10,12,1205、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?答: 1) 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。

这两者在存储方式上并无不同。

这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。

华为机试题目总结(程序篇)

华为机试题目总结(程序篇)

华为机试题目总结(程序篇)自己写的,水平很挫,仅供参考目录1.语言识别问题2.销售网络问题(未完成)3.股票投资问题4.判断手机号码合法性5.元音字母复制6.验证身份证号7.选秀节目打分8.数组最大值放中间,其他依次放其左右(规律未找着,未完成)9.任务调度(解题关键,需要一个容器来承载下标跟值的一一对应关系,最好就是定义一个结构体)10.将某字符变成小写后的某个字符11.链表的逆序12.单词统计13.字符串进行转换,转换成相应的数字已知:yi er san si wu liu qi ba jiu 分别对应,对一段只含有这几种字符的字符串进行转换,转换成相应的数字14.一个数组中比平均数大的个数15.求一个数组中第一大和第二大数16.字符变成整数17.整数变字符18.判断素数问题19(1).约瑟夫环(循环列表)19(2).约瑟夫环(数学方法只能求出最后的胜利者的序号)19(3).约瑟夫环(容器实现)20.判断某个整数是回文。

即这样的,反过来还是21.判断一个字符串是不是回文22.求一个字符串中的最大回文子串,就是从n个字符开始检查是不是回文,知道m个字符符合回文,那么这个就是最大回文23.找出^n的数24.统计一个数二进制表达中的个数25.镜像反转二进制表达式,并输出十进制值26.连续字符统计27.判断一个字符串中()是否配对28.查找子字符串个数29(1).找出一个字符串中是否包含相同(包括连续的)的子字符串(要求子串长度大于等于)并输出出现频率最高的子字符串29(2)找出一个字符串中是否包含连续相同的子字符串,并输出出现频率最高的子字符串30.删除字符窜中字符数最少的字符31.关于数组的循环移位,左移为负,右移为正32.求一个二维数组每列的最小值33.两个字符串,求最长公共子串34.超大整数加法运算,大整数会用字符串或者数组来存,不过注意低位存字符前面几位,高位存后面,存到字符中应该存“”。

c语言经典面试题

c语言经典面试题

C语言面试题大汇总之华为面试题1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。

要用全局变量,需要使用”::”;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。

2、如何引用一个已经定义过的全局变量?答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量.可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错。

4、请写出下列代码的输出内容#include 〈stdio。

h〉int main(void){int a,b,c,d;a=10;b=a++;c=++a;d=10*a++;printf(”b,c,d:%d,%d,%d”,b,c,d);return 0;}答:10,12,1205、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?答:1)全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。

这两者在存储方式上并无不同。

这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。

而静态全局变量则限制了其作用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文件中不能使用它。

华为C语言机试题面试题汇总.docx

华为C语言机试题面试题汇总.docx

1.第一题的题目大概是输入整型数组求数组的最小数和最大数之和,例如输入1,2,3,4则输出为5,当输入只有一个数的时候,则最小数和最大数都是该数,例如只输入1,则输出为2;另外数组的长度不超过50#include<stdio.h>main(){int num[50]={0};int i,n;printf("请输入整型数组的长度(1~50):");scanf("%d",&n);printf("请输入整型数组的元素:");for (i=0;i<n;i++){scanf("%d",&num[i]);}int min_num=num[0];int max_num=num[0];for(int j=0;j<n;j++){if(max_num<num[j])max_num=num[j];else if(min_num>num[j])min_num=num[j];}int sum=min_num+max_num;printf("数组中最大与最小值之和:%d\n",sum);return 0;}2.求两个长长整型的数据的和并输出,例如输入1233333333333333 。

3111111111111111111111111.。

,则输出。

#include<stdio.h>#include<string.h>#include<malloc.h>main(){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",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_max1=len_max;sum=(char*)malloc(sizeof(char)*len_max);memset(sum,0x00,len_max+1);//切忌初始化for(;len_num1>0&&len_num2>0;len_num1--,len_num2--){sum[len_max--]=((num1[len_num1-1]-'0')+(num2[len_num2-1]-'0'));}if(len_num1>0){sum[len_max--]=num1[len_num1 - 1 ]-'0';len_num1--;}if(len_num2>0){sum[len_max--]=num1[len_num2 - 1]-'0';len_num2--;}for(int j=len_max1;j>=0;j--) //实现进位操作{// temp=sum[j]-'0';if(sum[j]>=10){sum[j-1]+=sum[j]/10;sum[j]%=10;}}char *outsum=(char*)malloc(sizeof(char)*len_max1);j=0;while(sum[j]==0) //跳出头部0元素j++;for(int m=0;m<len_max1;j++,m++)outsum[m]=sum[j]+'0';outsum[m]='\0';printf("输出两长长整型数据之和:%s\n",outsum);return 0;}3.通过键盘输入一串小写字母(a~z)组成的字符串。

华为2010面试题

华为2010面试题
Database
19. 数据库编程哪部分最重要?
20. 未来的数据库(电子信息数据库)的走向?
21. 数据库第一范式怎么表示

华为复试问问题:
Network:
1. 如何设计一个模型来检验通信协议的正确性?
2. 位于网络两端的计算机的连接过程是怎SM和PETRI网哪个好
5. 中国一号和七号信令的区别。
14. 写出一个字符串子串匹配的算法?
15 对一个一维数组排序
Software System:
16. UNIX文件系统的最大优点是什么?
17. fork函数的返回值是?
18.(软件)测试有哪几种方法?
Hardware:
6. CPU里面有些什么东东,外面有些什么东东?
7. 指令执行分几个步骤
Languge and Compiler:
9. i = 0, 那么, ++i||i-- 的值?
8. c c++ java的区别?
9. 全局变量、局部变量、静态变量都放在内存的什么地方?
10. 结构与类的区别
11. a*b+c 这样的表达式如何写编译程序?
12 c++虚函数怎么实现
Data structure and Algorthim
13. 写出一个二分函数?

华为面试编程题

华为面试编程题
111. {
112. int i。
113. for(i=0。i<(num2_len>num1_len?num1_len:num2_len)。i++)
114. {
115. *res_p++=(*num1_p-'0'+*num2_p-'0'+count)%10+'0'。
116. count=(*num1_p-'0'+*num2_p-'0'+count)/10。
36. for(i=0。i<res_len/2。i++)
37. {
38. temp=result[i]。
39. result[i]=result[res_len-i-1]。
40. result[res_len-i-1]=temp。
41. }
42.}
43.
44./*加法函数,用于将两个字符串形式的整数相加,结果保存在char * result中*/
输入:num1 = "580"
num2 = "-600"
输出:result = "-20"
程序代码(C语言):
01.#include <stdio.h>
02.#include <string.h>
03.
04./*判断字符串整数是否合法,合法返回'1',否则返回'0'*/
05.int isLegalNum(const char * num)
-9876543210 + (-1234567890) = ?

C语言面试题大汇总之华为面试题2

C语言面试题大汇总之华为面试题2

C语言面试题大汇总之华为面试题216.谈谈Windows DNA结构的特点和优点。

答:Windows Distributed interNet Application Architecture(Windows分布式应用结构,简称Windows DNA)是微软创建新一代高适应性商业解决方案的框架,它使公司能够充分地挖掘数字神经系统的优点。

Windows DNA是第一个将Internet、客户/服务器、和用于计算的PC模型结合并集成在一起的为新一类分布式计算方案而设计的应用软件体系结构17.网络编程中设计并发服务器,使用多进程与多线程,请问有什么区别?答:1)进程:子进程是父进程的复制品。

子进程获得父进程数据空间、堆和栈的复制品。

2)线程:相对与进程而言,线程是一个更加接近与执行体的概念,它可以与同进程的其他线程共享数据,但拥有自己的栈空间,拥有独立的执行序列。

两者都可以提高程序的并发度,提高程序运行效率和响应时间。

线程和进程在使用上各有优缺点:线程执行开销小,但不利于资源管理和保护;而进程正相反。

同时,线程适合于在SMP机器上运行,而进程则可以跨机器迁移。

思科1. 用宏定义写出swap(x,y)答#define swap(x, y)x = x + y;y = x - y;x = x - y;2.数组a[N],存放了1至N-1个数,其中某个数重复一次。

写一个函数,找出被重复的数字.时间复杂度必须为o(N)函数原型:int do_dup(int a[],int N)答:int do_dup(int a[],int N) //未经调试{int sun = 0;int sum2;for(int i=0;i<N;++i){Sum+=a[i];}Sum2 = (1+N-1)*N/2;Return (sum-sum2);}3 一语句实现x是否为2的若干次幂的判断答:方法1)int i = 512;cout << boolalpha << ((i & (i - 1)) ? false : true) << endl; //位与为0,则表示是2的若干次幂2)return (x>>N==1);4.unsigned int intvert(unsigned int x,int p,int n)实现对x的进行转换,p 为起始转化位,n为需要转换的长度,假设起始点在右边.如x=0b00010001,p=4,n=3转换后x=0b0110 0001答:unsigned int intvert(unsigned int x,int p,int n) //假定p=4,n=3void UpperCase( char str[] ) // 将 str 中的小写字母转换成大写字母{for( size_t i=0; i<sizeof(str)/sizeof(str[0]); ++i )if( 'a'<=str[i] && str[i]<='z' )str[i] -= ('a'-'A' );}char str[] = "aBcDe";cout << "str字符长度为: " << sizeof(str)/sizeof(str[0]) << endl; UpperCase( str );cout << str << endl;答:函数内的sizeof有问题。

华为面试题

华为面试题

华为面试题面试是华为公司录用考试的关键环节。

下面是由店铺分享的华为面试题,希望对你有用。

华为面试题(一)1.static有什么用途?(请至少说明两种)1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。

2) 在模块内(但在函数体外),一个被声明为静态的变量可以被模块内所用函数访问,但不能被模块外其它函数访问。

它是一个本地的全局变量。

3) 在模块内,一个被声明为静态的函数只可被这一模块内的其它函数调用。

那就是,这个函数被限制在声明它的模块的本地范围内使用2.引用与指针有什么区别?1) 引用必须被初始化,指针不必。

2) 引用初始化以后不能被改变,指针可以改变所指的对象。

3) 不存在指向空值的引用,但是存在指向空值的指针。

3.描述实时系统的基本特性在特定时间内完成特定的任务,实时性与可靠性。

4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别? 全局变量储存在静态全局数据段,局部变量在堆栈。

5.什么是平衡二叉树?左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于1。

6.堆栈溢出一般是由什么原因导致的?没有回收垃圾资源。

7.什么函数不能声明为虚函数?constructor函数不能声明为虚函数。

8.冒泡排序算法的时间复杂度是什么?时间复杂度是O(n^2)。

9.写出float x 与“零值”比较的if语句。

if(x>0.000001&&x<-0.000001)10.Internet采用哪种网络协议?该协议的主要层次结构?Tcp/Ip协议主要层次结构为:应用层/传输层/网络层/数据链路层/物理层。

11.Internet物理地址和IP地址转换采用什么协议?ARP (Address Resolution Protocol)(地址解析协议)12.IP地址的编码分为哪俩部分?IP地址由两部分组成,网络号和主机号。

不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。

C语言面试题大汇总之华为面试题及答案(5篇)

C语言面试题大汇总之华为面试题及答案(5篇)

C语言面试题大汇总之华为面试题及答案(5篇)第一篇:C语言面试题大汇总之华为面试题及答案C语言面试题大汇总之华为面试题及答案2007-01-24 09:19作者:罗可龙出处:csdn责任编辑:罗可龙1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。

要用全局变量,需要使用“::”局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。

2、如何引用一个已经定义过的全局变量?答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个变写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。

可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错4、语句for(;1;)有什么问题?它是什么意思?答:和while(1)相同。

5、do……while和while……do有什么区别?答:前一个循环一遍再判断,后一个判断以后再循环6、请写出下列代码的输出内容以下是引用片段:#includemain(){int a,b,c,d;a=10;b=a++;c=++a;d=10*a++;printf(“b,c,d:%d,%d,%d”,b,c,d);return 0;}答:10,12,1207、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。

华为c语言面试题

华为c语言面试题

华为c语言面试题C语言作为一门广泛应用于嵌入式系统和高性能计算领域的编程语言,成为了许多IT从业者必备的技能之一。

在华为的面试中,C语言题目也常常出现,对应聘者的编程基础和逻辑思维能力有所考察。

在本文中,我们将介绍一些常见的华为C语言面试题,供大家参考。

一、变量与数据类型1. 如何声明一个整型变量并初始化为10?int x = 10;2. 如何声明一个字符型变量并初始化为字母'A'?char ch = 'A';3. 如何声明一个常量,并将其值设定为3.14?const float pi = 3.14;4. 如何交换两个变量的值,例如将变量a的值与变量b的值交换?int temp;temp = a;a = b;b = temp;二、控制结构1. 请写出一个实现求1到100之间所有奇数和的C语言程序。

```c#include <stdio.h>int main() {int sum = 0;int i;for (i = 1; i <= 100; i += 2) {sum += i;}printf("奇数和为:%d\n", sum);return 0;}```2. 请写出一个实现判断一个数是否为素数的C语言程序。

```c#include <stdio.h>int isPrime(int num) {int i;for (i = 2; i <= num / 2; i++) {if (num % i == 0) {return 0;}}return 1;}int main() {int num;printf("请输入一个整数:");scanf("%d", &num);if (isPrime(num)) {printf("%d是素数。

\n", num); } else {printf("%d不是素数。

C语言面试题大汇总之华为面试题

C语言面试题大汇总之华为面试题

1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。

要用全局变量,需要使用"::" ;局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。

2、如何引用一个已经定义过的全局变量?答:extern 可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。

可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错.4、请写出下列代码的输出内容#include <stdio.h>int main(void){int a,b,c,d;a=10;b=a++;c=++a;d=10*a++;printf("b,c,d:%d,%d,%d",b,c,d);return 0;}答:10,12,1205、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?答: 1) 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。

这两者在存储方式上并无不同。

这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。

C语言面试题大汇总之华为面试题

C语言面试题大汇总之华为面试题

C语言面试题大汇总之华为面试题女性时尚购物网编辑:8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存在于( 堆)中。

9、设有以下说明和定义:typedef union {long i; int k; char c;} DATE; struct data { int cat; DATE cow; double dog;} too; DATE max; 则语句 printf( "%d ",sizeof(struct date)+sizeof(max));的执行结果是:___52____ 答:DATE是一个union, 变量公用空间. 里面最大的变量类型是int, 占用20个字节. 所以它的大小是20 data是一个struct, 每个变量分开占用空间. 依次为int4 + DATE20 + double8 = 32. 所以结果是20 + 32 = 52. 当然...在某些16位编辑器下, int可能是2字节,那么结果是 int2 + DATE10 + double8 = 20 10、队列和栈有什么区别? 队列先进先出,栈后进先出11、写出下列代码的输出内容#include int inc(int a) { return(++a); } int multi(int*a,int*b,int*c) { return(*c=*a**b); } typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); void show(FUNC2 fun,int arg1, int*arg2) { INCp=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2);printf( "%d\n ",*arg2); } main() { int a; show(multi,10,&a); return 0; } 答:110 12、请找出下面代码中的所以错误说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”1、#include " " 2、main() 3、{ 4、 char*src= "hello,world "; 5、 char* dest=NULL; 6、int len=strlen(src); 7、dest=(char*)malloc(len); 8、 char* d=dest; 9、char* s=src; 10、 while(len--!=0) 11、 d++=s--;12、 printf( "%s ",dest); 13、 return 0; 14、} 答:方法1:int main() { char* src = "hello,world "; int len = strlen(src); char* dest = (char*)malloc(len+1);//要为\0分配一个空间char* d = dest; char* s = &src;//指向最后一个字符while( len-- != 0 ) *d++=*s--; *d = 0;//尾部要加\0 printf( "%s\n ",dest); free(dest);// 使用完,应当释放空间,以免造成内存汇泄露return 0; } 方法2:#include#include main() { char str= "hello,world "; int len=strlen(str); char t; for(int i=0; i> )%256 } 请问hash(16),hash(256)的值分别是: ;;; 找错题: 25.请问下面程序有什么错误? int a,i,j,k; for(k=0;k。

c语言经典面试题

c语言经典面试题

c语言经典面试题C语言面试题大汇总之华为面试题1、局部变量能否和全局变量重名?答:能,局部会屏蔽全局。

要用全局变量,需要使用"::";局部变量可以与全局变量同名,在函数内引用这个变量时,会用到同名的局部变量,而不会用到全局变量。

对于有些编译器而言,在同一个函数内可以定义多个同名的局部变量,比如在两个循环体内都定义一个同名的局部变量,而那个局部变量的作用域就在那个循环体内。

2、如何引用一个已经定义过的全局变量?答:extern可以用引用头文件的方式,也可以用extern关键字,如果用引用头文件方式来引用某个在头文件中声明的全局变理,假定你将那个编写错了,那么在编译期间会报错,如果你用extern方式引用时,假定你犯了同样的错误,那么在编译期间不会报错,而在连接期间报错。

3、全局变量可不可以定义在可被多个.C文件包含的头文件中?为什么?答:可以,在不同的C文件中以static形式来声明同名全局变量。

可以在不同的C文件中声明同名的全局变量,前提是其中只能有一个C文件中对此变量赋初值,此时连接不会出错.4、请写出下列代码的输出内容#include <stdio.h>int main(void){int a,b,c,d;a=10;b=a++;c=++a;d=10*a++;printf("b,c,d:%d,%d,%d",b,c,d);return 0;}答:10,12,1205、static全局变量与普通的全局变量有什么区别?static局部变量和普通局部变量有什么区别?static函数与普通函数有什么区别?答: 1) 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量。

全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方式。

这两者在存储方式上并无不同。

这两者的区别在于非静态全局变量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态的全局变量在各个源文件中都是有效的。

华为面试题c语言

华为面试题c语言

华为面试题 c语言华为面试题 c语言华为面试题 c语言(一)题目:输入一个正整数 X,在下面的等式左边的数字之间添加+号或者-号,使得等式成立。

1 2 3 4 5 6 7 8 9 = X比如:12-34+5-67+89 = 51+23+4-5+6-7-8-9 = 5请编写程序,统计满足输入整数的所有整数个数。

输入:正整数,等式右边的数字输出:使该等式成立的个数样例输入: 5样例输出: 21【下面的代码只输出了所有的等式,没有输出个数】代码如下:#includevoid dfs(int layer, int currentResult, int lastOp, int lastSum);const char sym[3] = {'+' , '-' , ' '};int ops[21] = {0};int result , num;void main(){while (1){printf("请输入等式右边的值\n");scanf("%c",&result);printf("\n以下是使等式成立的公式:\n");dfs(1,0,0,0);}return ;}void dfs(int layer, int currentResult, int lastOp, int lastSum) {int i;lastSum *= (layer > 9) ? 100 : 10;lastSum += layer;if(layer == 9){currentResult += (lastOp) ? (-1 * lastSum) : lastSum;if(currentResult == result){++num;printf("1");for(i = 2 ; i <= 9 ; ++i){if(sym[ops[i-1]] != ' ')printf(" %c ", sym[ops[i-1]]);printf("%d", i);}printf(" = %d\n" , result);}return;}ops[layer] = 2;dfs(layer + 1 , currentResult , lastOp , lastSum);currentResult += (lastOp)? (-1 * lastSum) : lastSum;ops[layer] = 0;dfs(layer + 1 , currentResult , 0 , 0);ops[layer] = 1;dfs(layer + 1 , currentResult , 1 , 0);}华为面试题 c语言(二)一面:介绍我的项目,针对我的项目中的点询问是如何实现的Activity生命周期?为什么Activity要这么设计?这样设计有什么好处?Android与iOS运行机制上有哪些不同?为什么Android用起来没有iOS流畅?为了让Android系统更流畅,应该从哪些方面做好?如何让Service不被杀死?Android系统分层?Library层起什么作用?如果一个应用要升级需要注意哪些方面?(我回答服务端api要兼容,如果只是小bug就通过补丁方式,但是貌似面试官不满意,就引导我说数据方面的,我才知道原来是想要我说本地数据的兼容)问我有什么要问他的?还有其他的一些问题,记不太清了….二面:二面是一个中年男人,一开始很严肃,聊了几句后它就笑嘻嘻了。

华为C语言面试题

华为C语言面试题

华为C语言面试题华为C语言经典面试题。

每道题都附有详细解答和讲解。

怎么判断链表中是否有环?bool CircleInList(Link* pHead){if(pHead = = NULL || pHead->next = = NULL)//无节点或只有一个节点而且无自环return (false);if(pHead->next = = pHead)//自环return (true);Link *pTemp1 = pHead;//step 1Link *pTemp = pHead->next;//step 2while(pTemp != pTemp1 && pTemp != NULL && pTemp->next != NULL){pTemp1 = pTemp1->next;pTemp = pTemp->next->next;}if(pTemp = = pTemp1)return (true);return (false);}两个字符串,s,t;把t字符串插入到s字符串中,s字符串有足够的空间存放t字符串void insert(char *s, char *t, int i){memcpy(&s[strlen(t)+i],&s[i],strlen(s)-i);memcpy(&s[i],t,strlen(t));s[strlen(s)+strlen(t)]='\0';}1。

编写一个C 函数,该函数在一个字符串中找到可能的最长的子字符串,且该字符串是由同一字符组成的。

char * search(char *cpSource, char ch){char *cpTemp=NULL, *cpDest=NULL;int iTemp, iCount=0;while(*cpSource){if(*cpSource == ch){iTemp = 0;cpTemp = cpSource;while(*cpSource == ch)++iTemp, ++cpSource;if(iTemp > iCount)iCount = iTemp, cpDest = cpTemp;if(!*cpSource)break;}++cpSource;}return cpDest;}2。

C语言面试题大汇总之华为面试题

C语言面试题大汇总之华为面试题

C语言面试题大汇总之华为面试题女性时尚购物网编辑:8、程序的局部变量存在于(堆栈)中,全局变量存在于(静态区 )中,动态申请数据存在于( 堆)中。

9、设有以下说明和定义:typedef union {long i; int k; char c;} DATE; struct data { int cat; DATE cow; double dog;} too; DATE max; 则语句 printf( "%d ",sizeof(struct date)+sizeof(max));的执行结果是:___52____ 答:DATE是一个union, 变量公用空间. 里面最大的变量类型是int, 占用20个字节. 所以它的大小是20 data是一个struct, 每个变量分开占用空间. 依次为int4 + DATE20 + double8 = 32. 所以结果是20 + 32 = 52. 当然...在某些16位编辑器下, int可能是2字节,那么结果是 int2 + DATE10 + double8 = 20 10、队列和栈有什么区别? 队列先进先出,栈后进先出11、写出下列代码的输出内容#include int inc(int a) { return(++a); } int multi(int*a,int*b,int*c) { return(*c=*a**b); } typedef int(FUNC1)(int in); typedef int(FUNC2) (int*,int*,int*); void show(FUNC2 fun,int arg1, int*arg2) { INCp=&inc; int temp =p(arg1); fun(&temp,&arg1, arg2);printf( "%d\n ",*arg2); } main() { int a; show(multi,10,&a); return 0; } 答:110 12、请找出下面代码中的所以错误说明:以下代码是把一个字符串倒序,如“abcd”倒序后变为“dcba”1、#include " " 2、main() 3、{ 4、 char*src= "hello,world "; 5、 char* dest=NULL; 6、int len=strlen(src); 7、dest=(char*)malloc(len); 8、 char* d=dest; 9、char* s=src; 10、 while(len--!=0) 11、 d++=s--;12、 printf( "%s ",dest); 13、 return 0; 14、} 答:方法1:int main() { char* src = "hello,world "; int len = strlen(src); char* dest = (char*)malloc(len+1);//要为\0分配一个空间char* d = dest; char* s = &src;//指向最后一个字符while( len-- != 0 ) *d++=*s--; *d = 0;//尾部要加\0 printf( "%s\n ",dest); free(dest);// 使用完,应当释放空间,以免造成内存汇泄露return 0; } 方法2:#include#include main() { char str= "hello,world "; int len=strlen(str); char t; for(int i=0; i> )%256 } 请问hash(16),hash(256)的值分别是: ;;; 找错题: 25.请问下面程序有什么错误? int a,i,j,k; for(k=0;k。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

C语言面试题精选学号:2009121041姓名:曹颖璐本题出自:华为C语言面试题题目:请写出下列代码的输出内容#include "stdio.h"int main(){int a,b,c,d;a = 10;b = a++;c = ++a;d = 10 * a++;printf("b,c,d:%d,%d,%d",b,c,d);return 0;}答:10,12,120学号:2009121042姓名:丁婷本题出自:雪花啤酒有限公司题目:将一个字符串“hello,world”逆序输出。

答案:#include<stdio.h>#include <string.h>int main(){char str[] = "hello,world";int len = strlen(str);char t;for (int i = 0; i < len / 2; i++){t = str[i];str[i] = str[len-i-1];str[len-i-1] = t;}printf("%s", str);return 0;}学号:2009121043姓名:杨柳本题出自:高等教育出版社题目:用指针的方法,将字符串“ABCD”前后对调显示。

答案:#include<stdio.h>#include<string.h>#include<dos.h>int main(void){char str[] = "ABCD1234efgh";int length = strlen(str);char *p1 = str;char *p2 = str + length - 1;while (p1 < p2){char c = *p1;*p1 = *p2;*p2 = c;++p1;--p2;}printf("str now is %s\n", str);system("pause");return 0;getch();}学号:2009121044姓名:郭茜敏本题出自:IBM写出下面程序的输出结果#include<stdio.h>void GetMemory ( char **p , int num){*p = (char *)malloc(num);}int main(){char *str = NULL;GetMemory( &str , 100);strcpy(str , "hello");free(str);if ( str != NULL){strcpy( str , "world");}printf("\n str is %s", str);getchar();}答案:str is world学号:2009121045姓名:王丹公司:百度知道——C语言面试题题目:在一个正整数序列中求和最大的非相邻子序列(序列任两元素在原序列里都不相邻)#include <stdio.h>int cal ( int h1, int length,int b[]);int main (){Unsigned int n[]={1,3,2,4,7,9,6};int length =7;printf ("%d", cal (-2,length,n) );return 0;}int cal ( int h1, int length , int b[]){if (length-h1 == 1)return b [h1];if (length-h1 == 2)return (b [h1] > b [h1 + 1] ? b[h1] : b[h1 + 1]);if (length-h1 == 3)return (b[h1] + b[h1+2] > b[h1 + 1] ? b[h1] + b[h1 + 2] : b[h1 + 1]);if (h1 >= 0)returnb [h1] + (cal (h1 + 2,length,b) > cal (h1 + 3,length,b) ? cal (h1 + 2,length,b) : cal(h1+3,length,b)); elsereturn (cal (h1 + 2,length,b) > cal (h1 + 3,length,b) ? cal (h1 + 2,length,b) : cal (h1 + 3,length,b)); }学号:2009121046姓名:陈凡题目:实现行程压缩,将重复的数据用重复次数来表达,例如:aaabbbccc->a3b3c3,abcd->abcd,aabcdd->a2bcd2,在代码实现过程中要考虑解压。

答案:#include <stdio.h>int main(void){char ch[100], ch1[100];void f1(char *);void f2(char *, char *);gets(ch);f1(ch);f2(ch, ch1);puts(ch1);return 0;}void f1(char *p1){char *p2, c;int lable, n;n = 1;lable = 0;while (*p1 != '\0') {c = *p1;if (c == *(p1+1)) {lable = 1;n++;if (n == 2)p2 = p1;} else {if( lable == 1)*(p2+1) = n + '0';n = 1;lable = 0;}p1++;}}void f2(char *p, char *p1){int i, j, n;i = 0;j = 0;while (*(p+i) != '\0') {if(*(p+i) >= '2' && *(p+i) <= '9') {*(p1+j++) = *(p+i);n = *(p+i) - '0';i += n -1;*(p1+j++) = *(p+i++);} else {*(p1+j) = *(p+i);j++;i++;}}*(p1+j) = '\0';}学号:2009121047姓名:孙晴本题出自:百度知道搜索——C语言面试题题目:求符合指定规则的数。

给定函数d(n) = n n的各位之和,n为正整数,如d(78) = 78 7 8=93。

这样这个函数可以看成一个生成器,如93可以看成由78生成。

定义数A:数A找不到一个数B可以由d(B)=A,即A不能由其他数生成。

现在要写程序,找出1至10000里的所有符合数A定义的数。

输出:13#include<stdio.h>int f[10001];int main(){int s , i , n , t ;for ( n = 0 ; n <= 10000 ; n++){s = t = n;while(t){s += t % 10;t/=10;}f[s] = 1;}for ( i = 1 ;i <= 10000 ; i++)if ( !f[i] )printf ( " %d \n " , i );}学号:2009121048姓名:李冰川本题出自:华为题目:请写出下面该程序的运行结果。

#include <stdio.h>int sum (int a){auto int c = 0;static int b = 3;c = c + 1;b = b + 2;return(a + b + c);}int main(void){int i;int a = 2;for(i = 0; i < 5; i++){printf("%d\n", sum(a));}}答案: 8 , 10 , 12 , 14 , 16学号:2009121049姓名:陈远凯本题出自:< 哈尔滨工大集团股份有限公司面试>题目:同构数,一个数,如果它出现在它的平方数的尾部,就称它为同构数,如5它们的平方是25。

现在请写出一个程序,求出从2~999之间的同构数。

答案:#include <stdio.h>#include <math.h>void main(){long int a, b, i, j, f = 0, d;/*定义变量*/printf("正在计算...\n");/*提示*/for (i = 2;i <= 999;i++)/*循环*/{a = i * i;for(j = 1;j <= 3;j++)/*二重循环*/{d = a % 10;a = a / 10;f = f + d * pow(10,j-1);if(f == i)/*判断尾数是否相同*/{printf("%ld\n",i);}if(a == 0)break;}f=0;/*重写变量*/}}学号:2009121050姓名:王迅题目:1元钱能买一瓶汽水,喝完后两个空瓶可以换一瓶汽水。

问:你有20元钱,最多可以喝到几瓶汽水?用C语言编写。

答案:int main(void){int n, i, m;n = 20;i = 0;for(n = 20; n >= 1; n--)//n为瓶子有个数1~20刚好20平{i++; //i为空平个数m = i;if(m % 2 == 0){n++;}}printf("%d", i);}学号:2009121051姓名:杨冰佳本题出自:成都某知名通讯公司题目:用指针的方法把一字符串倒序输出,如“abcd”倒序后变为“dcba”答案:方法1:int main(){char* src = "hello,world";int len = strlen(src);char* dest = (char*)malloc(len+1);//要为\0分配一个空间char* d = dest;char* s = &src[len-1];//指向最后一个字符while( len-- != 0 )*d++=*s--;*d = 0;//尾部要加\0printf("%s\n",dest);free(dest);// 使用完,应当释放空间,以免造成内存汇泄露return 0;}方法2:#include <stdio.h>#include <string.h>main(){char str[]="hello,world";int len=strlen(str);char t;for(int i=0; i<len/2; i++){t=str[i];str[i]=str[len-i-1]; str[len-i-1]=t;}printf("%s",str);return 0;}学号:2009121052姓名:付宇本题出自:美资公司题目:利用“正多边形逼近的方法”求圆周率的近似值。

相关文档
最新文档