100 条经典C语言笔试题目

您所在的位置:网站首页 c语言考试题库及答案 100 条经典C语言笔试题目

100 条经典C语言笔试题目

2022-10-11 04:57| 来源: 网络整理| 查看: 265

题目来源: 1、中兴、华为、慧通、英华达、微软亚洲技术中心等中 外企业面试题目; 2、C 语言面试宝典(林锐《高质量编程第三版》)。 说明: 1、部分C 语言面试题中可能会参杂部分和C++ 相关的知 识,为了保持题目的灵活性故保留,但选题最终还是 会以C 语言题目为主体; 2、以上公司的面试题目已成为国内中小型企业公司出题 模板; 3、由于本人的能力有限加上时间仓促,本课件肯定存在 不足之处,恳请各位同学批评指正。

请填写bool , float, 指针变量 与“零值”比较的if语句。

提示:这里“零值”可以是0, 0.0 , FALSE 或者“空指针”。 例如int变量n与“零值”比较的if语句为:

if ( n == 0 ) if ( n != 0 )

以此类推。

(1)请写出bool flag 与“零值”比较的if 语句:

【标准答案】

if(flag) { } if(!flag) { } (2)请写出float x 与“零值”比较的if 语句:

【标准答案】

const float EPSINON = 0.00001; if ((x >= - EPSINON) && (x =” 或“(Y)?(Y):(X))// 结尾没有 ; 带参宏与带参函数的区别(至少说出5点)?

【标准答案】

带参宏 带参函数 处理时间 编译时 运行时 参数类型 无 需定义 程序长度 变长 不变 占用存储空间 否 是 运行时间 不占运行时间 调用和返回时占 关键字volatile有什么含意?

【标准答案】 提示编译器对象的值可能在编译器未监测到的情况下改变。

问函数既然不会被其它函数调用,为什么要返回1? int main() { int x=3; printf("%d",x); return 1; }

问函数既然不会被其它函数调用,为什么要返回1? 【标准答案】 mian中,c标准认为0表示成功,非0表示错误。具体的值是某中具体出错信息。

已知一个数组tabl e ,用一个宏定义,求出数据的元素个数。

【标准答案】

#define NTBL(table) (sizeof(table)/sizeof(table[0])) A.c 和B.c两个c文件中使用了两个相同名字的static变量,编译的时候会不会有问题?这两个static变量会保存到哪里(栈还是堆或者其他的)?

【标准答案】 static的全局变量,表明这个变量仅在本模块中有意义,不会影响其他模块。他们都放在静态数据区,但是编译器对他们的命名是不同的。如果要使变量在其他模块也有意义的话,需要使用extern 关键字。

static全局变量与普通的全局变量有什么区别?

【标准答案】 static全局变量只初使化一次,防止在其他文件单元中被引用;

static局部变量和普通局部变量有什么区别

【标准答案】 static局部变量只被初始化一次,下一次依据上一次结果值;

static函数与普通函数有什么区别?

【标准答案】 static函数在内存中只有一份,普通函数在每个被调用中维持一份拷贝

关于45-47 的参考文章 全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量 。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方 式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变 量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态 的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作 用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文 件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只 能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。 从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储 方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的 作用域,限制了它的使用范围。 static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使 用的函数应该说明为内部函数(static),内部函数应该在当前源文件中 说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件 中说明,要使用这些函数的源文件要包含这个头文件。

程序的局部变量存在于___ 中,全局变量存在于____中,动态申请数据存在于___ 中。

【标准答案】 程序的局部变量存在于栈(stack) 中,全局变量存在于静态数据区中,动态申请数据存在于堆(heap)中。

什么是预编译,何时需要预编译:

【标准答案】 1.总是使用不经常改动的大型代码体。 2.程序由多个模块组成,所有模块都使用一组标准的包含文件和相同的编译选项。在这种情况下,可以将所有包含文件预编译为一个预编译头。

用两个栈实现一个队列的功能?要求给出算法和思路!

【标准答案】 设2个栈为A,B, 一开始均为空. 入队: 将新元素push入栈A; 出队: (1)判断栈B 是否为空; (2)如果不为空,则将栈A中所有元素依次pop 出并push到栈B; (3)将栈B 的栈顶元素pop 出;

对于一个频繁使用的短小函数,在C 语言中应用什么实现,在C++ 中应用什么实现?

【标准答案】 c用宏定义,c++ 用inline

1. 用预处理指令#define 声明一个常数,用以表明1年中有多少秒(忽略闰年问题)

【标准答案】

#define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL 哪种方法更好呢?

Typedef 在C 语言中频繁用以声明一个已经存在的数据类型的同义字。也可以用预处理器做类似的事。例如,思考一下下面的例子:

#define dPS struct s * typedef struct s * tPS;

以上两种情况的意图都是要定义dPS 和tPS 作为一个指向结构s指针。哪种方法更好呢?(如果有的话)为什么? 【标准答案】 这是一个非常微妙的问题,任何人答对这个问题(正当的原因)是应当被恭喜的。答案是:typedef 更好。思考下面的例子:

dPS p 1,p2; tPS p3,p4;

第一个扩展为

struct s * p1, p2;

上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许不是你想要的。第二个例子正确地定义了p3 和p4 两个指针。

在C++ 程序中调用被C 编译器编译后的函数,为什么要加extern “C”?

【标准答案】 C++ 语言支持函数重载,C 语言不支持函数重载。函数被C++ 编译后在库中的名字与 C 语言的不同。假设某个函数的原型为:void foo(int x, int y); 该函数被C 编译器编译后在库中的名字为_foo ,而C++ 编译器则会产生像_foo_int_int之类的名字。 C++提供了C 连接交换指定符号xtern“C”来解决名字匹配问题。

请简述以下两个for 循环的优缺点。

【标准答案】

语句for( ;1 ;) 有什么问题?它是什么意思?

【标准答案】 死循环,和while(1)相同。

do……while和while……do有什么区别?

【标准答案】 前一个循环一遍再判断,后一个判断以后再循环。

请写出下列代码的输出内容 #include 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

计算指针 unsigned char *p1; unsigned long *p2; p1=(unsigned char *)0x801000; p2=(unsigned long *)0x810000;

请问

p1+5= ; p2+5= ;

【标准答案】0x801005、0x810020

计算打印 main() { int a[5]={1,2,3,4,5}; int * ptr=(int*)(&a+1); printf(“%d,%d”,*(a+1),*(ptr-1)); }

请问输出: 【标准答案】2,5

请问下面程序有什么错误? int a[60][250][1000],i,j,k; for(k=0;k6” 。原因是当表达式中存在有符号类型和无符号类型时所有的数都自动转换为无符号类型。因此-20 变成了一个非常大的正整数,所以该表达式计算出的结果大于6 。这一点对于应当频繁用到无符号数据类型的嵌入式系统来说是丰常重要的。如果你答错了这个问题,你也就到了得不到这份工作的边缘。

评价下面的代码片断: unsigned int zero = 0; unsigned int compzero = 0xFFFF; /*1‘s complement of zero */

【标准答案】 对于一个int型不是16位的处理器为说,上面的代码是不正确的。应编写如下:

unsigned int compzero = ~0;

这一问题真正能揭露出应试者是否懂得处理器字长的重要性。在我的经验里,好的嵌入式程序员非常准确地明白硬件的细节和它的局限,然而PC机程序往往把硬件作为一个无法避免的烦恼。到了这个阶段,应试者或者完全垂头丧气了或者信心满满志在必得。如果显然应试者不是很好,那么这个测试就在这里结束了。但如果显然应试者做得不错,那么我就扔出下面的追加问题,这些问题是比较难的,我想仅仅非常优秀的应试者能做得不错。提出这些问题,我希望更多看到应试者应付问题的方法,而不是答案。不管如何,你就当是这个娱乐吧

下面的代码片段的输出是什么,为什么? char *ptr; if ((ptr = (char *)malloc(0)) == NULL) puts("Gota null pointer"); else puts("Gota valid pointer");

【标准答案】 这个你可以先大胆猜测下,然后再用你的 编译器尝试着编译下

欢迎进入C语言程序笔试面试,编写程序代码单元。

编写strcpy 函数

已知strcpy 函数的原型是 char *strcpy(char *strDest, const char *strSrc);其中strDest是目的字符串, strSrc 是源字符串。 (1)不调用C++/C 的字符串库函数,请编写函数 strcpy 。 (2)strcpy 能把 strSrc 的内容复制到strDest,为什 么还要char * 类型的返回值? 【标准答案】

写出二分查找的代码。

【标准答案】

int binary_search(int* arr, int k ey, int n) { int low = 0; int h igh = n - 1 ; int m id; while (low k) high = mid -1 ; else if (arr[mid] < k) low = mid + 1; else return mid; } return -1; } 请编写一个C 函数,该函数给出一个字节中被置1 的位的个数。

【标准答案】

unsigned int T estAsOne0(char log) { int i; unsigned int num=0, val; for(i=0; i> i; // 移位 val & = 0x01; // 与1 相与 if(val) num++; } return num; } 请编写一个C 函数,该函数将给定的一个字符串转换成整数。

【标准答案】

int Invert(char* str) { int num =0; while(*str!='\0') { int d igital=*str-48; num=num*10+digital; str=str+1; } return num; } 请编写一个C 函数,该函数将给定的一个整数转换成字符串。

【标准答案】

void IntToCharChange(int num, char* pval) { char strval[100]; int i , j; int val0 = 0; int val1 = 0; val0 = num; for(i=0; i 99) return; } source[j] = '\0'; for(i=0; inext && t2->next) { t1 = t1->next; if (NULL == (t2 = t2->next->next)) return 0; // 无环 if (t1 == t2) return 1; } return 0; } 有一浮点型数组A, 用C 语言写一函数实现对浮点

数组A进行降序排序,并输出结果,要求要以数组A 作为 函数的入口.( 建议用冒泡排序法) 【标准答案】

void BubbleSort(double a rr[], int n) { int i,j ; int e xchange = 1 ;// 交换标志 for(i=1;i=i ;j--) //对当前无序区R[i..n]自下向上扫描 if(arr[j+1] > arr [ j]) {// 交换记录 arr[0]=arr[j+1];//R[0]不是哨兵,仅做暂存单元 arr[j+1]=arr[j]; arr[j]=arr[0]; exchange=1 ;// 发生了交换,故将交换标志置为真 } if(!exchange) // 本趟排序未发生交换,提前终止算法 return; } //endfor(外循环) } 实现双向链表删除一个节点P,在节点P 后插入一

个节点,写出这两个函数。 【标准答案】

// 删除操作 Status ListDelete_DuL(DuLinkList &L,inti,Ele mType &e) { if(!(p=G e tElemP_DuL(L,i))) return ERROR; e=p->data; p->prior->next=p->next; p->next->prior=p->pror; free(p); return OK; } // 插入操作 Status ListInsert_DuL(DuLinkList &L,inti,ElemType &e) { if(!(p=G e tElemP_DuL(L,i))) return ERROR; if(!(s=(DuLinkList)malloc(sizeof(DuLNode)))) return ERROR; s->data=e; s->pri or =p; p-> next -> prior =s; p->next=s; s->next=p->next->next; return OK; } 把一个链表反向。

【标准答案】 从第一个元素开始,ps指向他,将他(ps)指向头节点(ps->next = head) ,将ps设为头节点(head = ps; )操作下一个元素(ps= pe->next;)等 于是依次将每个元素翻到原头节点前面。

void reverse(test* head) { test* pe = head; test* ps = head->next; while(ps) { pe->next = ps->next; ps->next = head; head = ps; ps = pe->next; } } 将二维数组行列元素互换,存到另一个数组中。

【标准答案】

#include main() { int a [2][3]={{1,2,3},{4,5,6}}; int b[3][2],i,j; printf("array a :\n"); for(i=0;i


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3