《C语言程序设计基础》单元总结与练习题及答案_第1页
《C语言程序设计基础》单元总结与练习题及答案_第2页
《C语言程序设计基础》单元总结与练习题及答案_第3页
《C语言程序设计基础》单元总结与练习题及答案_第4页
《C语言程序设计基础》单元总结与练习题及答案_第5页
已阅读5页,还剩35页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、精选优质文档-倾情为你奉上C语言程序设计单元总结与练习题答 案单元一 程序设计宏观认识单元总结提升本单元中,核心内容有C语言程序框架结构、程序的构成和程序开发过程。通过本单元的学习,我们应该知道:1C语言程序最基本的程序框架由两部分构成,分别是:(1) 编译预处理 (2) 函数组 2C程序最大的特点就是所有的程序都是用函数来装配的,函数是构成C语言程序的基本单位,函数包括主函数、库函数和自定义函数。函数的一般结构形式为: 函数返回值类型 函数名(形式参数) /函数首部 说明语句; /函数体 可执行语句; 3 标识符是用来标识程序中的某个对象名字的字符序列。C语言把标识符分为三类,即关键字、预定

2、义标识符、用户自定义标识符。对于用户自定义标识符的命名C语言规定:(1) 所有的用户标识符必须先定义后使用;(2) 用户标识符由字母(AZ,az)、数字(09)、下划线“_”组成,并且首字符不能是 数字 ;(3) 区分大小写;(4)不能用关键字作为用户自定义标识符,通常不使用预定义标识符作为用户自定义标识符。4理论上讲,程序开发过程分为四个步骤,分别为:(1) 编辑源程序 (2) 编译源程序,生成目标程序 (3) 连接目标程序及其相关模块,生成可执行文件 (4) 运行可执行文件 5简单描述使用VC+6.0开发应用程序的步骤:如图所示: 启动VC+6.0打开或新建工程打开或新建文件编辑、编译连接

3、、运行完成图 VC+6.0开发程序的步骤总之,通过本单元的学习,应该掌握C语言程序框架结构和程序开发过程,还要对C语言程序设计的知识脉络有一定的了解。单元练习一选择题 1构成C语言程序的基本单位是( )。A框架    B预处理    C函数   D语句 2在程序开发过程中,把文本文件格式源程序转化为二进制格式的目标程序的过程称之为( )。A编辑 B编译 C连接 D运行3关于主函数,下列说法不正确的是( )。A一个完整的C语言应用程序有唯一的主函数B主函数的名称只能是mainC主函数可以被其他自定义函数调用DC语言程

4、序的运行从主函数开始,以主函数为核心展开4关于标识符,下列说法不正确的是( )。A库函数名称为预定义标识符,不建议用作用户自定义标识符B. 关键字不能作为用户自定义标识符C用户自定义标识符中不区分大小写字母D标识符中可以出现下划线,且可以出现在标识符的任意位置5以下可用作用户自定义标识符的一组是( )。Avoid、return、ifBprintf、include、fabsCMax、_abc、MainD2abc、pay$、sum-10二填空题1C语言程序一般由若干个函数构成,程序中应至少包含一个_,其名称只能为_。 2C语言程序中每条语句必须以_结束。3C语言程序的注释是以_开头,以_

5、结束的,在VC+6.0编程环境中,可使用_作为注释的起始标识,注释对程序的执行不起任何作用。 4最初编写的C语言程序称为_,其扩展名为_,编译后生成的文件为_,其扩展名是_,连接后生成的文件是_,其扩展名是_。 5C语言规定,标识符只能由_、_和_三种字符组成,而且,首字符只能是_或_。*习题答案:一选择题1C2B3C4C5C二填空题1主函数 main2分号;3/* */ /4源程序 .cpp或.c目标文件(或目标程序) .obj 可执行文件(或可执行程序) .exe5字母(AZ,az)、数字(09)、下划线“_” 字母或下划线*单元二 程序设计基础知识单元总结提升本单元中

6、,核心内容有C语言中基本的数据类型、常量和变量、运算符和表达式以及算法的概念。通过本单元的学习,我们应该知道:1C语言中最基本的数据类型有: 整型、字符型、浮点型 。2C程序中使用的常量按照表现形式可分为直接常量和符号常量。(1)直接常量 1)整型常量,有十进制、八进制和十六进制三种描述方式,其中,八进制的前置符号标志为 0 ,十六进制的前置符号标志为 0x或0X 。 2)浮点型常量,有十进制小数和指数两种描述方式,指数形式的符号标志是 e或E 。 3)字符型常量,是用单撇引号括起来的单一字符,对一些特殊字符和控制字符用 的形式表示。 4)字符串常量,是用双撇引号括起来的一串字符序列。字符串的

7、结束标志为 0 。(2)符号常量 符号常量是使用某个符号代表的常量,符号常量使用编译预处理中的宏定义命令 定义。3C程序中使用变量,必须先 定义 ,后 使用 。变量定义后,系统会根据变量的类型分配相应的存储空间。4C语言有丰富的运算符,其中算术运算符包括+、-、*、/、%,运算符中的 仅用于整数间的运算;赋值运算符包括“=”和相应的复合赋值运算符 +=、-=、*=、/= ,赋值运算的含义是将“=”右侧的表达式的计算结果赋值给“=”左侧的变量,这与数学中“=”的含义不同,需要注意。5由运算符和数据构成表达式,若表达式中各数据的类型不同,则存在类型自动转换问题,必要时也可以使用强制类型转换。6对于

8、面向过程的程序设计来说,程序= 数据结构 + 算法 。7在C语言中,对于每一个程序设计单元可采用结构化程序设计方法,有三种基本的程序结构,分别为: 顺序 、 选择 和 循环 。通过本单元的学习,应该掌握C语言程序设计所需要的基本知识,为后续内容的学习打下坚实的基础。单元练习一选择题 1在C语言中,int、short、char三种类型数据所占用的存储空间是( )。A均为2个字节    Bint和short占2个字节,char占1个字节C与编译环境有关   D由用户自己定义  2下面定义字符型变量ch的语句不正确的是( )。Achar c

9、h=X2A;  Bchar ch="c" Cchar ch=65;   Dchar ch=NULL; 3已知大写字母A的ASCII是65,小写字母a的ASCII是97,以下不能将字符型变量c中的大写字母转换成对应的小写字母的语句是( )。Ac= (c-'A')%26+'a'    Bc2=tolower(c);Cc= c-'A'+'a'   Dc=('A'+c)%26-'a'

10、60; 4设有定义:double d,h;,其中d为三角形的底边长,h为三角形的高,则以下C语言表达式与其面积公式dh计算结果不相符的是( )。Ad*h/2    B1/2*d*hCd*h*1/2Dd/2*h  5以下选项中,与k=n+;完全等价的语句是( )。Ak=n;n=n+1;    Bn=n+1;k=n;Ck=+n;Dk+=n+1;二填空题1写出整型变量a、无符号长整型变量b、双精度浮点型变量c和字符型变量d的定义语句: 。2常量a和”a”分别占用_个字节和_个字节的存储空间。3有定义 int a=1234;,获取其

11、百位数码的表达式为_。4若有定义:char a=97,c;,则表达式c='a'+'8'-'3'的值为_。5已知int x=6;,则执行x+=x-=x-3;语句后,x的值是_。6将一个浮点型变量n四舍五入精确到小数点后两位,其表达式为: 。7C语言中基本的数据类型有 、 、 。8结构化程序设计中基本的程序结构有 、 、 。*习题答案:一选择题1C2B3D4B5A二填空题1int a; unsigned long b; double c; char d;21 23a/100%104f566(int)(n*100+0.5)/100.0;7整型、浮点型、

12、字符型8顺序、选择、循环*单元三 顺序结构程序设计单元总结提升本单元中,核心内容是顺序程序结构程序设计中标准输入输出库函数的使用。通过本单元的学习,我们应该知道:1C语言提供了标准输入输出库函数用于实现数据输入输出操作,其对应的头文件为 stdio.h 。2单字符输入和输出函数分别为 getchar() 和 putchar() 。3格式化输入和输出函数分别为 scanf() 和 printf() 。4格式化输出函数有两种调用格式:(1) printf("字符串常量"); (2) printf("格式控制字符串",输出项列表); 5格式化输入/输出中,格式

13、控制符由 % 开头。常用的格式控制符有:整型int格式符 %d 、float浮点型格式符 %f 、double浮点型格式符 %lf 、字符型格式符 %c ;对于浮点型格式可以用 m.n 形式的附加格式说明小数的宽度和小数位数。6格式化输入中的输入项为地址列表,对变量取地址的运算符为 & 。通过本单元的学习,应对顺序结构程序设计的特点和设计思路有所了解,同时重点学会单字符输入函数getchar()、单字符输出函数putchar()、格式化输出函数printf()和格式化输入函数scanf()的正确使用。单元练习一选择题1已定义x为float型变量,其值为213.45678,则printf

14、("%-4.2fn",x);的输出结果为( )。A213.46    B213.45   C-213.45   D输出格式控制说明的域宽不够,不能输出  2. 有以下程序,程序运行时输入:1,2,3<回车>,则输出的结果为( )。#include <stdio.h>void main( ) int a,b,c; scanf("%d%d%d",&a,&b,&c); printf("a+b+c=%dn",a+b+

15、c); A6    Ba+b+c=6C123D不确定的值3.下面输入语句中,正确的是( )。Ascanf("a=b=%d",&a,&b);  Bscanf("%d,%d",&a,&b); Cscanf("%c",c);   Dscanf("%d %dn",&f1,f2); 4在VC+6.0环境中,下列说法正确的是( )。A输入函数scanf()输入多个数据时,有时数据间不必加间隔符。B输入函数sc

16、anf()中单精度或双精度浮点型数据都要用%f作为格式控制符。C使用输出函数printf()输出字符或字符串都用格式控制符%s。 D输出函数printf()中单精度或双精度浮点型数据都要用%f作为格式控制符。5下面程序的功能是实现两个字符变量互换值,若为ch1输入a,ch2输入b,则程序运行时正确的输入是( )。#include <stdio.h>void main( ) char ch1,ch2,ch; scanf("%c%c",&ch1,&ch2); ch=ch1;ch1=ch2;ch2=ch;printf("ch1=%c

17、,ch2=%cn",ch1,ch2); Aa,b    Ba<空格>bCabDa<回车>b二填空题1.有语句putchar(getchar(),程序运行时输入:A,则输出结果是_。2printf("%6.2f%",1.0/3);的输出结果是_。3补充程序: int n1=10,n2=20; printf(" ",n1,n2); 要求按以下格式输出n1和n2的值,每个输出行从第一列开始。n1=0010n2=00204.有以下程序,程序运行时输入:1234<回车>,执行后输出的结果是

18、_。#include <stdio.h>void main( ) char ch1,ch2;int n1,n2; ch1=getchar();ch2=getchar();n1=ch1-0; n2=n1*10+(ch2-0); printf("n1=%d,n2=%d.n",n1,n2); 5. 输入多个非字符型的数值数据时,数据输入时可用 、 和 作为间隔符。*习题答案:一选择题1A2D3B4A5C二填空题1.A2.0.33%3.n1=%04dnn2=%04d4.n1=1,n2=125.空格,TAB键,回车*单元四 选择结构程序设计单元总结提升在选择结构程序设计中

19、,条件判断表达式和选择结构实现语句是两个核心内容。通过本单元的学习,我们应该知道:1条件判断表达式由关系运算符及其表达式、逻辑运算符及其表达式构成,其中:(1) 关系运算符有: > 、 < 、 >= 、 <= 、 !=、 = (2) 逻辑运算符有: &&、|、 ! 2选择结构实现语句有三种方式:(1) 单分支if选择结构,一般格式为: if ( 表达式 ) 语句;(2) 双分支if-else选择结构,一般格式为:if ( 表达式 ) 语句1; else 语句2;(3) 多分支 switch选择结构,一般格式为:switch( 表达式 ) case 常量表

20、达式1: 语句序列1; break; case 常量表达式2: 语句序列2; break; case 常量表达式n: 语句序列n; break; default: 语句序列n+1; 3在应用选择结构时,应注意以下问题:(1)在if嵌套语句中,要弄清else与if的匹配关系,书写if语句嵌套时一般采用缩进的阶梯式写法,在实际编程中,为了表明编程者的意图,也常常通过“”来强制if和else的配对关系。(2)switch语句中,“表达式”和“常量表达式”的类型只能是整型或字符型数据,且“常量表达式”只能由常量构成,通过“表达式”与“常量表达式”之间的对等关系构造出多分支选择结构。(3)在某些多分支选

21、择结构程序设计中,既可使用if-else语句实现,也可以使用switch语句实现。switch语句与if语句的不同之处在于:switch语句仅能判断一种逻辑关系,即“表达式”和指定“常量表达式”的值是否相等,而不能进行大于,小于某一个值的判断,不能表达区间数据的概念;if语句可以计算和判断各种表达式。所以switch语句不能完全替代if语句。总之,通过本单元的学习,应该掌握C语言选择结构程序设计的思路和语句的基本用法。单元练习一选择题1以下选项中,当x为大于1的奇数时,值为0的表达式( )。Ax%2=1     Bx/2   

22、;   Cx%2!=0    Dx%2=0 2在C语言中,if语句后的一对圆括号中有一个用以决定分支走向的表达式,该表达式( )。A只能是关系表达式 B只能是逻辑表达式C只能是关系或逻辑表达式 D可以是任何合法表达式3读下面程序段,当x=-3时,输出y的值为( )。int x,y; y=0;scanf(“%d”,&x);if(x>=0)if(x>0) y=1;else y=-1; printf(“y=%d”,y);A1 B-1 C0 D不确定4下列语句将小写字母转化为大写字母,正确的语句为( )。Aif(z>=ch&g

23、t;=a) ch=ch-32;Bif(ch>=a&&ch<=z) ch=ch-32;Cch=(z>=ch>=a)?ch-32:ch;Dch=( ch>=a&&ch<=z)?ch:ch-32;5关于与switch语句配套的case语句中所使用的表达式,说法正确的是( )。A可以是变量 B可以是常量或变量C只能是常量或常量表达式D无论是何种表达式,只要在执行时有确定的值就行二填空题1在算术运算符、关系运算符、逻辑运算符和赋值运算符中,运算优先级最高的运算符是 ,最低的是 。2正确表示数学关系“1<a<4”的C语言表达式

24、为_。3整型变量n不能被3整除的条件判断表达式为 。 4以下程序段的功能是:对输入的大写字母循环移动6个位置后输出,如A变为G,W变为C。请将程序段补充完整。char ch;ch= ;if(ch>=A&& ) else if( ) putchar(ch);5以下程序段功能是根据学生考试成绩,确定其成绩等级,成绩与等级对应情况与【例4-7】中表格相同,请将程序段补充完整。char level; /成绩等级float score; /考试成绩scanf(“%f”,&score);switch( ) :level=A; ;case 8: level=B;break;ca

25、se 7: level=C; break;case 6: level=D; break;default: ; printf(“考试成绩等级为: .”,level);*习题答案:一选择题1D2D3C4B5C二填空题1!(非) =2a>1&&a<43n%3!=04 char ch;ch= getchar() ;if(ch>=A&& ch<='T' ) ch=ch+6; else if(ch>='U'&&ch<='Z' ) ch=ch-20; putchar(ch);5

26、char level; /成绩等级float score; /考试成绩scanf(“%f”,&score);switch(int(score/10) ) case 10: case 9 :level=A; break ;case 8: level=B;break;case 7: level=C; break;case 6: level=D; break;default: level='E' ; *单元五 循环结构程序设计单元总结提升在本单元中,如何理解循环的本质、如何分析循环的三个要素以及如何描述循环结构语句是核心内容。通过本单元的学习,我们应该知道:1 循环的本质是将

27、程序员从大量重复编写相同代码的工作中解放出来,减少程序源代码的存储空间,提高程序的质量,提高程序编写的工作效率,但计算机执行程序的工作量并没有减少。2 循环结构的三要素包括:(1)循环变量初值 (2)循环控制条件表达式(3)循环体 3循环结构描述语句有三种: while 、 do-while 和 for 。其中while和do-while的区别在于 不管循环条件是否成立,do-while循环都先执行一次循环体,所以do-while循环的循环体至少执行一次,而while循环的循环体可能一次都不执行 。4循环结构控制语句break的作用是: 结束循环 ;循环结构控制语句continue的作用是:

28、提前结束本次循环 。5在一个循环结构语句中又包含了一个循环结构语句称之为 循环的嵌套 。程序执行时,外层循环每执行一次,内层循环就要完整的执行完,直至内层循环执行结束,再开始执行下一次外层循环。学习完本单元,应该掌握C语言循环结构程序设计的思路和基本语句的用法。至此,我们就学完了结构化程序设计中的三种基本结构:顺序、选择和循环。单元练习一选择题1下面说法正确的是( )。Awhile语句不管条件表达式是否为真,都将执行一次循环体。Bdo-while语句构成的循环,一定要有能使while后面表达式的值为0的操作,或在循环体中使用break语句。Cfor循环只能用于循环次数确定的情况,且先执行循环体

29、语句,后判断条件表达式。Dbreak语句的作用是从最近的循环体内跳出来,而continue语句的作用是继续执行循环体中尚未执行的语句。 2 对for(表达式1;表达式3),可理解为( )。Afor(表达式1;0;表达式3)Bfor(表达式1;1;表达式3)C语法错误D仅执行循环一次3 以下程序的功能为( )。 #include <stdio.h>void main() int i,k=0; for(i=1;i<10;i+=2) k+=i+1; printf("%dn",k); A计算自然数19的累加和 B计算自然数110的偶数之和C计算自然数19的奇数之和

30、 D计算自然数110的累加和4以下能正确计算1*2*3*4*5*6*7*8*9*10的程序段是( )。Adoi=1;s=1; Bdoi=1;s=0; s=s*i; s=s*i; i+; i+; while(i<=10); while(i<=10);Ci=1;s=1; Di=1;s=0;do do s=s*i; s=s*i; i+; i+; while(i<=10); while(i<=10);5有以下程序段 int k=0; while(k=1) k+; while循环执行的次数是( )。A无限次 B1次C语法错误,不能执行D一次也不执行二填空题1若输入字符串:abcd

31、e<回车>,则以下while循环体将执行 次。 while(ch=getchar()=e) printf("*");2以下程序执行后的输出结果是 。 #include <stdio.h>void main() int i; for(i=0;i<3;i+) switch(i) case 1: printf("%d",i); case 2: printf("%d",i); default: printf("%d",i); 3下面程序的功能是:输出100以内能被3整除且个位数为6的所有整数,

32、请填空。 #include <stdio.h>void main() int i,j; for(i=0; ;i+) j=i*10+6; if( ) continue; printf("%dn",j); 4有以下程序 #include <stdio.h>void main() int x=23; do printf("%d",x-);while(!x); 该程序执行的结果为 。5以下程序的功能是计算1-3+5-7+-99+101的值,请将程序补充完整。 #include <stdio.h>void main() int

33、i,t=1,s=0; for(i=1;i<=101;i+=2) s=s+ ; ; printf("%dn",s); *习题答案:一选择题1B2B3B4C5A二填空题1023i<10 j%3!=04235i*t t=-t*单元六 数组的使用单元总结提升在本单元中,如何定义一维、二维数组、如何操作数组以及如何利用字符数组处理字符串是核心内容。通过本单元的学习,我们应该知道:1 数组是一组相同类型的有序数据的集合。数组要先定义后使用,可以在定义时初始化,每个数组元素相当于同类型的变量,使用数组名和下标来唯一确定数组中的元素。2 一维数组定义的一般格式为: 类型标识符

34、数组名整型常量表达式; ,对于已定义好的一维数组C编译系统会分配连续的存储空间, 数组名 代表数组在内存中存放的首地址。一维数组的引用方法为: 数组名下标 ,其中下标从 0 开始。3 二维数组定义的一般格式为: 类型标识符 数组名整型常量表达式1 整型常量表达式2; ,对于已定义好的二维数组C编译系统会分配连续的存储空间,将二维数组元素按 行 依次存储。二维数组元素的访问涉及第一维和第二维两个下标,其引用方法为: 数组名下标1下标2 。4 字符数组是一组字符型数据的有序集合,其中每个数组元素的值都是字符。C语言用字符数组实现字符串变量,字符串以 0 作为结束标志。字符串的输入可以通过 gets

35、() 、 scanf() 函数实现,字符串的输出可以通过 puts() 、 printf() 函数实现。常见的字符串操作库函数有:求字符串长度函数 strlen() 、字符串复制函数 strcpy() 、字符串连接函数 strcat() 、字符串比较函数 strcmp(),这些库函数的定义都在头文件 string.h 中。常见的字符库函数的定义都在头文件 ctype.h 中。5 数组的操作通常离不开循环结构,在使用循环结构操作数组时应注意下标的变化规律。通过本单元的学习,应该掌握C语言中对于数组这一构造数据类型的使用方法和操作方法。单元练习一选择题1定义一个名为s的字符型数组,并且赋初值为字符

36、串"123"的错误语句是( )。 Achar s=1','2','3','0 ';  Bchar s="123"; Cchar s="123n"            Dchar s4='1','2','3';  2

37、下列数组定义语句中,正确的是()Aint a=1,2,3,4,5,6;Bchar a23=a',b'Cint a3=1,2,3,4,5,6;Dint a=1,2,3,4,5,6;3已定义 int a3=1,2,3,4,5,6,7,8,9;,则a12的初值为( )。A2B4C6D84判断字符串str1是否大于字符串str2,应当使用( )。Aif(str1>str2)Bif(strcmp(str1,str2)<0)Cif(strcmp(str2,str1)>0)Dif(strcmp(str1,str2)>0)5下列程序段的功能是给数组所有的元素输入数据,然

38、后输出,请选择正确答案填空( )。#include <stdio.h>void main() int a10,i=0; while(i<10)scanf("%d", ); for(i=0;i<10;i+) printf("%4d",ai);A a+(i+) B&ai+1 Ca+i D&a+i二填空题1定义一个名为a的单精度浮点型一维数组,数组的长度为4,所有元素的初值均为0,定义语句为 ,引用该数组元素时,下标的范围是 ,该数组占用的存储空间为 字节。2设有数据定义语句int i=3,x4=1,2,3;,则数组元素

39、xi 的值是 。3下列程序的功能是读取10个实数,然后依次输出前1个实数和、前2个实数和、.、前9个实数和、前10个实数和。请将程序补充完整。#include <stdio.h>void main() float f10,x=0; int i; for(i=0;i<10;i+) scanf("%f",&fi); for(i=0;i<10;i+) ; printf("sum of No.%2d is %.2f.n",i,x); 4下列程序的功能是求两个矩阵的和,请将程序补充完整。#include <stdio

40、.h>void main() int a34,b34,c34; /数组c存放矩阵a与b的和 int i,j; for(i=0;i<3;i+) for(j=0;j<4;j+) scanf("%d",&aij); for(i=0;i<3;i+) for(j=0;j<4;j+) scanf("%d", ); ; for(i=0;i<3;i+) for(j=0;j<4;j+)printf("%d ",cij); putchar('n'); 5阅读下列程序,程序运行后的输出结果是

41、 。#include <stdio.h>#include <string.h>void main() char s320=“1234”,”,”6789”; int i,k;for(k=0,i=1;i<3;i+)if(strcmp(sk,si)<0) k=i;puts(sk);*习题答案:一选择题1C2C3C4D5A二填空题1float a4=0 0至3 16203x+=fi;或x=x+fi;4&bij cij=aij+bij 56789*单元七 函数的使用单元总结提升在本单元中,如何使用自定义函数是核心内容。通过本单元的学习,我们应该知道:1 函数是

42、构成C程序的基本单位,函数的使用为模块化程序设计奠定了基础。从用户使用的角度,函数分为 库 函数、 自定义 函数两种。2 库函数的使用包括 头文件包含 和 库函数调用 两个环节;用户自定义函数的使用包括 函数声明 、 函数定义 和 函数调用 三个环节。3 从函数的外观形式看,函数分为 有参 函数、 无参 函数两种。当主调函数调用无参 函数时,不需要向这些函数传递参数;当主调函数调用 有参 函数时,需要传递参数。4 用户自定义函数的一般形式为:函数返回值类型 函数名(形式参数列表) /函数首部 函数体;其中第一行称为 函数首部 ,大括号“”括起来的部分称为 函数体 ,对于有返回值的函数,函数体中

43、要包括 return 语句。5函数首部也称为函数原型,用函数原型声明函数时,形参名可以省略不写,而只写形参的类型,但形参的 类型 和 数量 必须与函数首部保持一致。6函数要先声明,然后才能使用,函数声明在程序中的位置有以下几种情况:(1)函数声明写在主调函数的外部,这时的函数声明为全局声明。(2)函数声明写在主调函数的说明语句中,这时的函数声明为局部声明。(3)函数的定义出现在主调函数之前,则函数声明可以省略。 7函数的调用形式为:函数名(实际参数列表)。若调用无参函数,则实参为空;若调用有参函数,则在()内写出与形参类型、数量一致的实参。对于有参函数,函数调用过程中存在着参数传递的问题,参数

44、传递有两种情况,其一为 值传递,其二为 地址传递。8函数在函数体中出现了对自身调用的语句,就称为函数递归调用。使用递归方法解决问题的关键是如何找出 递归关系 ,以及找出递归调用的 终止条件 。9带参宏定义的一般形式为: #define 宏名(形参列表) 字符串 。通常用带参数的宏定义代替简单公式型函数。10函数的存储类型有static和extern两种。 extern 型函数称为“外部函数”,可以被其他编译单位中的函数调用; static 型函数称为“内部函数”,只能被本编译单位的函数调用。11程序中变量的使用范围称为变量的作用域,每个变量都有自己的作用域。按照作用域的范围可分为两种: 局部变

45、量 和 全局变量 。12变量的存储方式可分为“动态存储”和“静态存储”两种。动态存储变量包括 auto 和 regiest 两种类型;静态存储变量包括 static 和 extern 两种类型。静态存储变量若没有初始化,则默认初始值为 0 。static类型变量的值具有继承性,即本次调用的初值是上次调用结束时变量的值。单元练习一选择题1关于使用函数的目的,以下不正确的说法是( )。A提高程序的执行效率B提高程序的开发效率C减少程序文件所占内存D提高程序可读性2以下正确的函数首部是( )。Avoid fun(int x,int y)Bvoid fun(int x;int y)Cvoid fun(

46、int x,y)Dvoid fun(x,y)3设函数fun的定义形式为:void fun(char ch, float x) . 则以下对函数fun的调用正确的是( )。Afun("abc",3.0);Bt=fun('D',12.3);Cfun('65',3.7);Dfun(65,65);4关于函数的实参和形参,以下正确的说法是( )。A实参和对应的形参各占用独立的存储单元B实参和对应的形参共同占用同一存储单元C只有当实参与形参重名时才共同占用存储单元D形参是虚拟的,不占用存储单元5当调用函数时,实参是一个数组名,则向函数传递的是( )。A数

47、组的长度B数组的首地址C数组的每一个元素的地址D数组的每一个元素的值6将一个函数指定为static存储类别后,该函数将( )。A既可以被同一源文件中的函数调用,也可以被其他源文件中的函数调用B只能被同一源文件中的函数调用,不能被其他源文件中的函数调用C只能被其他源文件中的函数调用,不能被同一源文件中的函数调用D既不能被同一源文件中的函数调用,也不能被其他源文件中的函数调用7以下叙述正确的是( )。A全局变量的作用域一定比局部变量的作用域作用范围大B静态static类型变量的生存期贯穿于整个程序的运行期间C函数的形参都属于全局变量D未在定义语句中赋初值的auto变量和static变量的初值都是随机值二填空题1假设已有#define M(r) r*r,则语句printf(“%d”,M(

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论