程序设计和C语言谭浩强.pptx
1.1 什么是计算机程序什么是计算机程序程序:一组计算机能识别和执行的指令只要让计算机执行这个程序,计算机就会自动地、有条不紊地进行工作计算机的一切操作都是由程序控制的,离开程序,计算机将一事无成第1页/共61页1.2 什么是计算机语言什么是计算机语言计算机语言:人和计算机交流信息的、计算机和人都能识别的语言第2页/共61页1.2 什么是计算机语言什么是计算机语言计算机语言发展阶段:机器语言(由0和1组成的指令)符号语言(用英文字母和数字表示指令)高级语言(接近于人的自然语言和数学语言)面向过程的语言 (非结构化的语言、结构化语言)面向对象的语言低级语言第3页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言是国际上广泛流行的计算机高级语言。C语言的发展:BCPL语言B语言C语言精练、接近硬件,但过于简单,无数据类型具有多种数据类型第4页/共61页1.3 C语言的发展及其特点语言的发展及其特点最初的C语言只是为描述和实现UNIX操作系统提供一种工作语言而设计的。第5页/共61页1.3 C语言的发展及其特点语言的发展及其特点1983年,美国国家标准协会(ANSI)成立了一个委员会,根据C语言问世以来各种版本对C语言的发展和扩充,制定了第一个C语言标准草案(83 ANSI C)。第6页/共61页1.3 C语言的发展及其特点语言的发展及其特点1989年,ANSI公布了一个完整的C语言标准ANSI X3.159-1989(常称ANSI C,或C89)。第7页/共61页1.3 C语言的发展及其特点语言的发展及其特点1990年,国际标准化组织ISO(International Standard Organization)接受C89作为国际标准ISO/IEC 9899:1990,它和ANSI的C89基本上是相同的。第8页/共61页1.3 C语言的发展及其特点语言的发展及其特点1995年,ISO对C90作了一些修订,1999年,ISO又对C语言标准进行修订,在基本保留原来的C语言特征的基础上,针对应用的需要,增加了一些功能,尤其是C+中的一些功能,命名为ISO/IEC 9899:1999。第9页/共61页1.3 C语言的发展及其特点语言的发展及其特点2001、2004年先后进行了两次技术修正(TC1和TC2)。ISO/IEC 9899:1999(及其技术修正)被称为 C99。C99是C89(及1995基准增补1)的扩充。第10页/共61页1.3 C语言的发展及其特点语言的发展及其特点本书的叙述以C99标准为依据(对C99新增加的功能作特别的说明)。目前不同软件公司提供的各C语言编译系统多数并未完全实现C99建议的功能本书中程序基本上都可以在目前所用的编译系统(如VC+6.0,Turbo C+3.0,GCC)上编译和运行。第11页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言是一种用途广泛、功能强大、使用灵活的过程性(procedural)编程语言,既可用于编写应用软件,又能用于编写系统软件。因此C语言问世以后得到迅速推广。第12页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:语言简洁、紧凑,使用方便、灵活。只有37个关键字、9种控制语句程序书写形式自由,源程序短第13页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:运算符丰富。有34种运算符把括号、赋值、强制类型转换等都作为运算符处理表达式类型多样化第14页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:数据类型丰富。包括:整型、浮点型、字符型、数组类型、指针类型、结构体类型、共用体类型C99又扩充了复数浮点类型、超长整型(long long)、布尔类型(bool)指针类型数据,能用来实现各种复杂的数据结构(如链表、树、栈等)的运算。第15页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:具有结构化的控制语句如ifelse语句、while语句、dowhile语句、switch语句、for语句用函数作为程序的模块单位,便于实现程序的模块化C语言是完全模块化和结构化的语言第16页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:语法限制不太严格,程序设计自由度大。对数组下标越界不做检查对变量的类型使用比较灵活,例如,整型量与字符型数据可以通用C语言允许程序编写者有较大的自由度,因此放宽了语法检查第17页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:允许直接访问物理地址,能进行位操作,可以直接对硬件进行操作C语言具有高级语言的功能和低级语言的许多功能,可用来编写系统软件这种双重性,使它既是成功的系统描述语言,又是通用的程序设计语言第18页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:用C语言编写的程序可移植性好。C的编译系统简洁,很容易移植到新系统在新系统上运行时,可直接编译“标准链接库”中的大部分功能,不需要修改源代码几乎所有计算机系统都可以使用C语言第19页/共61页1.3 C语言的发展及其特点语言的发展及其特点C语言主要特点:生成目标代码质量高,程序执行效率高。第20页/共61页1.4最简单的最简单的C语言程序语言程序1.4.1 最简单的C语言程序举例1.4.2 C语言程序的结构第21页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例例1.1 要求在屏幕上输出以下一行信息。This is a C program.解题思路:在主函数中用printf函数原样输出以上文字。第22页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;函数的名字,表示主函数C程序必须有一个 main 函数第23页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;主函数类型第24页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;函数体第25页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;输出函数输出语句第26页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;输出语句第27页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;换行符第28页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;当main函数执行结束前将整数0作为函数值第29页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例#include int main()printf(”This is a C program.n”);return 0;表示语句结束用到函数库中的输入输出函数时第30页/共61页1.4.1 最简单的最简单的C语言程序举语言程序举例例C语言允许用两种注释方式:/:单行注释可单独占一行可出现在一行中其他内容的右侧/*/:块式注释可包含多行第31页/共61页例1.2 求两个整数之和。解题思路:u设置3个变量ua和b用来存放两个整数usum用来存放和数u用赋值运算符“=”把结果传送给sum第32页/共61页#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的的和赋给和赋给sum第33页/共61页#include int main()int a,b,sum;a=123;b=456;sum=a+b;printf(”sum is%dn”,sum);return 0;用用sum的值的值替代替代希望输出的字符希望输出的字符第34页/共61页例1.3求两个整数中的较大者。解题思路:解题思路:u用一个函数实现求两个整数中的较大者用一个函数实现求两个整数中的较大者u在主函数中调用此函数并输出结果在主函数中调用此函数并输出结果第35页/共61页#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函数第36页/共61页#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中较大者值返回给主函数第37页/共61页#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);第38页/共61页#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函数的定义函数的定义在在main函数之后函数之后,需声明,需声明第39页/共61页#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);输入函数第40页/共61页#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);输入语句第41页/共61页#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的地址第42页/共61页#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函数第43页/共61页#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);8588第44页/共61页#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);8588第45页/共61页#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);实际参数形式参数第46页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:1.一个程序由一个或多个源程序文件组成小程序往往只包括一个源程序文件例1.1,例1.2只有一个函数例1.3有两个函数只包括一个源程序文件只包括一个源程序文件第47页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:一个源程序文件中可以包括三个部分:预处理指令全局声明函数定义#include 等等在函数之外进行的数据声明在函数之外进行的数据声明每个函数用来实现一定的功能每个函数用来实现一定的功能第48页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:2.函数是C程序的主要组成部分一个C程序是由一个或多个函数组成的必须包含一个main函数(只能有一个)每个函数都用来实现一个或几个特定功能被调用的函数可以是库函数,也可以是自己编制设计的函数第49页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数首部int max (int x,int y)函数的第函数的第1行行函数类型函数名参数类型参数名第50页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数首部int max (int x,int y)若函数无参,在括弧中写void或空括弧int main(void)或或 int main()第51页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数体声明部分定义在本函数中所用到的变量对本函数所调用函数进行声明执行部分:由若干个语句组成,指定在函数中所进行的操作可以没有声明部分第52页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:3.一个函数包括两个部分:函数体void dump()可以是空函数第53页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:4.程序总是从main函数开始执行5.C程序对计算机的操作由C语句完成C程序书写格式是比较自由的一行内可以写几个语句一个语句可以分写在多行上为清晰起见,习惯上每行只写一个语句第54页/共61页1.4.2 C语言程序的结构语言程序的结构C语言程序的结构特点:4.程序总是从main函数开始执行5.C程序对计算机的操作由C语句完成6.数据声明和语句最后必须有分号7.C语言本身不提供输入输出语句8.程序应当包含注释,增加可读性第55页/共61页1.5 运行运行C程序的步骤与方法程序的步骤与方法1.上机输入和编辑源程序(.c文件)2.对源程序进行编译(.obj文件)3.进行连接处理(.exe文件)4.运行可执行程序,得到运行结果说明:以上过程参见教材中图1.1 附录A中有Visual C+6.0中编辑、编译、连接和运行C程序的方法第56页/共61页1.6 程序设计的任务程序设计的任务1.问题分析对于接手的任务要进行认真的分析研究所给定的条件分析最后应达到的目标找出解决问题的规律选择解题的方法第57页/共61页1.6 程序设计的任务程序设计的任务1.问题分析2.设计算法设计出解题的方法和具体步骤第58页/共61页1.6 程序设计的任务程序设计的任务1.问题分析2.设计算法3.编写程序4.对源程序进行编辑、编译和连接5.运行程序,分析结果结果错了,程序肯定错结果对了,程序未必对第59页/共61页1.6 程序设计的任务程序设计的任务1.问题分析2.设计算法3.编写程序4.对源程序进行编辑、编译和连接5.运行程序,分析结果6.编写程序文档第60页/共61页感谢您的观看!第61页/共61页