编写函数fun,功能是返回两个整数的平方和.主函数调用函数fun,求2的平方加3的平方

      问题1:循环1的优点和缺点。       问题2:循环2的优点和缺点。

条件判断出现在For里面,意味着,即使我在dosomething()或dootherthing()这2个函数中改变了condition的值,For循环也能正确执行我的意图,因为它在每次循环中都会重新检测conditon的值并针对condition的值做不同动作,所谓以不变应万变,这是难能可贵的.

缺点: 多执行了N-1次逻辑判断,并且打断了循环“流水线”作业,使得编译器不能对循环进行优化处理,降低了效率。
如果condition一直未曾改变,我们可怜的if必须每次循环都判断一下condition的真假.牺牲了运行时效率.

优点:循环的效率高。只进行一次判断,运行时效率高.适合那种condition的值不会改变的情况.
缺点:由于只在一开始进行一次判断,所以失去的改变condition的值的机会,也就是说,即使我在dosomething()中改变了condition的值为false,这个程序也不会改变它的判断,它依然执行着dosomething()的循环.我们不能随时更换我们需要进行的动作。这是牺牲了弹性。

N较大时,建议采用后面这种写法,由于前者老要进行逻辑判断,打断了循环“流水线”作业,使得编译器不能对循环进行优化处理,降低了效率。

3: 100 条经典 C语言笔试题目

【标准答案】(4)4、(5)4

4、用变量a 给出下面的定义
e) 一个有10个指针的数组,该指针是指向一个整型数
f) 一个指向有10个整型数数组的指针;
g) 一个指向函数的指针,该函数有一个整型参数并返
h) 一个有10个指针的数组,该指针指向一个函数,该
函数有一个整型参数并返回一个整型数;

5、设有以下说明和定义:

6、请问以下代码有什么问题:

【标准答案】没有为str分配内存空间,将会发生异常
问题出在将一个字符串复制进一个字符变量指针所指
地址。虽然可以正确输出结果,但因为越界进行内在

7、请问以下代码有什么问题:

AAA" 是字符串常量。
指向这个字符串常量,所以声明s的时候就有问题。
然后又因为是常量,所以对是s[0] 的赋值操作是不合法的。

【标准答案】程序崩溃,getmemory中的malloc 不能返回
动态内存,free ()对str操作很危险。

产生什么结果?为什么? 【标准答案】长度不一样,出现段错误。

100 条经典 C语言笔试题目
12、数组和链表的区别?
【标准答案】数组:数据顺序存储,固定大小;

链表:数据可以随机存储,大小可动态改变

【标准答案】p 为野指针(指向一个已删除的对象或未申请访问受限内存区域的指针)

中ptr为同一个指针。
20、要对绝对地址0x100000赋值,我们可以用
那么要是想让程序跳转到绝对地址是0x100000去执行
首先要将0x100000强制转换成函数指针,:

27、关键字volatile有什么含意? 并给出三个不同的例

一个定义为volatile的变量是说这变量可
能会被意想不到地改变,这样,编译器就不会去假设
这个变量的值了。精确地说就是,优化器在用到这个
变量时必须每次都小心地重新读取这个变量的值,而
不是使用保存在寄存器里的备份。下面是volatile变量
1). 并行设备的硬件寄存器(如:状态寄存器)
2). 一个中断服务子程序中会访问到的非自动变量
3). 多线程应用中被几个任务共享的变量

28、嵌入式系统经常具有要求程序员去访问某特定的
内存位置的特点。在某工程中,要求设置一绝对地址
为0x67a9的整型变量的值为0xaa66。编译器是一个纯
粹的ANSI编译器。写代码去完成这一任务。
【参考答案】这一问题测试你是否知道为了访问一绝对
地址把一个整型数强制转换(typecast )为一指针是合
法的。这一问题的实现方式随着个人风格不同而不同
。典型的类似代码如下:

【标准答案】防止该头文件被重复引用。

31、const 有什么用途?(请至少说明两种)
【标准答案】: (1)可以定义const 常量
(2)const 可以修饰函数的参数、返回值,甚至函数
的定义体。被const 修饰的东西都受到强制保护,可
以预防意外的变动,能提高程序的健壮性。

32、static有什么用途?(请至少说明两种)

  1. 限制变量的作用域(static全局变量);
  2. 设置变量的存储域(static局部变量)。

33、堆栈溢出一般是由什么原因导致的?
【标准答案】没有回收垃圾资源。

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

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

36、队列和栈有什么区别?
【标准答案】队列先进先出,栈后进先出。

【标准答案】Heap是堆,stack是栈。
Stack的空间由操作系统自动分配/释放,Heap上的空
Stack空间有限,Heap是很大的自由存储区
C 中的malloc 函数分配的内存空间即在堆上,C++中对
应的是new 操作符。
程序在编译期对变量和函数分配内存都在栈上进行,且
程序运行过程中函数调用时参数的传递也在栈上进行。

40、带参宏与带参函数的区别(至少说出5点)?
处理时间 编译时 运行时
运行时间 不占运行时间 调用和返回时占

【标准答案】提示编译器对象的值可能在编译器未监测

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

44、A.c 和B.c两个c文件中使用了两个相同名字的
static变量,编译的时候会不会有问题?这两个static变量
会保存到哪里(栈还是堆或者其他的)?
【标准答案】static的全局变量,表明这个变量仅在本
模块中有意义,不会影响其他模块。
他们都放在静态数据区,但是编译器对他们的命名是
如果要使变量在其他模块也有意义的话,需要使用

45、static全局变量与普通的全局变量有什么区别?
【标准答案】 static全局变量只初使化一次,防止在其

46、static局部变量和普通局部变量有什么区别
【标准答案】static局部变量只被初始化一次,下一次

47、static函数与普通函数有什么区别?
【标准答案】static函数在内存中只有一份,普通函数在
每个被调用中维持一份拷贝

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

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

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

50、用两个栈实现一个队列的功能?要求给出算法和
【参考答案】设2个栈为A,B, 一开始均为空.
(1)判断栈B 是否为空;
(2)如果不为空,则将栈A中所有元素依次pop 出并

51、对于一个频繁使用的短小函数,在C 语言中应用什
么实现,在C++ 中应用什么实现?
【标准答案】c用宏定义,c++ 用inline

53、Typedef 在C 语言中频繁用以声明一个已经存在的
数据类型的同义字。也可以用预处理器做类似的事。例
如,思考一下下面的例子:
以上两种情况的意图都是要定义dPS 和tPS 作为一个
指向结构s指针。哪种方法更好呢?(如果有的话)为
【参考答案】这是一个非常微妙的问题,任何人答对这个问题(正当的原
因)是应当被恭喜的。答案是:typedef 更好。思考下面的例子:
上面的代码定义p1为一个指向结构的指,p2为一个实际的结构,这也许
不是你想要的。第二个例子正确地定义了p3 和p4 两个指针。

54、在C++ 程序中调用被C 编译器编译后的函数,
【标准答案】C++ 语言支持函数重载,C 语言不支持函
数重载。函数被C++ 编译后在库中的名字与 C 语言的
该函数被C 编译器编译后在库中的名字为_foo ,而
提供了C 连接交换指定符号extern“C”来解决名字匹配

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

56、语句for( ;1 ;) 有什么问题?它是什么意思?
【标准答案】死循环,和while(1)相同。

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

62、以下是求一个数的平方的程序,请找出错误:
【标准答案】宏在预编译时会以替换的形式展开,仅仅
会替换。涉及到宏的地方,不要用+±- ,标准中对此
没有规定,因此最终结果将会依赖于不同的编译器。
执行程序的答案可能是25、也有可能是36。

64、嵌入式系统中经常要用到无限循环,你怎么用C
100 条经典 C语言笔试题目
65、程序输出结果是?

68、不能做switch()的参数类型是:
【标准答案】switch 的参数不能为实型。

70、找出程序的错误。

72、中断是嵌入式系统中重要的组成部分,这导致了很多编译开发商提
供一种扩展—让标准C 支持中断。具代表事实是,产生了一个新的关键字
务子程序(ISR),请评论一下这段代码的。
【参考答案】这个函数有太多的错误了,以至让人不知从何说起了:
1). ISR 不能返回一个值。如果你不懂这个,那么你不会被雇用的。
2). ISR 不能传递参数。如果你没有看到这一点,你被雇用的机会等同第
3). 在许多的处理器/编译器中,浮点一般都是不可重入的。有些处理器/编
译器需要让额处的寄存器入栈,有些处理器/编译器就是不允许在ISR 中做
浮点运算。此外,ISR 应该是短而有效率的,在ISR 中做浮点运算是不明
4). 与第三点一脉相承,printf() 经常有重入和性能上的问题。如果你丢掉
了第三和第四点,我不会太为难你的。不用说,如果你能得到后两点,那
么你的被雇用前景越来越光明了。

73、下面的代码输出是什么,为什么?
【参考答案】这个问题测试你是否懂得C 语言中的整数自动转换原则,
我发现有些开发者懂得极少这些东西。不管如何,这无符号整型问题的答
案是输出是“>6” 。原因是当表达式中存在有符号类型和无符号类型时所有
的数都自动转换为无符号类型。因此-20 变成了一个非常大的正整数,所
以该表达式计算出的结果大于6 。这一点对于应当频繁用到无符号数据类
型的嵌入式系统来说是丰常重要的。如果你答错了这个问题,你也就到了
得不到这份工作的边缘。

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

}

上海市计算机二级考试(C语言)复习资料题目

C语言是一种面向过程的程序设计语言,函数、指针、地址和递归概念是它的难点。本复习资料以教学大纲为依据,提供各类题型和练习,重在“基本概念”、“常用算法”、“阅读分析程序”、“编程技能”等诸方面的强化训练,按照上海市计算机二级考试(C语言)的框架,提供“基础知识、读程序写结果、改错、编程序和程序指令填空”几部份,供学生学习参考,文末附习题参考解答。

1. 下述循环的循环次数是(B)

2. 在下列选项中,没有构成死循环的程序段是(C)

3. 若有以下定义和语句,且0

4. 下面能正确将字符串"Boy"进行完整赋值操作的语句是(B)

5. 以下程序段的输出结果是(D )

}

它的功能是:将低于平均分

的人作为函数值返回,将低于平均分的分数放在

整除的所有证书,并将他们放在

各整数,并按从小到大的顺序放在

所指的数组中,这些除数的个数通过形参

出现的次数,并依次放在

其功能是:删除以各字符串中指定

指向原字符串,删除后的字符串存放在

用来求除数组的最大元素在数组中的下

功能是:根据以下攻势计算

计算结果作为函数值返回;

,它的功能是:根据以下公式求

的值,结果由函数值带回。

它的功能是:利用以下的简单迭代方法求方程

的一个实根,作为函数值返回。

并在主函数中自动赋值。

该函数的功能是:使数组左下半三角元素中的值全部置成

的二维数组,并在主函数中赋值。请编写函数

的功能使求出数组周边元素的平均值并作为函数值返回给主函数中的

组,求出二维函数组每列中最小元素,并依次放入

所指定一维数组中。二维数组中的数

}

我要回帖

更多关于 递归函数c语言 的文章

更多推荐

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

点击添加站长微信