C语言程序的设计基础单元总结与复习题与答案_第1页
C语言程序的设计基础单元总结与复习题与答案_第2页
C语言程序的设计基础单元总结与复习题与答案_第3页
C语言程序的设计基础单元总结与复习题与答案_第4页
C语言程序的设计基础单元总结与复习题与答案_第5页
免费预览已结束,剩余36页可下载查看

付费下载

下载本文档

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

文档简介

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

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

3、对 C语言程序设计的知识脉络有一定的了解。单元练习一.选择题1 .构成C语言程序的基本单位是()。A.框架B.预处理C .函数D .语句2 .在程序开发过程中,把文本文件格式源程序转化为二进制格式的目标程序的过程称之为()。A.编辑B .编译 C .连接 D .运行3 .关于主函数,下列说法不正确的是()。A. 一个完整的C语言应用程序有唯一的主函数B.主函数的名称只能是mainC.主函数可以被其他自定义函数调用D. C语言程序的运行从主函数开始,以主函数为核心展开4.关于标识符,下列说法不正确的是()。A.库函数名称为预定义标识符,不建议用作用户自定义标识符B.关键字不能作为用户自定义标识符

4、C.用户自定义标识符中不区分大小写字母D.标识符中可以出现下划线,且可以出现在标识符的任意位置5.以下可用作用户自定义标识符的一组是()。A. void、return 、ifB. printf 、include 、fabsC. Max _abc、MainD. 2abc、pay$、sum-10二.填空题1. C语言程序一般由若干个函数构成,程序中应至少包含一个 ,其名称只能为O2. C语言程序中每条语句必须以 结束。3. C语言程序的注释是以 开头,以 结束的,在 VC+6.0编程环境中,可使用 作为注释的起始标识,注释对程序的执行不起任何作用。4. 最初编写的 C语言程序称为 ,其扩展名为 ,

5、编译后生成的文件为,其扩展名是,连接后生成的文件是 ,其扩展名是5. C语言规定,标识符只能由 、和 三种字符组成,而且,首字符只能是 或。*习题答案:一.选择题1. C 2, B3. C 4. C 5. C二.填空题1 .主函数 main2 .分号;3 . /* */ /4 .源程序.cpp 或.c目标文件(或目标程序).obj可执行文件(或可执行程序) .exe5 .字母(2乙az数字(09)、下划线“ _"字母或下划线*.专业.专注.单元二程序设计基础知识单元总结提升本单元中,核心容有C语言中基本的数据类型、常量和变量、运算符和表达式以及算法 的概念。通过本单元的学习,我们应该

6、知道:1. C语言中最基本的数据类型有:整型、字符型、浮点型 。2. C程序中使用的常量按照表现形式可分为直接常量和符号常量。(1)直接常量1 )整型常量,有十进制、八进制和十六进制三种描述方式,其中,八进制的前置符 号标志为0_,十六进制的前置符号标志为 0x或0X。2 )浮点型常量,有十进制小数和指数两种描述方式,指数形式的符号标志是 e或E ,3 )字符型常量,是用单撇引号括起来的单一字符,对一些特殊字符和控制字符用的形式表示。4 )字符串常量,是用双撇引号括起来的一串字符序列。字符串的结束标志为 '0 '。(2)符号常量符号常量是使用某个符号代表的常量,符号常量使用编译

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

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

9、LL;3 .已知大写字母 A的ASCII是65,小写字母a的ASCII是97,以下不能将字符型变量c中的大写字母转换成对应的小写字母的语句是()。A. c= (c-'A')%26+'a'B. c2=tolower(c);C. c= c-'A'+'a'D. c=('A'+c)%26-'a'4 .设有定义:double d,h;,其中d为三角形的底边长,h为三角形的高,则以下 C语言表1达式与其面积公式1dh计算结果不相符的是()。2A. d*h/2B, 1/2*d*hC, d*h*1/2 D. d/2

10、*h5 .以下选项中,与 k=n+;完全等价的语句是()。A. k=n;n=n+1;B . n=n+1;k=n;C. k=+n;D. k+=n+1;二.填空题1 .写出整型变量a、无符号长整型变量 b、双精度浮点型变量 c和字符型变量d的定义语句: O2 .常量a和" a”分别占用 个字节和 个字节的存储空间。3 .有定义int a=1234获取其百位数码的表达式为 。4 .若有定义:char a=97,c;,则表达式 c='a'+'8'-'3' 的值为。5 .已知int x=6;,则执行x+=x-=x-3;语句后,x的值是。6 .将一

11、个浮点型变量n四舍五入精确到小数点后两位,其表达式为: 7 . C语言中基本的数据类型有 、。8 .结构化程序设计中基本的程序结构有 、*习题答案:一.选择题1. C2. B 3. D 4. B5. A二.填空题2. int a; unsigned long b; double c; char d;3. 1 24. a/100%105. f6. 67. (int)(n*100+0.5)/100.0;8. 整型、浮点型、字符型9. 顺序、选择、循环*单元三顺序结构程序设计单元总结提升本单元中,核心容是顺序程序结构程序设计中标准输入输出库函数的使用。通过本单元的学习,我们应该知道:1 . C语言提

12、供了标准输入输出库函数用于实现数据输入输出操作,其对应的头文件为stdio.h 。2 .单字符输入和输出函数分别为getchar()和putchar()。3 .格式化输入和输出函数分别为scanf()和printf()。4 .格式化输出函数有两种调用格式:(1) printf(" 字符串常量");(2) printf("格式控制字符串”,输出项列表);5 .格式化输入/输出中,格式控制符由_%开头。常用的格式控制符有:整型 int 格式符%d、float 浮点型格式符 %f、double浮点型格式符 %lf 、字符型格式 符%c ;对于浮点型格式可以用 m.n 形

13、式的附加格式说明小数的宽度和小数位数。6 .格式化输入中的输入项为地址列表,对变量取地址的运算符为 &。通过本单元的学习,应对顺序结构程序设计的特点和设计思路有所了解,同时重点学会单字符输入函数 getchar()、单字符输出函数putchar()、格式化输出函数printf() 和格式化输入函数 scanf()的正确使用。单元练习一.选择题1 .已定义x为float 型变量,其值为213.45678 ,则printf("%-4.2fn",x);的输出结果为()。A. 213.46B. 213.45C. -213.45D.输出格式控制说明的域宽不够,不能输出2 .有

14、以下程序,程序运行时输入:123V回车,则输出的结果为()。#include <stdio.h>void main() int a,b,c;scanf("%d%d%d",&a,&b,&c);printf("a+b+c=%dn",a+b+c);A. 6B. a+b+c=6C.123D.不确定的值3 .下面输入语句中,正确的是(A. scanf( "a=b=%d",&a,&b);B.scanf( "%d,%d",&a,&b);C. scanf( &qu

15、ot;%c",c);D.scanf( "%d %dn",&f1,f2)4 .在VC+6.0环境中,下列说法正确的是()。A.输入函数scanf()输入多个数据时,有时数据间不必加间隔符。B.输入函数scanf()中单精度或双精度浮点型数据都要用f作为格式控制符。C.使用输出函数printf()输出字符或字符串都用格式控制符$D.输出函数printf()中单精度或双精度浮点型数据都要用f作为格式控制符。5.下面程序的功能是实现两个字符变量互换值,若为 ch1输入a, ch2输入b,则程序运行 时正确的输入是()。#include stdio.hvoid ma

16、in() char ch1,ch2,ch;scanf("%c%c",&ch1,&ch2);ch=ch1;ch1=ch2;ch2=ch;printf("ch1=%c,ch2=%cn",ch1,ch2); A. a,bB. a空格bC. ab D. a回车b二.填空题1 .有语句putchar(getchar(),程序运行时输入:A,则输出结果是。2 . printf("%6.2f%”,1.0/3); 的输出结果是 。3 .补充程序:int n1=10,n2=20; printf("”,n1,n2);要求按以下格式输出n1

17、和n2的值,每个输出行从第一列开始。n1=0010n2=00204 .有以下程序,程序运行时输入:1234回车,执行后输出的结果是 #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 .输入多个非字符型的数值数据时,数据输入时可用 、 和 作为间隔符。*习题答案:一.选择题1. A 2. D

18、3. B 4. A5. C二.填空题1 .A2.0.33%3.n1=%04dnn2=%04d4.n1=1,n2=125 .空格,TAB键,回车*单元四选择结构程序设计单元总结提升在选择结构程序设计中,条件判断表达式和选择结构实现语句是两个核心容。通过本单元的学习,我们应该知道:1 .条件判断表达式由关系运算符及其表达式、逻辑运算符及其表达式构成,其中:(1) 关系运算符有:、=、=、!=、=(2) 逻辑运算符有:&&、|、!2 .选择结构实现语句有三种方式:(1) 单分支if选择结构,一般格式为:if ( 表达式)语句;(2) 双分支if-else选择结构,一般格式为:if (

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

20、符型数据,且“常量表达式”只能由常量构成,通过“表达式”与“常量表达式”之间的对等关系构造出多分支选择结构。( 3)在某些多分支选择结构程序设计中,既可使用if-else 语句实现,也可以使用switch 语句实现。switch 语句与 if 语句的不同之处在于:switch 语句仅能判断一种逻辑关系,即“表达式”和指定“常量表达式”的值是否相等,而不能进行大于,小于某一个值的判断,不能表达区间数据的概念;if 语句可以计算和判断各种表达式。所以switch 语句不能完全替代if 语句。总之,通过本单元的学习,应该掌握C 语言选择结构程序设计的思路和语句的基本用法。单元练习一选择题1 以下选项

21、中,当x 为大于 1 的奇数时,值为0 的表达式()。A x%2=1B x/2C x%2!=0D x%2=02 .在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);A1B -1 C 0 D 不确定4下列语句将小写字母转化为大写字母,正确的语句为

22、()。Aif( z >=ch>=a ) ch=ch-32;B if(ch>= a &&ch<= z ) ch=ch-32;C. ch=( ' z' >=ch>=' a' )?ch-32:ch;D. ch=( ch>= ' a' &&ch<=' z' )?ch:ch-32;5.关于与switch语句配套的case语句中所使用的表达式,说法正确的是()。A.可以是变量B.可以是常量或变量C.只能是常量或常量表达式D.无论是何种表达式,只要在执行时有确定的值

23、就行.填空题1 .在算术运算符、关系运算符、逻辑运算符和赋值运算符中,运算优先级最高的运算符 是,最低的是。2 .正确表示数学关系" 1<a<4”的C语言表达式为 。3 .整型变量n不能被3整除的条件判断表达式为 。4 .以下程序段的功能是:对输入的大写字母循环移动6个位置后输出,如 A变为G , ' W变为'C'。请将程序段补充完整。char ch;ch=;if(ch>= ' A &&)else if( )putchar(ch);5 .以下程序段功能是根据学生考试成绩,确定其成绩等级,成绩与等级对应情况与【例4-7】

24、中表格相同,请将程序段补充完整。char level; /成绩等级float score; /考试成绩scanf( "%f” ,&score);switch( ) :level=,A ;case 8:level='B'break;case 7:level='C; break;case 6:level='D' break;.专业.专注.default:printf( “考试成绩等级为: .",level);*习题答案:选择题1. D2. D 3. C 4. B5. C二.填空题2. !(非)=3. a>1&&

25、;a<44. n%3!=05. char ch;ch= getchar();if(ch>= ' A' && ch<=T )ch=ch+6;else if(ch>='U'&&ch<='Z') ch=ch-20;putchar(ch);6. char level; /成绩等级float score; /考试成绩scanf( "%f” ,&score);switch(int(score/10) case 10: case 9 :level= > A ; break ;

26、case 8: level='B'break;case 7: level='C; break;case 6: level='D' break;default: level='E'*单元五循环结构程序设计单元总结提升在本单元中,如何理解循环的本质、如何分析循环的三个要素以及如何描述循环结构语句是核心容。通过本单元的学习,我们应该知道:1 .循环的本质是将程序员从大量重复编写相同代码的工作中解放出来,减少程序源代码的存储空间,提高程序的质量,提高程序编写的工作效率,但计算机执行程序的 工作量并没有减少。2 .循环结构的三要素包括:(1)循环变

27、量初值(2)循环控制条件表达式(3)循环体3 . 循环结构描述语句有三种:while、do-while 和 for。其中while 和do-while 的区别在于 不管循环条件是否成立, do-while 循环都先执行 一次循环体,所以 do-while 循环的循环体至少执行一次,而 while 循环的循环体可能 一次都不执行 。4 .循环结构控制语句break的作用是:结束循环;循环结构控制语句 continue 的作用是:提前结束本次循环。5 .在一个循环结构语句中又包含了一个循环结构语句称之为循环的嵌套。程序执行时,外层循环每执行一次,层循环就要完整的执行完,直至层循环执行结束,再开始执

28、行下一次外层循环。学习完本单元,应该掌握C语言循环结构程序设计的思路和基本语句的用法。至此,我们就学完了结构化程序设计中的三种基本结构:顺序、选择和循环。单元练习选择题1 .下面说法正确的是(A. while语句不管条件表达式是否为真,都将执行一次循环体。B. do-while语句构成的循环,一定要有能使while后面表达式的值为 0的操作,或在循环体中使用break语句。C. for循环只能用于循环次数确定的情况,且先执行循环体语句,后判断条件表达式。D. break语句的作用是从最近的循环体跳出来,而 continue语句的作用是继续执行循 环体中尚未执行的语句。2 . 对for(表达式1

29、;表达式3),可理解为()。A. for(表达式1;0;表达式3)B. for(表达式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的奇数之和D .计算自然数110的累加和4.以下能正确计算 1*2*3*4*5*6*7*8*9*10的程序段是()。A. doi=1;s=1;s=s*i;i+;w

30、hile(i<=10);C. i=1;s=1;dos=s*i;i+;while(i<=10);B . doi=1;s=0;s=s*i;i+;while(i<=10);D . i=1;s=0;dos=s*i;i+;while(i<=10);5.有以下程序段int k=0;while(k=1) k+;while循环执行的次数是()。A.无限次B. 1次C.语法错误,不能执行D. 一次也不执行.填空题1 .若输入字符串:abcde回车,则以下while循环体将执行 次。 while(ch=getchar()= ' e' ) printf( "*&qu

31、ot;);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的所有整数,请填空。#include <stdio.h>void main() int i,j;for(i=0; ;i+) j=i*10+

32、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 i,t=1,s=0;.专业.专注.for(i=1;i<=101;i+=2) s=s+ ;; printf("%dn"

33、,s);*习题答案:一.选择题1. B 2, B3. B 4. C5. A二.填空题1. 02. 0111223. i<10 j%3!=04. 235. i*t t=-t*单元六数组的使用单元总结提升在本单元中,如何定义一维、二维数组、如何操作数组以及如何利用字符数组处理字符 串是核心容。通过本单元的学习,我们应该知道:1 .数组是一组相同类型的有序数据的集合。数组要先定义后使用,可以在定义时初始 化,每个数组元素相当于同类型的变量,使用数组名和下标来唯一确定数组中的元 素。2 .一维数组定义的一般格式为:类型标识符数组名整型常量表达式;,对于已定义好的一维数组 C编译系统会分配连续的存

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

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

36、;1','2 , 3 , '0'C char s="123n"'3';2 .下列数组定义语句中,正确的是()A. int a口尸1,2,3,4,5,6;C int a3=1,2,3,4,5,6;3 .已定义 int a口3=1,2,3,4,5,6,7,8,9;A. 2B. 4C. 6D.B. chars尸"123"D. char s4='1',2 ,B. char a23=' a',' b'D. int a=1,2,3,4,5,6;,则a12的初值为()。8A

37、. if(str1>str2)C. if(strcmp(str2,stn)>0)B. if(strcmp(str1,str2)<0)D. if(strcmp(str1,str2)>0)4 .判断字符串str1是否大于字符串str2,应当使用()。5 .下列程序段的功能是给数组所有的元素输入数据,然后输出,请选择正确答案填空()。#include <stdio.h>void main() int a10,i=0;while(i<10) scanf("%d", );for(i=0;i<10;i+) printf("%4d

38、",ai);A. a+(i+) B . &ai+1 C . a+i D . &a+i.填空题1 .定义一个名为a的单精度浮点型一维数组, 数组的长度为4,所有元素的初值均为 0,定 义语句为 ,引用该数组元素时, 下标的围是 , 该数组占用的存储空间为 字节。2 .设有数据定义语句int i=3,x4=1,2,3;,则数组元素xi 的值3 .下列程序的功能是读取10个实数,然后依次输出前1个实数和、前2个实数和、前9个实数和、前10个实数和。请将程序补充完整。#include <stdio.h>void main() float f10,x=0;int i

39、;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.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=

40、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 .阅读下列程序,程序运行后的输出结果是#include <stdio.h>#include <string.h>void main() char s320=“1234“,“ 234567“,“ 6789” ;int i,k;for(k=0,i=1;i<3;i+)if(strcmp(

41、sk,si)<0) k=i;puts(sk);*习题答案:选择题1 C2C3 C4D5 A二填空题1 float a4=00至3162 03 x+=fi; 或 x=x+fi;4 &bij cij=aij+bij5 6789*. 专业.专注.单元七函数的使用单元总结提升在本单元中,如何使用自定义函数是核心容。通过本单元的学习,我们应该知道:1 .函数是构成C程序的基本单位,函数的使用为模块化程序设计奠定了基础。从用户 使用的角度,函数分为库 函数、 自定义 函数两种。2 .库函数的使用包括头文件包含和库函数调用 两个环节;用户自定义函数的使用包括 函数声明、函数定义和函数调用三个环

42、节。3 .从函数的外观形式看,函数分为 有参函数、 无参 函数两种。当主调函数调用 无参 函数时,不需要向这些函数传递参数;当主调函数调用有参 函数时,需要传递参数。4 .用户自定义函数的一般形式为: 函数返回值类型 函数名(形式参数列表)/函数首部函数体;其中第一行称为 函数首部,大括号“ ”括起来的部分称为 函数体,对于有返 回值的函数,函数体中要包括 return 语句。5 .函数首部也称为函数原型,用函数原型声明函数时,形参名可以省略不写,而只写 形参的类型,但形参的 类型和数量必须与函数首部保持一致。6 .函数要先声明,然后才能使用,函数声明在程序中的位置有以下几种情况:(1)函数声

43、明写在主调函数的外部,这时的函数声明为全局声明。(2)函数声明写在主调函数 的说明语句中,这时的函数声明为局部声明。(3)函数的定义出现在主调函数之前,则函数声明可以省略。7 .函数的调用形式为:函数名(实际参数列表)。若调用无参函数,则实参为空;若调用有参函数,则在()写出与形参类型、数量一致的实参。对于有参函数,函数调用过程中存在着参数传递的问题,参数传递有两种情况,其一为 值传涕.其二为 地址传涕。8 .函数在函数体中出现了对自身调用的语句,就称为函数递归调用。使用递归方法解 决问题的关键是如何找出 递归关系 .以及找出递归调用的 终1卜.条件 。9 .带参宏定义的一般形式为:#defi

44、ne多(形参列表) 字待由 。通常用带参数的宏定义代替简单公式型函数。10 .函数的存储类型有 static 和extern两种。extern 型函数称为"外部函数",可 以被其他编译单位中的函数调用;st被c型函数称为“部函数”,只能被本编译单位的函数调用。11 .程序中变量的使用围称为变量的作用域,每个变量都有自己的作用域。按照作用域的围可分为两种:局部变量和全局变量 。12 .变量的存储方式可分为“动态存储”和“静态存储”两种。动态存储变量包括auto 和regiestM种类型;静态存储变量包括static 和extern 两种类型。静态存储变量若没有初始化,则默认初

45、始值为_0。static 类型变量的值具有继承性,即本次调用的初值是上次调用结束时变量的值。单元练习一.选择题1 .关于使用函数的目的,以下不正确的说法是()。B.提高程序的开发效率D.提高程序可读性B. void fun(int x;int y)D. void fun(x,y)A.提高程序的执行效率C.减少程序文件所占存2 .以下正确的函数首部是(A. void fun(int x,int y)C. void fun(int x,y)3 .设函数fun的定义形式为:void fun(char ch, float x) 则以下对函数fun的调用正确的是()。A. fun( "abc&

46、quot;,3.0);B. t=fun('D',12.3);.专业.专注.D. fun(65,65);C.数组的每一个元素的地址D.数组的每一个元素的值C. fun('65',3.7);4 .关于函数的实参和形参,以下正确的说法是()。A.实参和对应的形参各占用独立的存储单元B.实参和对应的形参共同占用同一存储单元C.只有当实参与形参重名时才共同占用存储单元D.形参是虚拟的,不占用存储单元5 .当调用函数时,实参是一个数组名,则向函数传递的是()。A.数组的长度B.数组的首地址6 .将一个函数指定为static 存储类别后,该函数将(A.既可以被同一源文件中的函

47、数调用,也可以被其他源文件中的函数调用B.只能被同一源文件中的函数调用,不能被其他源文件中的函数调用C.只能被其他源文件中的函数调用,不能被同一源文件中的函数调用D.既不能被同一源文件中的函数调用,也不能被其他源文件中的函数调用7 .以下叙述正确的是()。A.全局变量的作用域一定比局部变量的作用域作用围大8 .静态static类型变量的生存期贯穿于整个程序的运行期间C.函数的形参都属于全局变量D.未在定义语句中赋初值的auto变量和static变量的初值都是随机值二.填空题1 .假设已有#define M(r) r*r ,则语句printf( " %d ,M(2+3);的执行结果为

48、2 .以下程序输出结果为 。#include <stdio.h> void fun(int x,int y) x=x+y;y=x-y;x=x-y;printf("%d,%dn",x,y);void main() int x=2,y=3;fun(x,y);printf("%d,%dn",x,y);3 .以下程序输出结果为 。#include <stdio.h>int a,b;void fun()a=10;b=20;void main() int a=3,b=9;fun();printf("%d,%dn",a,b)

49、;4 .以下程序输出结果为 。#include <stdio.h>int f( )/定义f函数,a为形参int b=0;/定义b为自动变量static int c=3;/定义c为静态局部变量b=b+1;c=c+1;return b+c;void main()int a1,a2;a1=f();a2=f();printf("%d,%d”,a1,a2);5 .以下程序输出结果为 。#include <stdio.h>int fun(int n)if(n=1) return 1;else return fun(n-1)+1;void main() int i,j=0;

50、for(i=1;i<3;i+)j+=fun(i);printf("%dn",j);6 .以下程序输出结果为 。#include <stdio.h>void fun(int a , int n) for(int i=0;i<n;i+) if(ai>0) ai*=2;void main() int b5=1,2,3,4,5;fun(b,5);for(int i=0;i<5;i+) printf("%dt",bi);*习题答案:一.选择题1 A2A3D4A5B6B7B二填空题1 112 3,22,33 3,94 5,65 3

51、6 246810*. 专业.专注.单元八指针的使用单元总结提升在本单元中,对指针的理解,以及利用指针访问不同形式的数据是核心容。通过本单元的学习,我们应该知道:6 .存地址就称为指针。 C语言允许用一个变量来存放指针,这种变量称为指针变量, 而指针变量的值就是某个存单元的地址。7 .定义指针变量的一般格式为:类型标识符*指针变量名,其中:(1) “指针变量名”前面的“ *”,表示该变量是指针变量,不能省略。(2) “类型标识符”表示该指针变量所指向的变量的数据类型。(3)当一个指针变量已确定指向某类型的变量时,不能再指向另一种类型的变量。3 .指针变量被赋值后即可引用,引用指针变量的一般方法为

52、:*指针变量名 。4 .指针和数组有着密切的关系,任何通过控制数组下标实现的对数组的操作,都可用指针来实现。要通过指针操作数组,首先要建立指针变量与数组之间的关系, 然后才能 通过指针变量访问数组元素。若有语句段:int a10; int *p;p=a;,则对于数组元素的访问方式有 ai 、*(p+i) 、pi ,对数组元素地址白表示方式有 a+i 、 p+i、&ai。5 .数组名代表数组的首地址,利用函数处理一维数组数据时,函数之间的参数传递为数组首地址。将数组的首地址作为实参传递给函数的形参以后,实参数组和形参数组其实是同一段存中的数据。6 .字符串是存放在某存储区域的一串字符序列,可通过字符数组和字符指针两种方式 操作字符串。7 .函数返回值可以是地址(指针类型),返回值为地址的函数定义形式为:类型标识符 *函数名 (形参列表);。通过本单元的学习,应明确地址和指针的关系,掌握使用指针访问存数据的基本方法。单元练习选择题p指向a,以下赋值1 .假设整型变量 a的值是12, a的地址

温馨提示

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

最新文档

评论

0/150

提交评论