1、C语言谭浩语言谭浩强完整课件强完整课件2022-12-201.1 什么是计算机程序1.2 什么是计算机语言1.3 C语言的发展及其特点1.4 最简单的C语言程序1.5 运行C程序的步骤与方法1.6 程序设计的任务2022-12-201.1 什么是计算机程序什么是计算机程序程序:一组计算机能识别和执行的指令只要让计算机执行这个程序,计算机就会自动地、有条不紊地进行工作计算机的一切操作都是由程序控制的,离开程序,计算机将一事无成2022-12-201.2 什么是计算机语言什么是计算机语言 计算机语言:人和计算机交流信息的、计算机和人都能识别的语言2022-12-201.2 什么是计算机语言什么是计
2、算机语言 计算机语言发展阶段:机器语言(由0和1组成的指令)符号语言(用英文字母和数字表示指令)高级语言(接近于人的自然语言和数学语言)面向过程的语言 (非结构化的语言、结构化语言)面向对象的语言低级语言2022-12-201.3 C语言的发展及其特点语言的发展及其特点C语言是国际上广泛流行的计算机高级语言。C语言的发展:BCPL语言B语言C语言精练、接近硬件,但过于简单,无数据类型具有多种数据类型2022-12-201.3 C语言的发展及其特点语言的发展及其特点 最初的C语言只是为描述和实现UNIX操作系统提供一种工作语言而设计的。2022-12-201.3 C语言的发展及其特点语言的发展及
3、其特点 1983年,美国国家标准协会(ANSI)成立了一个委员会,根据C语言问世以来各种版本对C语言的发展和扩充,制定了第一个C语言标准草案(83 ANSI C)。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 1989年,ANSI公布了一个完整的C语言标准ANSI X3.159-1989(常称ANSI C,或C89)。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 1990年,国际标准化组织ISO(International Standard Organization)接受C89作为国际标准ISO/IEC 9899:1990,它和ANSI的C89基本上
4、是相同的。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 1995年,ISO对C90作了一些修订,1999年,ISO又对C语言标准进行修订,在基本保留原来的C语言特征的基础上,针对应用的需要,增加了一些功能,尤其是C+中的一些功能,命名为ISO/IEC 9899:1999。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 2001、2004年先后进行了两次技术修正(TC1和TC2)。ISO/IEC 9899:1999(及其技术修正)被称为 C99。C99是C89(及1995基准增补1)的扩充。2022-12-201.3 C语言的发展及其特点语言的发展及其特
5、点 本书的叙述以C99标准为依据(对C99新增加的功能作特别的说明)。目前不同软件公司提供的各C语言编译系统多数并未完全实现C99建议的功能 本书中程序基本上都可以在目前所用的编译系统(如VC+6.0,Turbo C+3.0,GCC)上编译和运行。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言是一种用途广泛、功能强大、使用灵活的过程性(procedural)编程语言,既可用于编写应用软件,又能用于编写系统软件。因此C语言问世以后得到迅速推广。2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:语言简洁、紧凑,使用方便、灵活。只有37个
6、关键字、9种控制语句 程序书写形式自由,源程序短2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:运算符丰富。有34种运算符 把括号、赋值、强制类型转换等都作为运算符处理 表达式类型多样化2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:数据类型丰富。包括:整型、浮点型、字符型、数组类型、指针类型、结构体类型、共用体类型 C99又扩充了复数浮点类型、超长整型(long long)、布尔类型(bool)指针类型数据,能用来实现各种复杂的数据结构(如链表、树、栈等)的运算。2022-12-201.3 C语言的发展及其特点语言的发展
7、及其特点 C语言主要特点:具有结构化的控制语句 如ifelse语句、while语句、dowhile语句、switch语句、for语句 用函数作为程序的模块单位,便于实现程序的模块化 C语言是完全模块化和结构化的语言2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:允许直接访问物理地址,能进行位操作,可以直接对硬件进行操作 C语言具有高级语言的功能和低级语言的许多功能,可用来编写系统软件 这种双重性,使它既是成功的系统描述语言,又是通用的程序设计语言2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:用C语言编写的程序可移植性好。
8、C的编译系统简洁,很容易移植到新系统 在新系统上运行时,可直接编译“标准链接库”中的大部分功能,不需要修改源代码 几乎所有计算机系统都可以使用C语言2022-12-201.3 C语言的发展及其特点语言的发展及其特点 C语言主要特点:生成目标代码质量高,程序执行效率高。2022-12-201.4最简单的最简单的C语言程序语言程序1.4.1 最简单的C语言程序举例1.4.2 C语言程序的结构2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例例1.1 要求在屏幕上输出以下一行信息。This is a C program.解题思路:在主函数中用printf函数原样输出以上文字。
9、2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;函数的名字,表示主函数C程序必须有一个 main 函数2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;主函数类型2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a
10、C program.n”);return 0;函数体2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;输出函数输出语句2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;输出语句2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This
11、 is a C program.n”);return 0;换行符2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;当main函数执行结束前将整数0作为函数值2022-12-201.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;表示语句结束用到函数库中的输入输出函数时2022-12-201.4.1 最简单的最简单的C语言程序举语言程
12、序举例例C语言允许用两种注释方式:/:单行注释 可单独占一行 可出现在一行中其他内容的右侧/*/:块式注释 可包含多行2022-12-20例1.2 求两个整数之和。解题思路:解题思路:u设置设置3个变量个变量ua和和b用来存放两个整数用来存放两个整数usum用来存放和数用来存放和数u用赋值运算符用赋值运算符“=”把结果传送给把结果传送给sum2022-12-20#include int main()int a,b,sum;a=123;b=456;sum=a+b;printf(”sum is%dn”,sum);return 0;定义整型变量a,b,sum对变量a,b赋值将a与b的和赋给sum20
13、22-12-20#include int main()int a,b,sum;a=123;b=456;sum=a+b;printf(”sum is%dn”,sum);return 0;用sum的值替代希望输出的字符2022-12-20例1.3求两个整数中的较大者。解题思路:u用一个函数实现求两个整数中的较大者u在主函数中调用此函数并输出结果2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(in
14、t x,int y)int z;if(x y)z=x;else z=y;return(z);主函数max函数2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);将x和y中较大者值返回给主函数2022-12-20#include int main()int max(int x,int y);int a,
15、b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);因max函数
16、的定义在main函数之后,需声明2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);输入函数2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%d
17、n,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);输入语句2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);输入的数据放到a,b中输入格式a的地址2022-12-20#include int main()int
18、 max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);调用max函数2022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x
19、y)z=x;else z=y;return(z);85882022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);85882022-12-20#include int main()int max(int x,int y);int a,b,c;scanf(”%d,%d”,&a,&b);c=max(a,b);
20、printf(max=%dn,c);return 0;int max(int x,int y)int z;if(x y)z=x;else z=y;return(z);实际参数形式参数2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:1.一个程序由一个或多个源程序文件组成 小程序往往只包括一个源程序文件 例1.1,例1.2只有一个函数 例1.3有两个函数只包括一个源程序文件2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:一个源程序文件中可以包括三个部分:预处理指令 全局声明 函数定义#include 等在函数之外进行的数据声明
21、每个函数用来实现一定的功能2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:2.函数是C程序的主要组成部分 一个C程序是由一个或多个函数组成的 必须包含一个main函数(只能有一个)每个函数都用来实现一个或几个特定功能 被调用的函数可以是库函数,也可以是自己编制设计的函数2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数首部int max (int x,int y)函数的第1行函数类型函数名参数类型参数名2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函
22、数包括两个部分:函数首部int max (int x,int y)若函数无参,在括弧中写void或空括弧int main(void)或 int main()2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数体 声明部分定义在本函数中所用到的变量对本函数所调用函数进行声明 执行部分:由若干个语句组成,指定在函数中所进行的操作可以没有声明部分2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数体void dump()可以是空函数2022-12-201.4.2 C语言程序的结
23、构语言程序的结构C语言程序的结构特点:4.程序总是从main函数开始执行5.C程序对计算机的操作由C语句完成 C程序书写格式是比较自由的 一行内可以写几个语句 一个语句可以分写在多行上 为清晰起见,习惯上每行只写一个语句2022-12-201.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:4.程序总是从main函数开始执行5.C程序对计算机的操作由C语句完成6.数据声明和语句最后必须有分号7.C语言本身不提供输入输出语句8.程序应当包含注释,增加可读性2022-12-201.5 运行运行C程序的步骤与方法程序的步骤与方法1.上机输入和编辑源程序(.c文件)2.对源程序进行编译(.
24、obj文件)3.进行连接处理(.exe文件)4.运行可执行程序,得到运行结果说明:以上过程参见教材中图1.1 附录A中有Visual C+6.0中编辑、编译、连接和运行C程序的方法2022-12-201.6 程序设计的任务程序设计的任务1.问题分析 对于接手的任务要进行认真的分析 研究所给定的条件 分析最后应达到的目标 找出解决问题的规律 选择解题的方法2022-12-201.6 程序设计的任务程序设计的任务1.问题分析2.设计算法 设计出解题的方法和具体步骤2022-12-201.6 程序设计的任务程序设计的任务1.问题分析2.设计算法3.编写程序4.对源程序进行编辑、编译和连接5.运行程序
25、,分析结果 结果错了,程序肯定错 结果对了,程序未必对2022-12-201.6 程序设计的任务程序设计的任务1.问题分析2.设计算法3.编写程序4.对源程序进行编辑、编译和连接5.运行程序,分析结果6.编写程序文档2022-12-202022-12-20 一个程序主要包括以下两方面的信息:(1)对数据的描述。在程序中要指定用到哪些数据以及这些数据的类型和数据的组织形式 这就是数据结构(data structure)(2)对操作的描述。即要求计算机进行操作的步骤 也就是算法(algorithm)2022-12-20 数据是操作的对象 操作的目的是对数据进行加工处理,以得到期望的结果 著名计算机
26、科学家沃思(Nikiklaus Wirth)提出一个公式:算法+数据结构=程序2022-12-20 一个程序除了算法和数据结构这主要要素外,还应当采用结构化程序设计方法进行程序设计,并且用某一种计算机语言表示 算法、数据结构、程序设计方法和语言工具是一个程序设计人员应具备的知识2022-12-20 算法是解决“做什么”和“怎么做”的问题 程序中的操作语句,是算法的体现 不了解算法就谈不上程序设计2022-12-202.1 什么是算法2.2 简单的算法举例2.3 算法的特性2.4 怎样表示一个算法2.5 结构化程序设计方法2022-12-20 广义地说,为解决一个问题而采取的方法和步骤,就称为“
27、算法”对同一个问题,可以有不同的解题方法和步骤 为了有效地进行解题,不仅需要保证算法正确,还要考虑算法的质量,选择合适的算法2022-12-20 计算机算法可分为两大类别:数值运算算法非数值运算算法 数值运算的目的是求数值解 非数值运算包括的面十分广泛,最常见的是用于事务管理领域2022-12-20例2.1 求12345 可以用最原始的方法进行:步骤1:先求1*2,得到结果2。步骤2:将步骤1得到的乘积2再乘以3,得到结果6。步骤3:将6再乘以4,得24。步骤4:将24再乘以5,得120。这就是最后的结果。例2.1 求12345 1000太繁琐2022-12-20 改进的算法:设变量p为被乘数
28、 变量i为乘数 用循环算法求结果2022-12-20S1:使p=1,或写成1pS2:使i=2,或写成2iS3:使p与i相乘,乘积仍放在变量p中,可表示为:p*ipS4:使i的值加1,即i+1 iS5:如果i不大于5,返回重新执行S3;否则,算法结束最后得到p的值就是 5!的值若是1000,求什么?2022-12-20S1:使p=1,或写成1pS2:使i=2,或写成2iS3:使p与i相乘,乘积仍放在变量p中,可表示为:p*ipS4:使i的值加1,即i+1 iS5:如果i不大于5,返回重新执行S3;否则,算法结束最后得到p的值就是 5!的值若求135791133221111相当于i 112022-
29、12-20 例2.2 有50个学生,要求将成绩在80分以上的学生的学号和成绩输出。用ni代表第i个学生学号,gi表示第i个学生成绩S1:1iS2:如果gi80,则输出ni和gi,否则不输出S3:i+1iS4:如果i50,返回到步骤S2,继续执行,否则,算法结束2022-12-20 例2.3 判定20002500年中的每一年是否闰年,并将结果输出。闰年的条件:(1)能被4整除,但不能被100整除的年份都是闰年,如2008、2012、2048年(2)能被400整除的年份是闰年,如2000年 不符合这两个条件的年份不是闰年 例如2009、2100年2022-12-20year不能被4整除非闰年yea
30、r被4整除,但不能被100整除闰年year被100整除,又能被400整除闰年其他非闰年逐渐缩小判断的范围2022-12-20例2.4 求 规律:第1项的分子分母都是1 第2项的分母是2,以后每一项的分母子都是前一项的分母加1 笫2项前的运算符为“-”,后一项前面的运算符都与前一项前的运算符相反100199141312112022-12-20例2.4 求S1:sign=1S2:sum=1S3:deno=2S4:sign=(-1)*signS5:term=sign*(1/deno)S6:sum=sum+termS7:deno=deno+1S8:若deno100返回S4;否则算法结束10019914
31、131211sign当前项符号term当前项的值sum当前各项的和deno当前项分母-1-1/21-1/23满足,返回S42022-12-20例2.4 求S1:sign=1S2:sum=1S3:deno=2S4:sign=(-1)*signS5:term=sign*(1/deno)S6:sum=sum+termS7:deno=deno+1S8:若deno100返回S4;否则算法结束10019914131211sign当前项符号term当前项的值sum当前各项的和deno当前项分母11/31-1/2+1/34满足,返回S42022-12-20例2.4 求S1:sign=1S2:sum=1S3:d
32、eno=2S4:sign=(-1)*signS5:term=sign*(1/deno)S6:sum=sum+termS7:deno=deno+1S8:若deno100返回S4;否则算法结束1001991413121199次循环后sum的值就是所要求的结果2022-12-20 例2.5 给出一个大于或等于3的正整数,判断它是不是一个素数。所谓素数(prime),是指除了1和该数本身之外,不能被其他任何整数整除的数 例如,13是素数,因为它不能被2,3,4,12整除。2022-12-20 判断一个数n(n3)是否素数:将n作为被除数,将2到(n-1)各个整数先后作为除数,如果都不能被整除,则n为素
33、数S1:输入n的值S2:i=2 (i作为除数)S3:n被i除,得余数rS4:如果r=0,表示n能被i整除,则输出n“不是素数”,算法结束;否则执行S5S5:i+1iS6:如果in-1,返回S3;否则输出n“是素数”,然后结束。可改为n/2n2022-12-20 一个有效算法应该具有以下特点:(1)有穷性。一个算法应包含有限的操作步骤,而不能是无限的。(2)确定性。算法中的每一个步骤都应当是确定的,而不应当是含糊的、模棱两可的。2022-12-20 一个有效算法应该具有以下特点:(3)有零个或多个输入。所谓输入是指在执行算法时需要从外界取得必要的信息。(4)有一个或多个输出。算法的目的是为了求解
34、,“解”就是输出。没有输出的算法是没有意义的。(5)有效性。算法中的每一个步骤都应当能有效地执行,并得到确定的结果。2022-12-20 对于一般最终用户来说:他们并不需要在处理每一个问题时都要自己设计算法和编写程序 可以使用别人已设计好的现成算法和程序 只需根据已知算法的要求给予必要的输入,就能得到输出的结果输入3个数黑箱子3个数中最大数求3个数的最大数2022-12-20 常用的方法有:自然语言 传统流程图 结构化流程图 伪代码 2022-12-202.4.1 用自然语言表示算法2.4.2 用流程图表示算法2.4.3 三种基本结构和改进的流程图2.4.4 用N-S流程图表示算法2.4.5
35、用伪代码表示算法2.4.6 用计算机语言表示算法2022-12-20 2.2节介绍的算法是用自然语言表示的 用自然语言表示通俗易懂,但文字冗长,容易出现歧义性 用自然语言描述包含分支和循环的算法,不很方便 除了很简单的问题外,一般不用自然语言2022-12-20 流程图是用一些图框来表示各种操作 用图形表示算法,直观形象,易于理解起止框输入输出框处理框判断框流程线连接点注释框x0YN一个入口两个出口2022-12-20 流程图是用一些图框来表示各种操作 用图形表示算法,直观形象,易于理解起止框输入输出框处理框判断框流程线连接点注释框位置不够防止交叉2022-12-20 例2.6 将例2.1的算
36、法用流程图表示。求12345 如果需要将最后结果输出:1ti5开始2it*iti+1i结束NY2022-12-20 例2.6 将例2.1的算法用流程图表示。求12345 如果需要将最后结果输出:1t输出ti5开始2it*iti+1i结束NY2022-12-20 例2.7 例2.2的算法用流程图表示。有50个学生,要求将成绩在80分以上的学生的学号和成绩输出。2022-12-201ii50开始i+1i结束NY输入ni、gi1i开始gi80输出ni、gii+1ii50NYYN如果包括输入数据部分2022-12-201ii50开始i+1i结束NY输入ni、gi1igi80输出ni、gii+1ii50
37、NYYN如果包括输入数据部分2022-12-20 例2.8 例2.3判定闰年的算法用流程图表示。判定20002500年中的每一年是否闰年,将结果输出。2022-12-20NYN开始2000yearyear不能被4整除year是闰年year不能被100整除year+1yearyear2500结束Yyear不能被400整除year不是闰年year是闰年year不是闰年YNYN2022-12-20例2.9 将例2.4的算法用流程图表示。求100199141312112022-12-201sum2deno1sign(-1)*signsignsign*(1/deno)termsum+termsumden
38、o+1denoNdeno100Y输出sum结束开始2022-12-20 例2.10 例2.5判断素数的算法用流程图表示。对一个大于或等于3的正整数,判断它是不是一个素数。2022-12-20NY输出n是素数结束开始输入n2in%irr=0i+1iin输出n是素数YN2022-12-20 通过以上几个例子可以看出流程图是表示算法的较好的工具 一个流程图包括以下几部分:(1)表示相应操作的框(2)带箭头的流程线(3)框内外必要的文字说明 流程线不要忘记画箭头,否则难以判定各框的执行次序2022-12-201.传统流程图的弊端 传统的流程图用流程线指出各框的执行顺序,对流程线的使用没有严格限制 使用
39、者可以毫不受限制地使流程随意地转来转去,使人难以理解算法的逻辑2022-12-202.三种基本结构(1)顺序结构AB2022-12-202.三种基本结构(2)选择结构ABYpNAYpN2022-12-202.三种基本结构(3)循环结构 当型循环结构AYp1NYx51t输出t2it*iti+1i2022-12-20 例2.12 将例2.2的算法用N-S图表示。将50名学生中成绩高于80分者的学号和成绩输出。直到i501t1ii+1i输入ni、gii+1i直到i50gi80否是输出ni,gi2022-12-20例2.13 将例2.3判定闰年的算法用N-S图表示直到year25002000yeary
40、ear+1year否是year%4为0否是输出year非闰年year%100不为0year%400为0是否输出year非闰年输出year闰年输出year闰年2022-12-20例2.14 将例2.4的算法用N-S图表示。求10019914131211直到deno100deno+1deno输出sum1sum1sign2deno(-1)*signsignsign*(1/deno)termsum+termsum2022-12-20 例2.15 将例2.5判别素数的算法用N-S流程图表示。例2.10的流程图不是由三种基本结构组成的 循环有两个出口,不符合基本结构的特点 无法直接用N-S流程图的三种基本
41、结构的符号来表示 先作必要的变换2022-12-20NY开始输入n0w 2in%irr=0i+1ii 和w=0nYN1w输出n是素数结束w=0输出n不是素数2022-12-20输入nr=0是否0w2in%ir1wi+1i直到i 或w 0nw=0是否输出n是素数输出n不是素数2022-12-20 一个结构化的算法是由一些基本结构顺序组成的 在基本结构之间不存在向前或向后的跳转,流程的转移只存在于一个基本结构范围之内 一个非结构化的算法可以用一个等价的结构化算法代替,其功能不变 如果一个算法不能分解为若干个基本结构,则它必然不是一个结构化的算法2022-12-20 伪代码是用介于自然语言和计算机语
42、言之间的文字和符号来描述算法 用伪代码写算法并无固定的、严格的语法规则,可以用英文,也可以中英文混用2022-12-20例2.16 求5!。begin (算法开始)1 t 2 i while i5 t*i t i+1 i print tend (算法结束)2022-12-20例2.17 求begin 1 sum 2 deno 1 sign while deno 100 (-1)*sign sign sign*1/deno term sum+term sum deno+1 deno print sumend100199141312112022-12-20 要完成一项工作,包括设计算法和实现算法两
43、个部分。设计算法的目的是为了实现算法。不仅要考虑如何设计一个算法,也要考虑如何实现一个算法。2022-12-20 例2.18 将例2.16表示的算法(求5!)用C语言表示。2022-12-20#include int main()int i,t;t=1;i=2;while(i=5)t=t*i;i=i+1;printf(%dn,t);return 0;2022-12-20例2.19 将例2.17表示的算法(求多项式 的值)用C语言表示。100199141312112022-12-20#include int main()int sign=1;double deno=2.0,sum=1.0,ter
44、m;while(deno=100)sign=-sign;term=sign/deno;sum=sum+term;deno=deno+1;printf(%fn,sum);return 0;2022-12-20 结构化程序设计强调程序设计风格和程序结构的规范化,提倡清晰的结构。结构化程序设计方法的基本思路是:把一个复杂问题的求解过程分阶段进行,每个阶段处理的问题都控制在人们容易理解和处理的范围内。2022-12-20 采取以下方法保证得到结构化的程序:(1)自顶向下;(2)逐步细化;(3)模块化设计;(4)结构化编码。2022-12-203.1 顺序程序设计举例3.2 数据的表现形式及其运算3.3
45、 C语句3.4 数据的输入输出2022-12-203.1顺序程序设计举例顺序程序设计举例 例3.1 有人用温度计测量出用华氏法表示的温度(如 F,今要求把它转换为以摄氏法表示的温度(如 C)。解题思路:找到二者间的转换公式)32(95fcf代表华氏温度,c代表摄氏温度2022-12-203.1顺序程序设计举例顺序程序设计举例算法:输入f的值输出c的值)32(95fc 例3.1 有人用温度计测量出用华氏法表示的温度(如 F,今要求把它转换为以摄氏法表示的温度(如 C)。N-S图2022-12-203.1顺序程序设计举例顺序程序设计举例)32(95f#include int main()float
46、 f,c;f=64.0;c=(5.0/9)*(f-32);printf(f=%fnc=%fn,f,c);return 0;定义f和c为单精度浮点型变量指定f的值计算c的值输出f和c的值2022-12-203.1顺序程序设计举例顺序程序设计举例 例3.2 计算存款利息。有1000元,想存一年。有三种方法可选:(1)活期,年利率为r1 (2)一年期定期,年利率为r2 (3)存两次半年定期,年利率为r3 请分别计算出一年后按三种方法所得到的本息和。2022-12-203.1顺序程序设计举例顺序程序设计举例 解题思路:确定计算本息和的公式。从数学知识可知:若存款额为p0,则:活期存款一年后本息和为:p
47、1=p0(1+r1)一年期定期存款,一年后本息和为:p2=p0(1+r2)两次半年定期存款,一年后本息和为:)23+)(123+p0(1=p3rr2022-12-203.1顺序程序设计举例顺序程序设计举例 算法:输入输入p0,r1,r2,r3的值的值计算计算p1=p0(1+r1)计算计算p2=p0(1+r2)计算计算p3=p0(1+)(1+)输出输出p1,p2,p323r23r2022-12-203.1顺序程序设计举例顺序程序设计举例#include int main()float p0=1000,r1=0.0036,r2=0.0225,r3=0.0198,p1,p2,p3;p1=p0*(1+
48、r1);p2=p0*(1+r2);p3=p0*(1+r3/2)*(1+r3/2);printf(”%fn%fn%fn”,p1,p2,p3);return 0;定义变量同时赋予初值2022-12-203.2 数据的表现形式及其运算数据的表现形式及其运算3.2.1 常量和变量3.2.2 数据类型3.2.3 整型数据3.2.4 字符型数据3.2.5 浮点型数据3.2.6 怎样确定常量的类型3.2.7 运算符和表达式2022-12-203.2.1 常量和变量常量和变量1.常量:在程序运行过程中,其值不能被改变的量整型常量:如1000,12345,0,-345实型常量 十进制小数形式:如0.34 -56
49、.79 0.0 指数形式:如12.34e3(代表12.34103)字符常量:如?转义字符:如n字符串常量:如”boy”符号常量:#define PI 3.14162022-12-203.2.1 常量和变量常量和变量2.变量:在程序运行期间,变量的值是可以改变的变量必须先定义,后使用定义变量时指定该变量的名字和类型变量名和变量值是两个不同的概念变量名实际上是以一个名字代表的一个存储地址从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据2022-12-203.2.1 常量和变量常量和变量3.常变量:const int a=3;4.标识符:一个对象的名字语言规定标识符只能由字
50、母、数字和下划线3种字符组成,且第一个字符必须为字母或下划线合法的标识符:如sum,average,_total,Class,day,BASIC,li_ling不合法的标识符:M.D.John,¥123,33,3D64,ab大小写字母是不同的字符2022-12-203.2.2 数据类型数据类型 所谓类型,就是对数据分配存储单元的安排,包括存储单元的长度(占多少字节)以及数据的存储形式 不同的类型分配不同的长度和存储形式2022-12-203.2.2 数据类型数据类型C语言允许使用的数据类型:基本类型 整型类型 基本整型 短整型 长整型 双长整型 字符型 布尔型u浮点类型l单精度浮点型l双精度浮