C几个经典的关于内存的C语言笔试题7(25)

C++&C面试题100道分析(61-80)
时间: 20:55:55
&&&& 阅读:27
&&&& 评论:
&&&& 收藏:0
标签:&&&&&&&&&&&&&&&&&&&&&&&&&&&61.字符指针、浮点数指针、以及函数指针这三种类型的变量哪个占用的内存最大?为什么?
  指针变量占有的空间是固定的,他和计算机操作系统的位数有关系。
62.构造函数可否是虚函数,为什么?析构函数呢,可否是纯虚的呢?
  构造函数不可以是虚函数,构造函数的作用是申请内存空间,实例化类成为对象的,而虚函数存储在虚函数表中,构造函数执行的时候还没有空间,也没有虚函数表。
  析构函数可以是虚函数。
63.C++的空类,默认产生哪些类成员函数?(c++类中默认的一些方法)
class Empty{public:Empty(); // 缺省构造函数Empty ( const Empty&
) ; // 拷贝构造函数~Empty(); // 虚构函数Empty& operator(const Empty& ) // 赋值运算符Empty& operator&(); // 取址运算符const Empty* operator&() //
取址运算符 const}
//缺省构造函数,缺省拷贝构造函数,缺省析构函数,对符号 = , && , * 的重载。
64.拷贝构造函数相关问题,深拷贝,浅拷贝等
  拷贝构造分为浅拷贝和深拷贝,
  所谓的浅拷贝就是仅仅拷贝地址,而不拷贝地址指向的内容。浅拷贝可能会在结束的时候对对象的空间二次释放。
  深拷贝就是拷贝地址指向的内容而不是简单的拷贝地址。
65.下面的代码是否有问题?
unsigned int const size1 = 2;char str1[ size1 ];unsigned int temp = 0;cin &&unsigned int const size2 =char str2[ size2 ];
  数组的长度必须在编译时期就确定,常变量可以初始化
  第二个str2并没有确定长度,所以无法是错误的。
66.c++中那些函数不可以被声明成为虚函数?
  1.普通函数,虚函数是类中的函数,普通函数不可以被声明。
  2.构造函数,构造函数不能通过虚函数表来调用,他运行在虚函数表产生之前。
  3.静态函数,静态函数不可以被继承
  4.友元函数,
67.当一个类 A 中没有生命任何成员变量与成员函数,&这时 sizeof(A)的值是多少,请解释一下编译器为什么没有让它为零。
  需要区分不同的对象,需要设置虚函数指针。
68.以下代码中的输出语句输出0 0 吗,为什么?
struct CLS{int m_i;CLS( int i ) : m_i(i) {}CLS() {CLS(0);}};CLScout && obj.m_i &&
不会,考察初始化表的执行。
如果在默认构造函数中调用构造函数,只会执行函数体,而不会执行初始化表达式不会执行。
只有在类实例成对象的时候才会执行初始化表达式。
69.What are the values of a, b, and c after thefollowing instructions:
int a=5, b=7,c = a+++b;
++的优先级高,而且执行的顺序是从右向左,所以先读取的是++,然后在执行++;
b = 7 , c = 12 , a = 6;
70.在排序方法中,关键码比较次数与记录地初始排列无关的是()
A. Shell 排序 B. 归并排序C.
直接插入排序 D. 选择排序
希尔排序:选择位置是4,2,1的余数的排列。
归并排序:8 , 4& ,2& , 1 ,逐渐的排序。
直接插入,从后面开始,向前移动,把数据插入到有序的队列中
选择排序,c++STL中algorithm中有sort可以对vector,string,dequeu
71.代码 void func()
{…}void func(){…}
中,变量 val 的内存地址位于:A.
已初始化数据段 B. 未初始化数据段C.堆 堆 D.栈
答案:A,static修饰的变量,会被初始化,所以应该放在已经初始化的数据段。
  数据段中还会存放全局变量
class A {public:A() { p= }~A() { if(p!=NULL) { p=NULL; } }A*};
上面的代码有什么问题?
P指向的是this也就是对象自己,delet会调用自己的析构函数,这样就会无限的循环下去。
73.写出判断 ABCD 四个表达式的是否正确, 若正确, 写出经过表达式中& a 的值。
int a = 4;(A)a += (a++);& & (B) a += (++a) ;(C)(a++) +=& & (D) (++a) += (a++);
A& a = a +& & a ++& & a = 9
B a++ a = a+ a& a = 10;
C,左侧没有可以赋值的变量
74.请你谈谈你是如何使用 return语句的。
  return表明一个函数体的结束,一些内存的释放。
  return返回值的类型,有指针,引用,普通变量。
  也要考虑效率
75.return String(s1 + s2); 和②String temp(s1 +s2);String temp(s1 +s2); 一样吗?
  不一样,第一条语句是返回了一个临时的变量。
  第二条语句是创建了一个局部变量,在函数结束的时候,这个局部变量还会被销毁。
  第一条语句建立的临时变量会不需要被销毁。
76.下列代码执行的结果,理由?
inline void max_out( int val1, int val2 ) {cout && ( val1 & val2 ) ? val1 : val2;}int main() {int ix = 10, jx = 20;cout && "The larger of " &&cout && ", " && jx && " is ";max_out( ix, jx );cout &&}
  执行的结果是 The larger of 10, 20 is 0;
  此处在cout语句中使用了三目运算符(条件选择运算符),&& 的优先级比 ?: 的优先级要高,所以返回的是比较的结果。
77.下列语句算重载还是重复声明
int max( int *ia, int sz );int max( int *, int = 10 );
他们的区别是一个具有默认参数,一个没有默认参数。
因为只有缺省时他们的参数列表才不一样,所以他们不是重载,而是重复声明了。
78.请编写一个 C 函数,该函数给出一个字节中被置1 的位的个数。
int count(char tmp)
int count = 0;
for(int i = 0 ; i & 8 ; i ++)
char ret = tmp & 0x01;
tmp = tmp && 1;
//编写一个函数,函数接收一个字符串, , 是由十六进制数组成的一组字符串, ,函//数的功能是把接到的这组字符串转换成十进制数字函数的功能是把接到的这组字//符串转换成十进制数字. . 并将十进制数字返回。
int mun(int len)
int tmp = <span style="color: #;
for(int i = <span style="color: # ; i &i++)
tmp *= <span style="color: #;
int HToD(string tmp)
int length = tmp.length();
int sum = <span style="color: #;
for(int i = <span style="color: # ; i & i++)
int tmp1 ;
if(tmp[i] & <span style="color: #)
tmp1 = tmp[i] - <span style="color: #;
else if(tmp[i] & <span style="color: #)
tmp1 = tmp[i] - <span style="color: #;
tmp1 = tmp[i] - <span style="color: #;
sum += mun(length-i-<span style="color: #)
80.输入一个字符串,将其逆序后输出 。
string reserve(string tmp)
int length = tmp.length();
for(int i = <span style="color: # ; i & length /<span style="color: #; i++)
excharge = tmp[i];
tmp[i] = tmp[length - i -<span style="color: # ];
tmp[length - i - <span style="color: #] =
&标签:&&&&&&&&&&&&&&&&&&&&&&&&&&&原文地址:https://www.cnblogs.com/qiny1012/p/9461118.html
&&国之画&&&& &&&&chrome插件
版权所有 京ICP备号-2
迷上了代码!100 条经典C语言笔试题目
题目来源:
1、中兴、华为、慧通、英华达、微软亚洲技术中心等中
外企业面试题目;
2、C 语言面试宝典(林锐《高质量编程第三版》)。
1、部分C 语言面试题中可能会参杂部分和C&#43;&#43; 相关的知
识,为了保持题目的灵活性故保留,但选题最终还是
会以C 语言题目为主体;
2、以上公司的面试题目已成为国内中小型企业公司出题
3、由于本人的能力有限加上时间仓促,本课件肯定存在
不足之处,恳请各位同学批评指正。
1、请填写bool , float, &指针变量 与“零&#20540;”比较的if &
提示:这里“零&#20540;”可以是0, 0.0 , FALSE &或者“空指针”
。例如int 变量n &与“零&#20540;”比较的if &语句为:
if ( n == 0 )&
if ( n != 0 )&
以此类推。
(1)请写出bool flag &与“零&#20540;”比较的if &语句:
【标准答案】if ( flag ) & &if ( !flag )
100 条经典 C语言笔试题目
(2)请写出float &x & 与“零&#20540;”比较的if &语句:
【标准答案】 const float EPSINON = 0.00001; & & & & & & & & & &
if ((x &= - EPSINON) && (x &= EPSINON) & & & & & & & & &
不可将浮点变量用“==” 或“!=” 与数字比较,应该设法
转化成“&=” 或“&=” 此类形式。
100 条经典 C语言笔试题目
(3)请写出char &*p & 与“零&#20540;”比较的if &语句
【标准答案】 if (p == NULL) & &if (p != NULL)&
2、以下为Linux下的32 位C 程序,请计算sizeof 的
&#20540;。
char &str[] = “Hello” ; & & & & & & & & & & & & & & &&
char & *p = & & & & & & & & & & & & & & & & & & &
i nt & &n = 10; & & & & & & & & & & & & & & & & & & & & & & & & & &
(1)sizeof (str ) = & & & & & & & & &(2)s i zeof ( p ) = & & & & & & & &&
(3)sizeof ( n ) =
【标准答案】
(1)6、(2)4 、(3 )4
(4)void Func ( char str[100]) & & & & & & & & & & & & &&
{ & & & & & & & & & & & & & & & & & & & & &
…… ; & & & & & & & & & & & & & & & & & & & & & & & & & & & & & &
} & & & & & & & & & & & & & & & & & & & & &
请计算sizeof( str ) = & & & & & & & & & & & & & & & & & & &&
(5)void * p = malloc( 100 ); & & & & & & & & & & & & & & & & & & & & & & & &
请计算sizeof ( p ) =&
【标准答案】(4)4、(5)4
4、用变量a 给出下面的定义
e) 一个有10个指针的数组,该指针是指向一个整型数
f) &一个指向有10个整型数数组的指针;
g) 一个指向函数的指针,该函数有一个整型参数并返
回一个整型数;
h) 一个有10个指针的数组,该指针指向一个函数,该
函数有一个整型参数并返回一个整型数;
【标准答案】e)int * &a[10]; & & &f)int (*a)[10] & & & & & & & & & & & & & & & &&
g)int (*a)(int); & h) int (*a[10])(int)
5、设有以下说明和定义:
typedef u nion { int k[5];} DATE;
struct data { DATE}
则语句printf(&%d&,sizeof(struct date)&#43;sizeof(max)); 的
执行结果是:_____
【标准答案】DATE是一个union, 变量公用空间. &里面最
大的变量类型是int[5], &占用20个字节. &所以它的大小是
data 是一个struct, &每个变量分开占用空间. &依次为int4 &#43;&
DATE20 &#43; double8 = 32.
所以结果是20 &#43; 32 = 52.
当然... 在某些16位编辑器下, int 可能是2字节,那么结果
是int2 &#43; DATE10 &#43; double8 = 20
6、请问以下代码有什么问题:
int main()
char *str=&a;
strcpy(str,&hello&);
printf(str);
【标准答案】没有为str分配内存空间,将会发生异常
问题出在将一个字符串复制进一个字符变量指针所指
地址。虽然可以正确输出结果,但因为越界进行内在
读写而导致程序崩溃。
7、请问以下代码有什么问题:
char* s=&AAA&;
printf(&%s&,s);
printf(&%s&,s);
有什么错?
【标准答案】&AAA& 是字符串常量。s是指针,指向这个
字符串常量,所以声明s的时候就有问题。
cosnt char* s=&AAA&;
然后又因为是常量,所以对是s[0] 的赋&#20540;操作是不合法
8、int (*s[10])(int) &表示的是什么啊
【标准答案】int (*s[10])(int) &函数指针数组,每个指针
指向一个int func(intp aram) 的函数。
9、c和c&#43;&#43; 中的struct有什么不同?
【标准答案】c和c&#43;&#43; 中struct的主要区别是c中的struct
不可以含有成员函数,而c&#43;&#43; 中的struct可以。c&#43;&#43; 中
struct和class的主要区别在于默认的存取权限不同,
struct默认为public ,而class默认为private
10、void getmemory(char *p)
p=(char *) malloc(100);
strcpy(p,“hello world”);
int main( )
char *str=NULL;
getmemory(str);
printf(“%s/n”,str);
free(str);
} 会出现什么问题?
【标准答案】程序崩溃,getmemory中的malloc 不能返回
动态内存,free ()对str操作很危险。
11、char szstr[10];
strcpy(szstr,&&);
产生什么结果?为什么?
【标准答案】长度不一样,出现段错误。
100 条经典 C语言笔试题目
12、数组和链表的区别?
【标准答案】数组:数据顺序存储,固定大小;
链表:数据可以随机存储,大小可动态改变
13、void main()
char aa[10];
printf(“%d”,strlen(aa));
} & & & & & & & & & & & & & & & & & & & & &
会出现什么问题?打印结果是是多少?
【标准答案】sizeof()和初不初始化,没有关系,
strlen()和初始化有关,打印结果&#20540;未知。
14、给定结构struct A
unsigned short i:8;
}; 问sizeof(A) = ?
【标准答案】8
15、struct name1{
} ;求sizeof(name1)?
【标准答案】8
16、struct name2{
}; 求sizeof(name2)?
【标准答案】12
17、程序哪里有错误
wap( int* p1,int* p2 )
*p1 = *p2;
【标准答案】p 为野指针(指向一个已删除的对象或未申请访问受限内存区域的指针)
19、(void *)ptr 和(*(void**))ptr 的结果是否相同?其
中ptr为同一个指针。
【标准答案】(void *)ptr 和(*(void**))ptr &#20540;是相同的
20、要对绝对地址0x100000赋&#20540;,我们可以用
(unsigned int*)0x100000 = 1234;
那么要是想让程序跳转到绝对地址是0x100000去执行
,应该怎么做?
【标准答案】*((void (*)( ))0x100000 ) ( );
首先要将0x100000强制转换成函数指针,即:
(void (*)())0x100000
然后再调用它:
*((void (*)())0x100000)();
22、关于内存的思考题(1)你能看出有什么问题?
23、关于内存的思考题(2)你能看出有什么问题?
25、关于内存的思考题(3)你能看出有什么问题?
26、关于内存的思考题(4)你能看出有什么问题?
27、关键字volatile有什么含意? 并给出三个不同的例
【参考答案】一个定义为volatile的变量是说这变量可
能会被意想不到地改变,这样,编译器就不会去假设
这个变量的&#20540;了。精确地说就是,优化器在用到这个
变量时必须每次都小心地重新读取这个变量的&#20540;,而
不是使用保存在寄存器里的备份。下面是volatile变量
的几个例子:
1). 并行设备的硬件寄存器(如:状态寄存器)
2). 一个中断服务子程序中会访问到的非自动变量
(Non-automatic variables)
3). 多线程应用中被几个任务共享的变量
28、嵌入式系统经常具有要求程序员去访问某特定的
内存位置的特点。在某工程中,要求设置一绝对地址
为0x67a9的整型变量的&#20540;为0xaa66。编译器是一个纯
粹的ANSI编译器。写代码去完成这一任务。
【参考答案】这一问题测试你是否知道为了访问一绝对
地址把一个整型数强制转换(typecast )为一指针是合
法的。这一问题的实现方式随着个人风&#26684;不同而不同
。典型的类&#20284;代码如下:
ptr= &(int *)0x67a9;
*ptr = 0xaa55;
29、头文件中的ifndef/define/endif 干什么用?
【标准答案】防止该头文件被重复引用。
30、#include &&filename.h& & &和#include &
“filename.h” 有什么区别?
【标准答案】对于#include &&filename.h& & ,编译器从
标准库路径开始搜索filename. & & & & & & & & & & & & & & & &
对于#include &“filename.h” ,编译器从用户的工作路
径开始搜索filename.h 。
31、const & 有什么用途?(请至少说明两种)
【标准答案】: (1)可以定义const & 常量
(2)const &可以修饰函数的参数、返回&#20540;,甚至函数
的定义体。被const &修饰的东西都受到强制保护,可
以预防意外的变动,能提高程序的健壮性。
32、static有什么用途?(请至少说明两种)
【标准答案】
1. 限制变量的作用域(static全局变量);
2. 设置变量的存储域(static局部变量)。
33、堆栈溢出一般是由什么原因导致的?
【标准答案】没有回收垃圾资源。
34、如何引用一个已经定义过的全局变量?
【标准答案】可以用引用头文件的方式,也可以用
extern 关键字,如果用引用头文件方式来引用某个在
头文件中声明的全局变理,假定你将那个变量写错了
,那么在编译期间会报错,如果你用extern 方式引用
时,假定你犯了同样的错误,那么在编译期间不会报
错,而在连接期间报错。
35、全局变量可不可以定义在可被多个.C 文件包含的
头文件中?为什么?
【标准答案】可以,在不同的C 文件中以static形式来声
明同名全局变量。可以在不同的C文件中声明同名的全
局变量,前提是其中只能有一个C文件中对此变量赋初
&#20540;,此时连接不会出错。
36、队列和栈有什么区别?
【标准答案】队列先进先出,栈后进先出。
37、Heap与stack的差别。
【标准答案】Heap是堆,stack是栈。
Stack的空间由操作系统自动分配/释放,Heap上的空
间手动分配/释放。
Stack空间有限,Heap是很大的自由存储区
C 中的malloc 函数分配的内存空间即在堆上,C&#43;&#43;中对
应的是new 操作符。
程序在编译期对变量和函数分配内存都在栈上进行,且
程序运行过程中函数调用时参数的传递也在栈上进行。
38、用宏定义写出swap(x,y),即交换两数。
【标准答案】
#define swap(x, y) (x)=(x)&#43;(y);(y)=(x)–(y);(x)=(x)–(y);
39、写一个“标准”宏,这个宏输入两个参数并返回较
小的一个。
【标准答案】#define Min(X, Y) ((X)&(Y)?(Y):(X))// 结尾没有 ;
40、带参宏与带参函数的区别(至少说出5点)?
【标准答案】
& & & & & & & & & &
& 带参宏 & & & & & & & &带参函数
处理时间 & & & & & & 编译时 & & & & & & & &运行时
参数类型 & & & & & & & & 无 & & & & &
& & &需定义
程序长度 & & & & & & & &变长 & & & &
& & & &不变
占用存储空间 & & & & & 否 & & & & &
& & & & &是
运行时间 & & & & & 不占运行时间 & & &调用和返回时占
41、关键字volatile有什么含意?
【标准答案】提示编译器对象的&#20540;可能在编译器未监测
到的情况下改变。
42、int main()
printf(&%d&,x);
问函数既然不会被其它函数调用,为什么要返回1?
【标准答案】mian中,c标准认为0表示成功,非0表示
错误。具体的&#20540;是某中具体出错信息。
43、已知一个数组tabl e ,用一个宏定义,求出数据的
元素个数。
【标准答案】
#define NTBL(table) (sizeof(table)/sizeof(table[0]))
44、A.c 和B.c两个c文件中使用了两个相同名字的
static变量,编译的时候会不会有问题?这两个static变量
会保存到哪里(栈还是堆或者其他的)?
【标准答案】static的全局变量,表明这个变量仅在本
模块中有意义,不会影响其他模块。
他们都放在静态数据区,但是编译器对他们的命名是
如果要使变量在其他模块也有意义的话,需要使用
extern 关键字。
45、static全局变量与普通的全局变量有什么区别?
【标准答案】 static全局变量只初使化一次,防止在其
他文件单元中被引用;
46、static局部变量和普通局部变量有什么区别
【标准答案】static局部变量只被初始化一次,下一次
依据上一次结果&#20540;;
47、static函数与普通函数有什么区别?
【标准答案】static函数在内存中只有一份,普通函数在
每个被调用中维持一份拷贝
关于45-47 的参考文章
全局变量(外部变量)的说明之前再冠以static 就构成了静态的全局变量
。全局变量本身就是静态存储方式,静态全局变量当然也是静态存储方
式。这两者在存储方式上并无不同。这两者的区别虽在于非静态全局变
量的作用域是整个源程序,当一个源程序由多个源文件组成时,非静态
的全局变量在各个源文件中都是有效的。而静态全局变量则限制了其作
用域,即只在定义该变量的源文件内有效,在同一源程序的其它源文
件中不能使用它。由于静态全局变量的作用域局限于一个源文件内,只
能为该源文件内的函数公用,因此可以避免在其它源文件中引起错误。
从以上分析可以看出,把局部变量改变为静态变量后是改变了它的存储
方式即改变了它的生存期。把全局变量改变为静态变量后是改变了它的
作用域,限制了它的使用范围。
static函数与普通函数作用域不同。仅在本文件。只在当前源文件中使
用的函数应该说明为内部函数(static),内部函数应该在当前源文件中
说明和定义。对于可在当前源文件以外使用的函数,应该在一个头文件
中说明,要使用这些函数的源文件要包含这个头文件。
48、程序的局部变量存在于___ 中,全局变量存在于
____中,动态申请数据存在于___ 中。
【标准答案】程序的局部变量存在于栈(stack) 中,全局
变量存在于静态数据区中,动态申请数据存在于堆(
heap)中。
49、什么是预编译,何时需要预编译:
【标准答案】1、总是使用不经常改动的大型代码体
2、程序由多个模块组成,所有模块都使用一组标准
的包含文件和相同的编译选项。在这种情况下,可以
将所有包含文件预编译为一个预编译头。
50、用两个栈实现一个队列的功能?要求给出算法和
【参考答案】设2个栈为A,B, 一开始均为空.
将新元素push入栈A;
(1)判断栈B 是否为空;
(2)如果不为空,则将栈A中所有元素依次pop 出并
push到栈B;
(3)将栈B 的栈顶元素pop 出;
51、对于一个频繁使用的短小函数,在C 语言中应用什
么实现,在C&#43;&#43; 中应用什么实现?
【标准答案】c用宏定义,c&#43;&#43; 用inline
52、1. 用预处理指令#define &声明一个常数,用以表
明1年中有多少秒(忽略闰年问题)
【参考答案】#define SECONDS_PER_YEAR (60 * 60&
* 24 * 365)UL
53、Typedef 在C 语言中频繁用以声明一个已经存在的
数据类型的同义字。也可以用预处理器做类&#20284;的事。例
如,思考一下下面的例子:
#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 两个指针。
54、在C&#43;&#43; &程序中调用被C 编译器编译后的函数,
为什么要加extern “C”?
【标准答案】C&#43;&#43; 语言支持函数重载,C 语言不支持函
数重载。函数被C&#43;&#43; 编译后在库中的名字与 C 语言的
不同。假设某个函数的原型为:void foo(int x, int y);&
该函数被C 编译器编译后在库中的名字为_foo ,而
C&#43;&#43; 编译器则会产生像_foo_int_int之类的名字。 C&#43;&#43;
提供了C 连接交换指定符号extern“C”来解决名字匹配
55、请简述以下两个for &循环的优缺点。
【标准答案】
56、语句for( &;1 &;) 有什么问题?它是什么意思?
【标准答案】死循环,和while(1)相同。
57、do……while和while……do有什么区别?
【标准答案】前一个循环一遍再判断,后一个判断以后
58、请写出下列代码的输出内容
#include &stdio.h&
int main()
int a,b,c,d;
b=a&#43;&#43;;
c=&#43;&#43;a;
d=10*a&#43;&#43;;
printf(&b,c ,d:%d,%d,%d&,b,c,d );
【标准答案】10,12,120
59、unsigned char *p1;
unsigned long *p2;
p1=(unsigned char *)0x801000;
p2=(unsigned long *)0x810000;
请问p1&#43;5= ;
p2&#43;5= ;
【标准答案】0xx810020
60、main()
int a[5]={1,2,3,4,5};
int * ptr=(int*)(&a&#43;1);
printf(“%d,%d”,*(a&#43;1),*(ptr-1));
请问输出:
【标准答案】2,5
61、请问下面程序有什么错误?
int a[60][250][1000],i,j,k;
for(k=0;k&=1000;k&#43;&#43;)
for(j=0;j&250;j&#43;&#43;)
for(i=0;i&60;i&#43;&#43;)
a[i][j][k]=0;
【标准答案】把循环语句内外换一下。
62、以下是求一个数的平方的程序,请找出错误:
#define SQUARE(a)((a)*(a))
b=SQUARE(a&#43;&#43;);
【标准答案】宏在预编译时会以替换的形式展开,仅仅
会替换。涉及到宏的地方,不要用&#43;&#43;-- ,标准中对此
没有规定,因此最终结果将会依赖于不同的编译器。
执行程序的答案可能是25、也有可能是36。
63、#define Max_CB 500
void LmiQueryCSmd(StructMSgCB * pmsg)
unsigned char ucCmdN
for(ucCmdNum=0;ucCmdNum&Max_CB;ucCmdN
um&#43;&#43;)
} & & & & & & & & & & & & & & & & & & & & &
} 这段代码执行有什么问题?
【标准答案】死循环
unsigned char //无符号字符型表示范围0~255
char // 有符号字符型 表示范围-128~127
64、嵌入式系统中经常要用到无限循环,你怎么用C
编写死循环。
【标准答案】while(1){}或者for(;;)
100 条经典 C语言笔试题目
65、程序输出结果是?
【标准答案】8 ,10,12,14,16
【标准答案】16
67、int modifyvalue()
return(x&#43;=10);
int c hangevalue(int x )
return(x&#43;=1);
void m ain()
int x =10;
x&#43;&#43;;
changevalue(x);
x&#43;&#43;;
modifyvalue();
printf(&First output:%dn&,x);
x&#43;&#43;;
changevalue(x);
printf(&Second output:%dn&,x);
modifyvalue();
printf(&Thirdoutput:%dn&,x);
【标准答案】12、13、13
68、不能做switch()的参数类型是:
【标准答案】switch 的参数不能为实型。
69、请写出下列代码的输出内容
#i nclude&stdio.h&
int a,b,c,d;
b=a&#43;&#43;;
c=&#43;&#43;a;
d=10*a&#43;&#43;;
printf(&b,c ,d:%d,%d,%d&,b,c,d );
【标准答案】10,12,120
70、找出程序的错误。
【标准答案】
71、一语句实现x是否为2 的若干次幂的判断。
【参考答案】 void mai n() & & & & & & & & & & & & & & & & & & & & & & & &
{ & & & & & & & & & & & & & & & & & & & & &
& & & & & & & & & & & & & & & & & & & & & & & & & & & &&
scanf(“%d”,&a); & & & & & & & & & & & & & & & & & &
printf(“%c”,(a)&(a-1)?’n’:’y’); // & 若是打印y,否则n & & & & &
72、中断是嵌入式系统中重要的组成部分,这导致了很多编译开发商提
供一种扩展—让标准C 支持中断。具代表事实是,产生了一个新的关键字
__interrupt 。下面的代码就使用了__interrupt 关键字去定义了一个中断服
务子程序(ISR),请评论一下这段代码的。
__interrupt double compute_area (double radius)
double area = PI * radius *
printf(& Area = %f&, area);
【参考答案】这个函数有太多的错误了,以至让人不知从何说起了:
1). ISR 不能返回一个&#20540;。如果你不懂这个,那么你不会被雇用的。
2). ISR 不能传递参数。如果你没有看到这一点,你被雇用的机会等同第
3). 在许多的处理器/编译器中,浮点一般都是不可重入的。有些处理器/编
译器需要让额处的寄存器入栈,有些处理器/编译器就是不允许在ISR 中做
浮点运算。此外,ISR 应该是短而有效率的,在ISR 中做浮点运算是不明
4). 与第三点一脉相承,printf() 经常有重入和性能上的问题。如果你丢掉
了第三和第四点,我不会太为难你的。不用说,如果你能得到后两点,那
么你的被雇用前景越来越光明了。
73、下面的代码输出是什么,为什么?
void foo(void)
unsigned int a = 6;
int b = -20;
(a&#43;b& 6)? puts(&& 6&) : puts(&&= 6&);
【参考答案】这个问题测试你是否懂得C 语言中的整数自动转换原则,
我发现有些开发者懂得极少这些东西。不管如何,这无符号整型问题的答
案是输出是“&6” 。原因是当表达式中存在有符号类型和无符号类型时所有
的数都自动转换为无符号类型。因此-20 变成了一个非常大的正整数,所
以该表达式计算出的结果大于6 。这一点对于应当频繁用到无符号数据类
型的嵌入式系统来说是丰常重要的。如果你答错了这个问题,你也就到了
得不到这份工作的边缘。
74、评价下面的代码片断:
unsigned int zero = 0;
unsigned int compzero = &0xFFFF;
/*1‘s complement of zero */
【参考答案】对于一个int型不是16位的处理器为说,上面的代码是不正
确的。应编写如下:
unsigned int compzero = ~0;
这一问题真正能揭露出应试者是否懂得处理器字长的重要性。在我的经
验里,好的嵌入式程序员非常准确地明白硬件的细节和它的局限,然而
PC机程序往往把硬件作为一个无法避免的烦恼。
到了这个阶段,应试者或者完全垂头丧气了或者信心满满志在必得。如
果显然应试者不是很好,那么这个测试就在这里结束了。但如果显然应
试者做得不错,那么我就扔出下面的追加问题,这些问题是比较难的,
我想仅仅非常优秀的应试者能做得不错。提出这些问题,我希望更多看
到应试者应付问题的方法,而不是答案。不管如何,你就当是这个娱乐
75、下面的代码片段的输出是什么,为什么?
if ((ptr = (char *)malloc(0)) == NULL)
puts(&Gota null pointer&);
puts(&Gota valid pointer&);
【参考答案】这个你可以先大胆猜测下,然后再用你的
编译器尝试着编译下~~
100 条经典 C语言笔试题目
欢迎进入C语言程序笔试面试,编写程序代码单元。
76、编写strcpy 函数
已知strcpy 函数的原型是 char *strcpy(char *strDest,&
const char *strSrc);其中strDest是目的字符串,
strSrc 是源字符串。
(1)不调用C&#43;&#43;/C 的字符串库函数,请编写函数
(2)strcpy 能把 strSrc 的内容复制到strDest,为什
么还要char * &类型的返回&#20540;?
77、写出二分查找的代码。
【参考答案】 int b inary_search(int* arr, int k ey, int n)
int low = &0;
int h igh = n - 1 ;
while (low &= high)
mid = (high &#43; low) / 2;
if (arr[mid] & k)
high = mid -1 ;
else if (arr[mid] & k)
low = mid &#43; 1;
return -1;
78、请编写一个C 函数,该函数给出一个字节中被置
1 &的位的个数。
【参考答案】
unsigned int T estAsOne0(char log)&
unsigned int num=0,&
for(i=0; i&8; i&#43;&#43;)&
va l = &log && &i; &// 移位
val & = 0x01; &// 与1 相与
num&#43;&#43;;&
79、请编写一个C 函数,该函数将给定的一个字符串
转换成整数。
【参考答案】
int Invert(char* str)&
int num =0;&
while(*str!='\0')&
int d igital=*str-48;&
num=num*10&#43;&
str=str&#43;1;&
80、请编写一个C 函数,该函数将给定的一个整数转
换成字符串。
【参考答案】
void IntToCharChange(int num, &char* pval)&
char strval[100];&
int val0 = 0;&
int val1 = 0;&
for(i=0; i&100; i&#43;&#43;)&
val1 = val0 % 10; //取余
val0 = val0 / 10; // 取整
strval[i] = val1 &#43; 48; &// 数字—字符
if(val0 & 10)&
i&#43;&#43;;&
strval[i] = val0 &#43; 48;&
for(j=0; j&=i; j&#43;&#43;) &// 倒置
pval[j] = strval[i-j];&
pval[j] = '\0';&
81、实现strcmp 函数。
【参考答案】
int m ystrcmp(const c har* str1, const char* str2)
assert((str1 != NULL) && (str2 != NULL));
int r et = 0;
while (!(ret = *(unsigned char*)str1 - * (unsigned char*)str2) && *str2)
str1&#43;&#43;;
str2&#43;&#43;;
if (ret & 0)
else if (ret & 0)
82、请编写一个C 函数,该函数将一个字符串逆序。
【参考答案】
void AntitoneValue(cha r* father, char* child)&
char source[100];&
int j = 0;&
while(father[j]) //放入source ,[j] 为长度
source[j] = father[j];&
j&#43;&#43;;&
if(j & 99)&
source[j] = '\0';&
for(i=0; i&j; i&#43;&#43;)&
child[i] = source[j-i-1]; &// 反序
child[i] = '\0';&
83、请编写一个C 函数,该函数在给定的内存区域搜
索给定的字符,并返回该字符所在位置索引&#20540;。
【参考答案】
int s earch(char* cpSource, intn , char ch) &// 起始地址,搜索长度,目标字符
for(i=0; i&n && *(cpSource&#43;i) != &#43;&#43;i);
84、请编写一个C 函数,该函数在一个字符串中找到
可能的最长的子字符串,该字符串是由同一字符组成
【参考答案】
int C hildString(char*p) & & // 自己写
char *q =p;
int s tringlen=0, i=0,j=1,len=0,maxlen=1; &&
while(*q!=’\0’) & & & & &//不能用strlen, 求得长度stringlen
Stringlen&#43;&#43;;
q&#43;&#43;;
while( i& &String len ) & &
if(*(p&#43;i)==*(p&#43;j)& & j& St ri ngle n ) &&
len&#43;&#43;; & & & & & & & & & &// 统计子串长度
i&#43;&#43;;
j&#43;&#43;; &&
if(len&maxlen) & & & & & // 统计最大子串长度
maxlen=len&#43;1; &&
i&#43;&#43;;
j&#43;&#43;;
retu rn & & &
85、华为面试题:怎么判断链表中是否有环?
【参考答案】答:用两个指针来遍历这个单向链表,第
一个指针p1,每次走一步;第二个指针p2,每次走两
步;当p2 指针追上p1的时候,就表明链表当中有环
int testLinkRing(Link *head)
Link *t1=head,*t2=
while( t1-&next && t2-&next)
if (NULL == (t2 = t2-&next-&next))
return 0; // 无环
if (t1 == t2)
86、有一浮点型数组A, 用C 语言写一函数实现对浮点
数组A进行降序排序,并输出结果,要求要以数组A 作为
函数的入口.( 建议用冒泡排序法)
【参考答案】
void BubbleSort(double a rr[], int n)&
int i,j ;
int e xchange = 1 ;// 交换标志
for(i=1;i&n;i&#43;&#43;)
{ // 最多做n-1趟排序
exchange=0 ;// 本趟排序开始前,交换标志应为假
for(j=n-1;j&=i ;j--) //对当前无序区R[i..n]自下向上扫描
if(arr[j&#43;1] & arr [ j])
{// 交换记录
arr[0]=arr[j&#43;1];//R[0]不是哨兵,仅做暂存单元
arr[j&#43;1]=arr[j];
arr[j]=arr[0];
exchange=1 ;// 发生了交换,故将交换标志置为真
if(!exchange) // 本趟排序未发生交换,提前终止算法
} //endfor(外循环)&
87、实现双向链表删除一个节点P,在节点P 后插入一
个节点,写出这两个函数。
【参考答案】
// 删除操作
Status ListDelete_DuL(DuLinkList &L,inti,Ele mType &e)
if(!(p=G e tElemP_DuL(L,i))) return ERROR;
p-&prior-&next=p-&
p-&next-&prior=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-&
return OK;
88、把一个链表反向。
【参考答案】从第一个元素开始,ps指向他,将他(
ps)指向头节点(ps-&next = head) ,将ps设为头节点
(head = )操作下一个元素(ps= pe-&)等
于是依次将每个元素翻到原头节点前面。
void reverse(test* head)
test* pe =
test* ps = head-&
pe-&next = ps-&
ps-&next =
ps = &pe-&
89、将二维数组行列元素互换,存到另一个数组中。
【参考答案】
#include &stdio.h&
{ & int a [2][3]={{1,2,3},{4,5,6}};
int b[3][2],i,j;
printf(&array a :\n&);
for(i=0;i&=1;i&#43;&#43;)
{ & for(j=0;j&=2;j&#43;&#43;)
{ & printf(&%5d&,a[i][j]);
b[j][i]=a[i][j];
printf(&\n&);
printf(&array b :\n&);
for(i=0;i&=2;i&#43;&#43;)
{ & for(j=0;j&=1;j&#43;&#43;)
printf(&%5d&,b[i][j]);
printf(&\n&);
90、输入一行字符,统计其中有多少个单词。
【参考答案】
#include &stdio.h&
char str i ng[81];
int i,num=0,word=0;
gets(string);
for(i=0;(c=string[i])!='\0';i&#43;&#43;)
if(c==' ') &
else if(word==0)
word=1; &num&#43;&#43;; & }
printf(&There are %d word s in the line\n&,num);
91、写一个内存拷贝函数,不用任何库函数.就是前些时
候本版讨论的那个问题。
【参考答案】
void* m e mcpy(void* pvTo, const void* pvFrom, size_t size)
assert((pvTo != NULL) && (pvFrom ! = NULL));
byte* pbTo= pvTo;
byte* pbFrom = pbF
while (size-- & &0)
*pbTo&#43;&#43; = *pbFrom&#43;&#43;;
return pvTo;
92、有1、2、3 、4个数字,能组成多少个互不相同且
无重复数字的三位数?都是多少?
【参考答案】
#inc lude &&stdio.h&
#include &conio.h&
int i,j,k;
printf(&\n&);
for(i=1;i&5;i&#43;&#43;) /* 以下为三重循环*/
for(j=1;j&5;j&#43;&#43;)
for (k=1;k&5;k&#43;&#43;)
if (i!=k&&i!=j&&j!=k) /* 确保i、j、k三位互不相同*/
pr intf(&%d,%d,%d\n&,i,j,k);
93、取一个整数a从右端开始的4~7位。
【参考答案】
unsigned a,b,c,d;
scanf(&%o&,&a);
c=~(~0&&4);
printf(&%o\n%o\n&,a,d);
94、打印出杨辉三角形(要求打印出10行如下图)。
【参考答案】
int a [10][10];
printf(&\n&);
for(i=0;i&10;i&#43;&#43;)
a[i][0]=1;
a[i][i]=1;
for(i=2;i&10;i&#43;&#43;)
for(j=1;j&i;j&#43;&#43;)
a[i][j]=a[i-1][j-1]&#43;a[i-1][j];
for(i=0;i&10;i&#43;&#43;)
for(j=0;j&=i;j&#43;&#43;)
printf(&%5d&,a[i][j]);
printf(&\n&);
95、实现strcmp 函数。
100 条经典 C语言笔试题目
96、写一个函数,求一个字符串的长度,在main函数
中输入字符串,并输出其长度。
【参考答案】
char *s tr[20];
printf(&please input a string:\n&);
scanf(&%s&,str);
len=length(str);
printf(&the s tring has %d characters.&,len);
while(*p!='\0')
n&#43;&#43;;
p&#43;&#43;;
97、809*??=800*??&#43;9*??&#43;1 &其中??代表的两位数
,8*?? 的结果为两位数,9*??的结果为3位数。求??代
表的两位数,及809*??后的结果。
【参考答案】output(long b,long i)
printf(&\n%ld/%ld=809*%ld&#43;%ld&,b,i,i,b%i);
long int a ,b,i;
for(i=10;i&100;i&#43;&#43;)
b=i*a&#43;1;
if(b&=1000&&b&=10000&&8*i&100&&9*i&=100)
output(b,i);
98、某个公司采用公用电话传递数据,数据是四位的整数,在
传递过程中是加密的,加密规则如下:每位数字都加上5, 然后
用和除以10的余数代替该数字,再将第一位和第四位交换,第
二位和第三位交换。
【参考答案】
int a ,i,aa[4],t;
scanf( & % d & ,&a) ;
aa[0]=a %10;
aa[1]=a %100/10;
aa[2]=a %;
aa[3]=a /1000;
for(i=0 ; i&=3 ;i&#43;&#43;)
aa [i]&#43;=5;
aa[i] %=10;
for(i=0;i&=3/2;i&#43;&#43;)
aa[i]= aa[3- i];
for(i=3;i&=0;i--)
prin tf(&% d &, a [i]);
99、计算字符串中子串出现的次数。
【参考答案】
char str1[20],str2[20],*p1,*p2;
int sum=0;
printf(&please input two strings\n&);
scanf(&%s%s&,str1,str2);
p1=str1;p2=str2;
while(*p1!='\0')
if(*p1==*p2)
while(*p1==*p2&&*p2!='\0')
p1&#43;&#43;;
p2&#43;&#43;;
p1&#43;&#43;;
if(*p2=='\0')
sum&#43;&#43;;
printf(&%d&,sum);
100 、有两个磁盘文件A和B, 各存放一行字母,要求把
这两个文件中的信息合并(按字母顺序排列),输出
到一个新文件C 中。
【参考答案】
100 条经典 C语言笔试题目
in t i,j,n,
char c[160],t,
if((fp=fopen(&A&,&r &))==NULL)
printf(&file A cannot &be opened\n&);exit(0);
printf(&\nA contents are :\n&);
for(i=0;(ch=fgetc(fp))!=EOF ; i&#43;&#43;)
c[i]=pu tchar(c[i]);
fclose(fp);
if((fp=fopen(&B&,&r &))==NULL)
printf(&file B cannot &be opened\n&);exit(0);
printf(&\nB contents are :\n&);
for(i=0;(ch=fgetc(fp))!=EOF ; i&#43;&#43;)
c[i]=pu tchar(c[i]);
fclose(fp);
for(i=0;i&n;i&#43;&#43;)
for(j=i&#43;1;j&n;j&#43;&#43;)
if(c[i]&c[j]){t=c[i ];c[i]=c[j];c[j]=t;}
printf(&\nC file is:\n&);
fp =f open(&C&,&w&);
for(i=0;i&n;i&#43;&#43;){putc(c[i ],fp);putchar(c[i]);}
fclose(fp);
12个有趣的C语言面试题及答案
转载自:http://blog.csdn.net/sjin_1314/article/details/
12个C语言面试题,涉及指针、进程、运算、结构体、函数、内存,看看你能做出...
C语言面试题大汇总
JavaScript 教程
static有什么用途?(请至少说明两种)
1.限制变量的作用域
2.设置变量的存储域
7. 引用与指针有什么区别?
1) 引用必须被初始化,指针不必。
2) 引用初始...
C语言经典面试题 与 C语言面试宝典
问题1:什么是预编译?何时需要预编译?
预编译又称预处理,是整个编译过程最先做的工作,即程序执行前的一些预处理工作。主要处理#开头的指令。如拷贝#include包含...
华为C语言笔试题集合
①华为笔试题搜集
1.static有什么用途?(请至少说明两种)
1)在函数体,一个被声明为静态的变量在这一函数被调用过程中维持其值不变。
2) 在模块内(但在函数体外),一个被...
经典16道:嵌入式C语言笔试题
1.用预处理指令#define 声明一个常数,用以表明1年中有多少秒(忽略闰年问题)
  #define SECONDS_PER_YEAR (60 * 60 * 24 * 365)UL
  我在...
C语言面试题---指针篇(一)
原创创新教育研究中心TeachPlus
C语言面试题---指针篇(...
100道c语言面试题
题目来源:
1、中兴、华为、慧通、英华达、微软亚洲技术中心等中
外企业面试题目;
2、C 语言面试宝典(林锐《高质量编程第三版》)。
1、部分C 语言面试题中可能会参杂部分和C++ ...
C语言经典笔试题(一)
C语言经典笔试题(一)
没有更多推荐了,}

我要回帖

更多关于 成都中软国际2018年C笔试题 的文章

更多推荐

版权声明:文章内容来源于网络,版权归原作者所有,如有侵权请点击这里与我们联系,我们将及时删除。

点击添加站长微信