C语言程序设计谭浩强(第四版~)期末预习复习重点.doc
《C语言程序设计谭浩强(第四版~)期末预习复习重点.doc》由会员分享,可在线阅读,更多相关《C语言程序设计谭浩强(第四版~)期末预习复习重点.doc(37页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、|第 1 章 程序设计和 C 语言1.1.什么是计算机程序程序:一组计算机能识别和执行的指令。只要让计算机执行这个程序,计算机就会自动地、有条不紊地进行工作计算机的一切操作都是由程序控制的,离开程序,计算机将一事无成。1.2 什么是计算机语言计算机语言:人和计算机交流信息的、计算机和人都能识别的语言。计算机语言发展阶段:机器语言(由 0 和 1 组成的指令)符号语言(用英文字母和数字表示指令)高级语言(接近于人的自然语言和数学语言)面向过程的语言(非结构化的语言、结构化语言) ;面向对象的语言1.3C 语言的发展及其特点C 语言是一种用途广泛、功能强大、使用灵活的过程性编程语言,既可用于编写应
2、用软件,又能用于编写系统软件。因此 C 语言问世以后得到迅速推广。C 语言主要特点:语言简洁、紧凑,使用方便、灵活。 (只有 37 个关键字、9 种控制语句;程序书写形式自由,源程序短)运算符丰富。 (34 种运算符;把括号、赋值、强制类型转换等都作为运算符处理;表达式类型多样化)数据类型丰富。 (包括:整型、浮点型、字符型、数组类型、指针类型、结构体类型、共用体类型;C99 又扩充了复数浮点类型、超长整型、布尔类型;指针类型数据,能用来实现各种复杂的数据结构的运算。 )具有结构化的控制语句。 (如 ifelse 语句、while 语句、 dowhile 语句、switch 语句、for 语句
3、用函数作为程序的模块单位,便于实现程序的模块化;C 语言是完全模块化和结构化的语言)语法限制不太严格,程序设计自由度大。 (对数组下标越界不做检查;对变量的类型使用比较灵活,例如,整型量与字符型数据可以通用;C 语言允许程序编写者有较大的自由度,因此放宽了语法检查)允许直接访问物理地址,能进行位操作,可以直接对硬件进行操作。 (C 语言具有高级语言的功能和低级语言的许多功能,可用来编写系统软件;这种双重性,使它既是成功的系统描述语言,又是通用的程序设计语言)用 C 语言编写的程序可移植性好。 (C 的编译系统简洁,很容易移植到新系统;在新系统上运行时,可直接编译“标准链接库”中的大部分功能,不
4、需要修改源代码;几乎所有计算机系统都可以使用 C 语言)生成目标代码质量高,程序执行效率高。1.4.1 最简单的 C 语言程序举例C 语言允许用两种注释方式:/:单行注释,可单独占一行,可出现在一行中其他内容的右侧。/*/:块式注释,可包含多行。1.4.2 C 语言程序的结构C 语言程序的结构特点:1、一个程序由一个或多个源程序文件组成(小程序往往只包括一个源程序文件,一个源程序文件中可以包括三个部分:预处理指令、全局声明、函数定义。 )2、函数是 C 程序的主要组成部分 (一个 C 程序是由一个或多个函数组成的;必须包含一个 main 函数(只能有一个) ;每个函数都用来实现一个或几个特定功
5、能;被调用的函数可以是库函数,也可以是自己编制设计的函数。)3、一个函数包括两个部分(函数首部、函数体(声明部分、执行部分) )4、程序总是从 main 函数开始执行5、C 程序对计算机的操作由 C 语句完成(C 程序书写格式是比较自由的:一行内可以写几个语句;一个语句可以分写在多行上。 )6、数据声明和语句最后必须有分号 7、C 语言本身不提供输入输出语句 8、程序应当包含注释,增加可读|性 1.6 程序设计的任务 1.问题分析 2.设计算法 3.编写程序 4.对源程序进行编辑、编译和连接 5.运行程序,分析结 6.编写程序文档第 2 章 算法程序的灵魂一个程序主要包括以下两方面的信息:(1
6、) 对数据的描述。在程序中要指定用到哪些数据以及这些数据的类型和数据的组织形式,这就是数据结构。(2) 对操作的描述。即要求计算机进行操作的步骤,也就是算法。数据是操作的对象,操作的目的是对数据进行加工处理,以得到期望的结果。著名计算机科学家沃思(Nikiklaus Wirth) 提出一个公式:算法 + 数据结构 = 程序一个程序除了算法和数据结构这主要要素外,还应当采用结构化程序设计方法进行程序设计,并且用某一种计算机语言表示。算法 、 数据结构 、 程序设计方法 和 语言工具 是一个程序设计人员应具备的知识。2.1 什么是算法广义地说,为解决一个问题而采取的方法和步骤,就称为“算法” 。计
7、算机算法可分为两大类别:数值运算算法(目的是求数值解) ;非数值运算算法(包括面十分广泛,常见的是用于事务管理领域)2.3 算法的特性一个有效算法应该具有以下特点:(1) 有穷性。一个算法应包含有限的操作步骤,而不能是无限的。(2) 确定性。算法中的每一个步骤都应当是确定的,而不应当是含糊的、模棱两可的。(3) 有零个或多个输入。所谓输入是指在执行算法时需要从外界取得必要的信息。(4) 有一个或多个输出。算法的目的是为了求解, “解” 就是输出。没有输出的算法是没有意义的。(5) 有效性。算法中的每一个步骤都应当能有效地执行,并得到确定的结果。流程图是表示算法的较好的工具。2.4.3 三种基本
8、结构和改进的流程图三种基本结构:(1)顺序结构 (2)选择结构 (3)循环结构 当型循环结构 直到型循环结构2.4.5 用伪代码表示算法伪代码是用介于自然语言和计算机语言之间的文字和符号来描述算法。用伪代码写算法并无固定的、严格的语法规则,可以用英文,也可以中英文混用。2.4.6 用计算机语言表示算法要完成一项工作,包括设计算法和实现算法两个部分。设计算法的目的是为了实现算法。例 2.19 将例 2.17 表示的算法(求多项式 的值)用 C 语言表示。#include int main( ) int sign=1;double deno = 2.0,sum = 1.0, term; while
9、 (deno int main ( )float f,c; 定义 f 和 c 为单精度浮点型变量f=64.0; 指定 f 的值c=(5.0/9)*(f-32); 计算 c 的值printf(“f=%fnc=%fn“,f,c); 输出 f 和 c 的值 return 0;例 3.2 计算存款利息。有 1000 元,想存一年。有三种方法可选: (1)活期,年利率为 r1 (2)一年期定期,年利率为 r2 (3)存两次半年定期,年利率为 r3,请分别计算出一年后按三种方法所得到的本息和。解题思路:确定计算本息和的公式。从数学知识可知:若存款额为 p0,则:活期存款一年后本息和为:p1=p0(1+r1
10、);一年期定期存款,一年后本息和为:p2=p0(1+r2) ;两次半年定期存款,一年后本息和为:p3=p0(1+r3/2 ) (1+r3/2 )算法:#include int main ( )float p0=1000, r1=0.0036,r2=0.0225,r3=0.0198, p1, p2, p3; p1 = p0 * (1 + r1); p2 = p0 * (1 + r2); p3 = p0 * (1 + r3/2) * (1 + r3/2); printf(”%fn%fn%fn”,p1, p2, p3); return 0;)32(95fc)2(95c|3.2.1 常量与变量1.常量
11、:在程序运行过程中,其值不能被改变的量。整型常量:如 1000,12345,0,-345;实型常量:十进制小数形式:如 0.34 -56.79 0.0,指数形式:如 12.34e3 (代表 12.34 103);字符常量:如? ,转义字符:如n ;字符串常量:如”boy” ;符号常量:#define PI 3.14162.变量:在程序运行期间,变量的值是可以改变的。变量必须先定义,后使用,定义变量时指定该变量的名字和类型。变量名和变量值是两个不同的概念,变量名实际上是以一个名字代表的一个存储地址。从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据。3.常变量:const
12、 int a=3;4.标识符:一个对象的名字。语言规定标识符只能由字母、数字和下划线 3 种字符组成,且第一个字符必须为字母或下划线合法的标识符:如 sum,average, _total, Class, day, BASIC, li_ling不合法的标识符:M.D.John ,¥123,33,3D64 ,ab3.2.2 数据类型所谓类型,就是对数据分配存储单元的安排,包括存储单元的长度(占多少字节) 以及数据的存储形式。不同的类型分配不同的长度和存储形式。C 语言允许使用的数据类型:整型类型:基本整型(int 型) :占 2 个或 4 个字节短整型(short int) :VC+6.0 中占
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 谭浩强 第四 期末 预习 复习 重点
限制150内