C语言-复习计划提纲记要.doc
《C语言-复习计划提纲记要.doc》由会员分享,可在线阅读,更多相关《C语言-复习计划提纲记要.doc(31页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。
1、C C 语言复习提纲语言复习提纲第一章第一章 C C 语言程序设计概述语言程序设计概述一、Visual C+6.0 开发环境 1、了解 Visual C+6.0 的安装过程; 2、了解 Visual C+6.0 的工作界面,菜单和工具栏的使用; 二、掌握 C 语言程序运行的过程 1、编辑:编辑:是指把按照 C 语法规则编写的程序代码通过编辑器(Visual C+ 6.0,Turbo C 3.0)输入计算机,并存盘。在存盘时,C 源文件的扩展名为 .c 2、编译:将编译:将 C C 语言源程序编译成目标程序语言源程序编译成目标程序,即对源程序进行编译,并将源程序转换为扩展名 为.obj 的二进制
2、目标代码(即把已经编辑好的源程序翻译成二进制目标代码的过程把已经编辑好的源程序翻译成二进制目标代码的过程) 。 3、连接连接:将用户程序生成的目标代码文件(.obj)和系统提供的库文件(.lib)中的某些代 码连接在一起,生成一个可执行文件(.exe) 。 4、执行执行:执行生成的可执行代码,并输出结果。 5、调试调试:是将编制的程序投入实际运行前,用手工或编译程序等方法进行测试,修正语法错 误和逻辑错误的过程。 三、结构化程序设计的基本概念 1、概念 以模块化设计为中心,将待开发的软件系统划分为若干个相互独立的模块,将原来较为复杂的 问题化简为一系列简单模块的设计,任何模块都可以使用一些基本
3、的结构来实现,任何复杂的程序, 都可以使用这些基本结构按一定的顺序组合起来,这些基本结构的特点都是只有一个入口、一个出 口,这样的程序设计方法称为结构化程序设计。 2、基本思想 结构化程序设计的基本思想是采用结构化程序设计的基本思想是采用“ “自顶向下,逐步细化、模块化设计、结构化编码自顶向下,逐步细化、模块化设计、结构化编码“的程序设 计方法和“单入口单出口“的控制结构。 3、三种基本结构 顺序结构顺序结构 选择结构选择结构 循环结构循环结构 4、三种基本结构的特点 只有一个入口 只有一个出口 每一个基本结构中的每一部分都有机会执行到 结构内不存在“死循环” 5、设计原则 自顶向下 逐步细化
4、 模块化设计 结构化编码 四、C 程序的基本组成: C 程序是由若干个函数构成的,至少有一个主函数 main(),main()main()的位置可以任意,的位置可以任意,其他各函 数在程序中的前后位置也是可以任意的。程序的执行总是从主函数开始,在主函数中结束。主函数程序的执行总是从主函数开始,在主函数中结束。主函数 是可以调用其他任何非主函数的函数,任何非主函数也可以调用其它任何非主函数。是可以调用其他任何非主函数的函数,任何非主函数也可以调用其它任何非主函数。 C 程序的基本组成:声明区、主程序区、函数定义区。 1、声明区 处在程序文件的所有函数的外部,一般包含:包含头文件、宏定义、类定义、
5、结构体定义、函 数声明、全局变量声明、条件编译等。 2、主程序区 主程序以 main()函数开始,main()函数(主函数)是程序运行时的入口,包含局部变量的声 明、函数调用、一般运算、结构控制、对象与结构的处理、文件处理等。 3、函数定义区 函数的定义包含函数说明和函数体两部分。4、注释 /或/* */为注释,不能嵌套 不产生编译代码,不影响程序的执行效率。 五、标识符 1、标识符的定义:用来对变量、符号常量名、函数、数组、类型等命名的有效字符序列统称 为标识符。 2、标识符的命名规则:由字母、数字或下画线组成,并且第由字母、数字或下画线组成,并且第 1 1 个字符必须为字母或下画线。个字符
6、必须为字母或下画线。 注意:标识符区分大小写,即大写字母和小写字母的通常意义不同,且不能与关键字重名。注意:标识符区分大小写,即大写字母和小写字母的通常意义不同,且不能与关键字重名。 练习练习 1_11_1:下列变量标识符哪些是正确的,哪些是不正确的?:下列变量标识符哪些是正确的,哪些是不正确的?a3bca3bc if a!bc _abc_abc abcabc _3abc_3abc a_bca_bc 3abc3、标识符分类:关键字、预定义标识符、用户自定义标识符。第二章第二章 数据类型、运算符和表达式数据类型、运算符和表达式一、C 语言的数据类型C C 语言中基本数据类型包括整型、实型、字符型
7、、枚举类型,构造类型有数组、结语言中基本数据类型包括整型、实型、字符型、枚举类型,构造类型有数组、结构体、共用体等。构体、共用体等。、基本数据类型(见 P17) 、构造类型又称为组合类型,它是由基本类型按照某种规则组合而成的。 数组:是由具有相同数据类型的元素组成的集合。 结构体:是由不同的数据类型构成的一种混合的数据结构,构成结构体的成员的数据类型 一般不同,并且在内存中分别占据不同的存储单元。 共用体:是类似于结构体的一种构造类型,与结构体不同的是构成共同体的数据成员共用 同一段内存单元。 枚举:是将变量的值一一列举出来,变量的值只限于列举出来的值的范围内。 、指针类型变量用于存储另一变量
8、的地址,而不能用来存放基本类型的数据。它在内存中占图2_1 C语言的数据类型数据类型基本类型空类型(无值类型)void构造类型指针类型实型(浮点型)联合型类型union单字符型char整型int 单精度型float双精度型double字符型宽字符型w-char 逻辑型bool类类型class枚举类型enum结构类型struct数组类型据一个存储单元。 、类是一种数据类型,它定义的是一种对象类型,由数据和方法组成,描述了属于该类型的 所有对象的性质。 二、常量和变量 、常量:在程序运行的整个过程中,其值始终保持不变的量。 整型常量:表示形式有十进制、八进制(以 0 开头)和十六进制(以 0x 或
9、 0X 开头) 。整 型常量可以后缀字母 L(或 l)表示长整数,后缀字母 U(或 u)表示无符号整数。 实型常量(浮点型常量):表示形式有一般形式和指数形式。实型常量缺省为 double 型 (双精度型) ,如后缀 f 或 F,则为 float 型(单精度型) 。 字符常量:用单撇号括起来的一个字符。如A,*等。 转义字符:用反斜杠引导的,具有特定含义的字符(见 P22表 2-4),如 n,367,x8a。 注:C 语言字符集中的任何一个字符均可用转义字符来表示。 字符串常量:用双撇号括起来的字符序列。如“student“,“广东广州“等。 布尔常量:false,true。 符号常量: #d
10、efine 宏名 常数 练习练习 2 2_1_1:下列哪些是合法的常量:下列哪些是合法的常量: 12.7f 09860986 0986.012 、0625L 87U -0x98C2 01a01a -6.87E-2 1.2e0.51.2e0.5 E-3E-3 0xFF 2L 72 160 -0xffff 5E2.05E2.0 -0xcdf 1.3E1.3E 2E0 06680668 (21)011 (22)0xe (23)-01 (24)-0x48a (2525)0x0x 变量:指程序在运行时其值可改变的量。 变量应先定义(声明其类型和名称)后使用; 变量定义的一般形式为: ,; 在定义一个变量
11、的同时,也可以给它赋以初值。 练习练习 2_22_2 以下正确的变量标识符是以下正确的变量标识符是 3abc3abc $amount$amount Num_of_Student ifif a!bca!bc _above _abc abab sin day三、运算符和表达式 1、算术运算符和算术表达式 注意:int i=1.2*3; /结果为 3,而不是 3.6。 int i=5/3 结果为 1。 表达式表达式 17175 5 的结果是的结果是 3 3,表达式,表达式 17175 5 的结果是的结果是 2 2。 2、赋值运算符和赋值表达式 注意: 赋值运算符的结合性是从右至左的 复合赋值运算符:
12、复合赋值运算符:intint a=12;a=12; a+=a-=a*=a;a+=a-=a*=a;(a=a+(a=a-(a=a*a),a=a+(a=a-(a=a*a),结果为结果为 0 0) 注意: 在在 C C 语言中,定义语言中,定义 intint a=b=c=3;a=b=c=3;是错误的,而定义是错误的,而定义 intint a,b,c;a,b,c; a=b=c=3;a=b=c=3;是正确的。是正确的。 练习练习 2_32_3 设设 m=9,i=3,m=9,i=3,则执行运算则执行运算 m%=i+1m%=i+1 后后,m,m 的值是多少?结果的值是多少?结果 1 1。 m=m%(i+1)m
13、=9%(3+1)m=1m=m%(i+1)m=9%(3+1)m=1。 3、关系运算符和关系表达式 注意: 关系运算符的优先级低于算术运算符关系运算符的优先级低于算术运算符。例如:a+bc 等价于 (a+b)c,a!=bc 等价于 a!=(bc) “=”与“=”的区别4、逻辑运算符与逻辑表达式 注意: 逻辑非的优先级最高,逻辑与次之,逻辑或最低 练习练习 2_42_4 若有若有 intint a=3,b=0;a=3,b=0;则表达式则表达式 ac=+a|+b;a=b=3;c=+a|+b;后,后,b b 的值为的值为 3 3。 练习练习 2_72_7 设设 x x、y y 和和 z z 都是都是 i
14、ntint 型变量,且型变量,且 x=8,x=8, y=3,y=3, z=5,z=5, 则表达式则表达式 x*y/z+6-14%zx*y/z+6-14%z 的值为的值为 6 6。 练习练习 2_82_8 设有定义设有定义:int:int x=1,y=-1;x=1,y=-1;则执行语句则执行语句 printf(“%dn“,(x-printf(“%dn“,(x-后的输出结果是后的输出结果是 0 0。 练习练习 2_92_9 设设 x x,y y,z z,t t 均为均为 intint 型变量,则执行以下语句型变量,则执行以下语句 x=y=z=1;t=+x|+yx=y=z=1;t=+x|+y 后,后
15、, x x、y y、z z、t t 的值分别为的值分别为 2 2,1 1,1 1,1 1。 6、条件运算符 表达式 1?表达式 2:表达式 3 注意: 结合性是自右向左结合性是自右向左。ab?a:cd?c:d 相当于 ab?a:(cd?c:d) 条件运算符的优先级别高于赋值运算符,低于关系运算符和算术运算符条件运算符的优先级别高于赋值运算符,低于关系运算符和算术运算符。如: ab?a-b:b-a 相当于 ab?(a-b):(b-a) 练习练习 2_102_10 设有变量说明:设有变量说明:intint x=3x=3,y=5y=5;那么表达式:;那么表达式:z=xy?x:yz=xy?x:y 运算
16、后,运算后,z z 的值是的值是 5 5。 7、位运算符 位运算符是对其操作数按其二进制形式逐位进行运算,参加位运算的操作数必须为整数。 练习练习 2_112_11 intint a=5,b=6;aa|b=7;ab=3;b=-7;b2=1a=5,b=6;aa|b=7;ab=3;b=-7;b2=1。 注:在位运算中,操作数左移三位,其结果相当于操作数乘以注:在位运算中,操作数左移三位,其结果相当于操作数乘以 8。 8、逗号运算符 表达式, 表达式, , 表达式 n 注意: 自左至右,依次计算各表达式的值, “表达式 n” 的值即为整个逗号表达式的值。如:a = 3 * 5, a * 4, a +
17、 5 的值为 20。 四、运算符的优先级与结合性 1、所谓结合性是指,当一个操作数两侧的运算符具有相同的优先级时,该操作数是先与左边 的运算符结合,还是先与右边的运算符结合。 自左至右的结合方向,称为左结合性。反之,称为右结合性。 结合性是语言的独有概念。除单目运算符、赋值运算符和条件运算符是右结合性外,其它运 算符都是左结合性。 2、表达式求值 按运算符的优先级高低次序执行。例如,先乘除后加减。 如果在一个运算对象(或称操作数)两侧的运算符的优先级相同,则按语言规定的结合 方向(结合性)进行。 例如,算术运算符的结合方向是算术运算符的结合方向是“自左至右自左至右” ,即:在执行“a b +
18、c”时,变量 b 先与减 号结合,执行“a - b” ;然后再执行加 c 的运算。 练习 2_12 设 int x=2,y=3,z=4; 执行语句行 x+;y+=1;z=x+y-以后,x,y 和 z 的值分别是 多少? 答案:3,3,7 练习练习 2_132_13 若有定义若有定义 intint m=2;m=2;则逻辑表达式则逻辑表达式(m=3)后,后,n 的值为的值为 2。练习练习 2_16 如果如果 a=5,b=3,c=7,d=9,则条件表达式则条件表达式 am,正常输出;3.69 3.23.2,根据定义和数据,根据定义和数据 的输入方式,输入函数语句的正确形式为的输入方式,输入函数语句的
19、正确形式为 scanf(“%lf%lf“,n = m+ -1;printf(“%d %dn“, m ,n); 输出结果是输出结果是 3,1。第四章第四章 选择结构程序设计选择结构程序设计一、算法 1 1、算法的概念:算法是指、算法的概念:算法是指为解决一个问题而采取的确定的、有限的方法和步骤。为解决一个问题而采取的确定的、有限的方法和步骤。 2、算法的描述方法最常用的有算法的描述方法最常用的有自然语言、流程图、自然语言、流程图、N-S 流程图、流程图、PAD 图和伪代码等。图和伪代码等。 二、顺序结构程序设计 顺序结构是结构化程序设计中最简单、最常见的一种程序结构。顺序结构中的语句是按照书写
20、的先后次序执行的,并且每个语句都会被执行到。 练习 4_1 编写一个程序,从键盘上输入一个学生 5 门课的成绩,计算出该学生的总成绩和平 均成绩,并用自然语言描述算法。 解:设变量 a、b、c、d、e 分别表示学生 5 门课的成绩,sum 表示总成绩,aver 表示平均成 绩, 则用自然语言描述算法如下: 输入学生 5 门课的成绩 a、b、c、d、e; 求总成绩 sum=a+b+c+d+e; 求平均成绩: aver =sum/5.0; 输出总成绩和平均成绩。 程序如下: #include main() float a,b,c,d,e,sum,aver; printf(“请输入学生 5 门课的成
21、绩n“);scanf(“%f,%f,%f,%f,%f“, sum=a+b+c+d+e; aver=sum/5.0; printf(“总成绩=%0.2f,平均成绩=%.2fn“,sum,aver); 练习练习 4_24_2 编写一个程序,从键盘输入梯形的上底、下底和高的值(浮点数)编写一个程序,从键盘输入梯形的上底、下底和高的值(浮点数) ,计算并输出其,计算并输出其 面积(保留两位小数)面积(保留两位小数) ,并用,并用 N-SN-S 结构图表示算法。结构图表示算法。 解:设变量 a、b、h、area 分别表示梯形的上底、下底、高和面积,则用 N-S 结构图表示算法 如下:程序如下: #inc
22、lude main() float a,b,h,area; printf(“请输入梯形的上底、下底和高n“); scanf(“%f,%f,%f“,area=(a+b)*h/2.0; printf(“梯形的面积为%0.2fn“,area); 练习练习 4_34_3 编写一个程序,从键盘输入圆的半径,计算并输出圆的周长和面积(保留两位小数)编写一个程序,从键盘输入圆的半径,计算并输出圆的周长和面积(保留两位小数) ,用伪代码表示出算法。,用伪代码表示出算法。 解:设用变量 r 、length、area 分别表示圆的半径、周长和面积,则用伪代码表示算法如下:BEGINinput rlength=2*
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言 复习计划 提纲 记要
限制150内