C语言期末复习资料 (2).doc

上传人:博****1 文档编号:551641776 上传时间:2022-09-08 格式:DOC 页数:11 大小:121.50KB
返回 下载 相关 举报
C语言期末复习资料 (2).doc_第1页
第1页 / 共11页
C语言期末复习资料 (2).doc_第2页
第2页 / 共11页
C语言期末复习资料 (2).doc_第3页
第3页 / 共11页
C语言期末复习资料 (2).doc_第4页
第4页 / 共11页
C语言期末复习资料 (2).doc_第5页
第5页 / 共11页
点击查看更多>>
资源描述

《C语言期末复习资料 (2).doc》由会员分享,可在线阅读,更多相关《C语言期末复习资料 (2).doc(11页珍藏版)》请在金锄头文库上搜索。

1、期末复习资料 第11页-总11页期末复习学完C语言后要求各位达到的一个最基本的目标是对于给定任务能够独立设计和编写多函数(模块)的程序。很遗憾对于模块的规划和设计能力在我们目前公共课的考试系统和作业系统中基本没有很好的体现,而要编写程序就得熟练掌握各个知识点,下面我们以多模块程序为基点来介绍我们这门课主要讲授的内容。第一部分:C中的数据首先,从主调函数和被调函数(模块间)要处理的任务数据的角度来总结数据的知识点:C语言中所讲授的数据有基本类型(整型、实型和字符型)和构建类型(数组、结构体、共用体、链表结点)之分。构建类型是由基本类型构建而成,因此我们有必要对基本类型的数据做以更细致的研究。一基

2、本类型的数据程序中的数据无非是以常量和变量两种形式描述。在这里我们应思考两个问题:(1)为什么要用变量?(2)常量经常用在什么地方?(一)常量对于基本类型常量我们要掌握:常量分几类?每类的书写规则是什么?(1)整型常量:有十、八、十六进制三种表示形式。(3.3.1、3.3.3)(2)实型常量:有小数和指数两种表示形式.(3.4.1、3.4.3)(3)字符型常量:有普通字符(可以是ASCII码表中的任何一个字符)、转义字符(表示控制命令的转义字符和用八进制十六进制描述的转义字符)(3.5.1)(4)字符串常量(3.5.4)(5)符号常量:实际上是不带参数的宏定义(3.2.1 、9.1.1)对于常

3、量部分的考察无非是辨别书写形式,字符类的常量特别注意转义字符的辨认。这就要求我们熟记书写规则。例如以下题目:t-1:下面哪个是正确的整型常量表示A)019B)0X34gC)-123D)o56E) 12,000t-2: 下面哪个是错误的实型常量表示A).23B)3.8E-4.5C)45E12D)92.45t-3: 下面哪个是正确的字符常量表示:A)”b”B)C)34D)0x9E)0123t-4: 下面那个是正确的字符串常量表示:A)abcB)“”C)“ ”D)“0x120”E)”abRT0”F)”A”t-5: 字符串“ab0340tv012”中有多少个字符?t-6: puts(“ab0340tv

4、012”);的结果是什么?strlen(“ab0340tv012”)的值是多少?(二)变量对于基本类型的变量,我们知道要使用变量必须先定义变量,定义的基本格式是:数据类型 变量名;要正确定义变量就必须清楚两点(1)什么样的变量名才是合法的?(3.2.2)(2)如何用类型符来描述所要定义的变量,这就涉及到变量所分配的字节数、存储特点、有无符号及各自表示的数值范围等。变量的三大类:(1) 整型变量(3.3.2)分配字节:2字节(int/short) 4字节(long)存储特点:存储的是数值的补码形式符号标识:signed unsigned表示数值范围:表3-1(2) 实型变量(3.4.2)分配字节

5、:4字节(float) 8字节(double) 16字节(long double)存储特点:图3-7表示数值范围:表3-2(3) 字符型变量(3.5.2、3.5.3)分配字节:1字节(char)存储特点: 存储字符的ASCII值符号标识:signed unsigned表示数值范围:signed char: -128+127 Unsigned char: 0255基本类型变量这部分知识主要的考察形式:(1)变量名(标识符)的正确与否鉴别(2)变量类型标识符的识别与应用(3)变量定义语句中对变量进行初始化的形式正确与否鉴别(3.6)例如以下题目:t-7: 以下正确的变量标识符是:A)3sumB)I

6、NTC)_3maxD)caseE)p&sum F)s_m_at-8: 以下正确的变量类型声明是:A)signed int B)int longC)unsigned longD)short longt-9: 下面程序段在tc2.0和cfree3.0运行时的输出各是什么?unsigned int a=65535; printf(%d,a);t-10: 以下正确的定义语句是:A)int a=b=5 ; B)char ch=97 ; C)unsigned int x, y=-5; D)int a=3,b=5;E)int c=3(二)建构类型的数据程序给出的任务数据可以是基本类型的,也可以是集合性质的。

7、集合中的所有数据可以是同类型的即数组(7.1.17.1.3、7.2.17.2.3、7.3.17.3.4),也可以是不同类型的(例如学生记录)即结构体(11.111.5)。在这部分知识中主要考察的形式有:(1) 数组及结构体的定义、初始化和引用(2) 计算集合(数组、结构体变量)存储所需要的空间(3) 数组定义时缺省形式的一些规则:l 在定义一维数组时,若给出了初值则一维中括号内的数值可以省略,由初始值的个数来确定其值。但若没有给出初始值,则不能省略中括号内的值。例如:int a=1,2,3; int b=3;都对。int a; 不对。l 二维数组的第2维列数任何情况下都不能缺省,第1维中的数值

8、若在给出初始值的按情况下可以缺省。例如int a2=1,23,4不对。 int a2=1,2,3,4,5;正确。(4) 只有在数组定义时可以给数组整体赋值,不能单独用赋值运算“=”给数组整体赋值,特别是字符串数组。例如int a3; a=1,2,3; char b10; b=”china”; char c210; c0=”chian”;c1=”japan”都不对, 只能是int a3=1,2,3;char b10=”china”; char c210=“china”,”japan”; (5) 函数体内定义的数组名是地址常量,而由数组名表示的一些表达式也是常量表达式。如int a3=1,2,3;

9、 a,a+i都是常量。int b33=.; b,b0,b+i,*(b+i)也都是常量形式。常量形式意味着该式只能出现在等号的右边,而不能作为左值。例如以下题目:t-11: 以下正确的数组定义形式是:A)int n; scanf(“%d”,&n); int an;B)#define N 10 int aN;C)int b34;D)char b 4;t-12: 以下不正确的数组定义和初始化形式是:A)int a=1,2,3; B) int a=0; C) int a3=1,2,3,4; D)int a22=1,1,2,2,3,3 E) char a10=“hello”; F) char a=”he

10、llo”;G)int a2=1,1,2,2; H) char a10; a=”hello” ;I)char a210; a0=”hello ” ;a1=”tom” ; G) char a210=“hello”, “tom”;t-13: 在TC2.0中存储以下结构体类型的变量需要多少字节?struct A int x,y; char s10; float a; ;t-14:以下结构体类型声明是否正确:A)struct A B) struct A C) struct A int x=2; struct A a; int a; float b; int b; struct A *p; ; ; ;t-

11、15: 若有数组int a22=1,2,3,4,则能引用数组元素4的形式为:A) a12 B) *(a+1) C) *(*(a+1)+1) D) *(a+3) E) a11 F) *(a1+1)t-16: 若有数组int a3=1,2,3;则能引用数组元素2的形式为: A) a1 B) *(a+1) C) &a1 D) a+1t-17: 若有如下程序段,则对于“TOM”串中首字符T的正确引用形式为: struct A int age; char name10; ;Struct A t2=1,”TOM”,2,”MIKE”,*p=t;A)(*p).name B) t2.name C)t1.name

12、0 D)p-name0第二部分:数据的输入输出讨论完C中的数据我们再讨论各种数据的输入与输出。如果数据输入不当再完美的程序也不可能显示出预期的结果。这部分作业的输入出现的问题较多,我们要熟记输入规则但不能死记硬背。下面的这三对函数都包含在文件“stdio.h“中,因他们的输入输出终端是标准设备-键盘和显示器,因此称为标准的IO函数,标准IO函数的使用与缓冲区有密切的联系。学习本部分时最重要的是要理解输入缓冲区中数据流和输入函数格式匹配的输入机制(参见本章手册中的参考资料)C中的输入输出是调用系统库函数来实现的,常见有三对库函数:(1) scanf()/printf(): 可输入输出任何类型的数

13、据。一次函数调用可以实现多个数据的IO。(2) gets()/puts(): 只对字符串数据进行输入输出操作。一次函数调用只可实现一个串的IO。(3) getchar()/putchar():只对字符数据进行输入和输出操作。一次函数调用只可实现一个字符的IO。对于这几对函数的使用主要考察:(1) scanf、printf的使用规则(4.5,可参考本章教学目标)(2) getchar和putchar的使用格式(4.4)(3) gets与scanf的使用区别例如以下题目:t-18:若有程序段int a; float x; char c10;scanf(“%2d%f%s”,&a,&x,c);当程序执行时从键盘输入 23456.78abcd ,问变量a、x、和 c中的值各是什么?t-19:若有定义int a;float b; 则scanf(“a=%d;b=%f”,&a,&b);的输入形式是什么?t-20:若有定义float x;则语句scanf(“%5.2f”,&x)是否正确?t-21:若有定义char a,b;对于scanf(“%c%c”,&a,&b);若输入A B,则a、b的值各是什么?t-22:若用getchar()函数输入一个字符存储到字符变量ch中再将其输出,则以下正确的写法是:

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 生活休闲 > 社会民生

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号