第10章C语言程序设计初步课件.ppt
《第10章C语言程序设计初步课件.ppt》由会员分享,可在线阅读,更多相关《第10章C语言程序设计初步课件.ppt(70页珍藏版)》请在三一办公上搜索。
1、第10章 C语言程序设计初步,1,第10章 C语言程序设计初步1,10.1引论,程序设计语言的发展经历了三个阶段:,机器语言是用二进制表示的,计算机能直接识别和执行的语言 如:10000000(加)10010000(减),机器语言执行速度最快。由于用二进制表示,因而程序可读性差,非专业人员难于掌握,二进制指令通过符号化 如 ADD A,B,高级语言表达方式接近被描述的问题,接近于自然语言和数学表达式,易于人们接受和掌握,2,10.1引论 程序设计语言的发展经历了三个阶段:机器语言,C语言发展史,产生背景产生过程 时间:19721973 地点:美国贝尔实验室 目的:UNIX操作系统 设计人:Ke
2、n.Thompson和Dennis.M.RitchieC标准 标准C:K&R合著The C Programming Language ANSI C:1983年 87 ANSI C:1987年 1990年国际标准的ANSI C,3,C语言发展史产生背景3,2.C语言的特点,(1)高效性:C程序往往紧凑且运行速度快。(2)移植性:C程序不经修改或很少修改就可以到其他系统上运行。(3)运算符丰富:有算术、关系、逻辑、位、自增/自减、赋值运算符等等。(4)数据结构丰富:数据类型有整型、实型、字符、数组、指针、结构体等,能实现如链表、树、栈等结构运算。(5)对硬件操作:能直接访问内存的物理地址,并进行位
3、操作。(6)自由度大:语法限制不严格。如:不检查数组下标是否越界,整型与字符型可通用,条件可用0和非0表示假与真,指针操作灵活等。,4,2.C语言的特点(1)高效性:C程序往往紧凑且运行速度快。,10.1.3 C语言程序的基本结构,一个C语言程序可以是非常简单的,也可以是特别复杂的,这取决于程序所要实现的功能。我们先来认识一个最为简单的C程序。,【例1】最简单的C程序。,void main()printf(This is a C Language Program!n);,语句结束标志,运行结果:This is a C Language Program!,main是主函数的函数名,表示这是一个主
4、函数。每一个C源程序都必须有,并且只能有一个主函数(main函数),这是整个C程序运行的入口点,printf是C语言中的输出函数,它的功能是把要输出的内容送到显示器去显示。双引号内字符串原样输出,“n”是回车换行符。,C语言规定:语句以分号结束,5,10.1.3 C语言程序的基本结构 一个C语言程序,【例2】计算输入的两个整数的和。,/*求两数的和。*/void main()int a,b,sum;/*这是定义变量*/a=12;b=34;sum=a+b;printf(The sum is%dn,sum);,运行结果:the sum is 46,6,【例2】计算输入的两个整数的和。数据类型名定义
5、的变量名,以,【例3】计算输入的两个整数的最大值。,/*This is the third C program*/#include int max(int a,int b);void main()int x,y,z;printf(Input two numbers:n);scanf(%d%d,int max(int a,int b)int c;if(a b)return a;else return b;return(c);,自定义函数max,返回a、b中最大值,假设输入:10 20 运行结果:max=20,调用内部函数,接受键盘输入数据,7,【例3】计算输入的两个整数的最大值。/*This i
6、s,总结源程序的结构特点,(1)一个语言源程序可以由一个或多个源文件组成,每个源文件以“.c”作为扩展名。(2)每个源文件可由一个或多个函数组成。(3)一个源程序不论由多少个文件组成,都有一个且只能有一个main函数,即主函数,整个程序的运行从主函数开始。(4)源程序中可以有预处理命令(include 命令仅为其中的一种),预处理命令通常应放在源文件或源程序的最前面。(5)每一个说明,每一个语句都必须以分号结尾。但预处理命令,函数头之后不能加分号。(6)标识符、关键字之间必须至少加一个空格以示间隔。若已有明显的间隔符,也可不再加空格来间隔。,8,总结源程序的结构特点(1)一个语言源程序可以由一
7、个或多,编 辑,程序代码的录入,生成源程序*.c或*.cpp,编 译,语法分析查错,翻译生成目标程序*.obj,链 接,与其它目标程序或库链接装配,生成可执行程序*.exe,运 行,10.1.4 语言的编辑、编译和运行,9,编 辑程序代码的录入,生成源程序*.c或*.cpp编 译语法,人们使用计算机,就是要利用计算机处理各种不同的问题,而要做到这一点,人们就必须事先对各类问题进行分析,确定解决问题的具体方法和步骤,再编制好一组让计算机执行的指令即程序,让计算机按人们指定的步骤有效地工作。这些具体的方法和步骤,其实就是解决一个问题的算法。根据算法,依据某种规则编写计算机执行的命令序列,就是编制程
8、序,而书写时所应遵守的规则,即为某种语言的语法.,10.2 算法基础,10.2.1 算法(Algorithm)的概念,【例10.2.1】输入3个数,求其最大值。问题分析:设num1,num2,num3存放3个数,max存放其最大值。为求最大值,就必须对3个数进行比较,可按如下步骤去做:输入3个数num1,num2,num3。先把第1个数num1的值赋给max。将第2个数num2与max比较,如果num2max,则把第2个数num2的值赋给max(否则不做任何工作)。将第3个数num3与max比较,如果num3max,则把第3个数num3的值赋给max(否则不做任何工作)。输出max的值,即最大
9、值。,10,人们使用计算机,就是要利用计算机处理各种不同的问题,而要做到,10.2.2 算法的基本特征,一个算法应具有以下5个基本特征:有穷性确定性有效性 有零个或多个输入 有一个或多个输出,算法必须总是在执行有限个操作步骤和可以接受的时间内完成其执行过程。也就是说,对于一个算法,要求其在时间和空间上均是有穷的。例如:一个采集气象数据并加以计算进行天气预报的应用程序,如果不能及时得到结果,超出了可以接受的时间,就起不到天气预报的作用。,算法中的每一步都必须有明确的含义,不允许存在二义性。例如:“将成绩优秀的同学名单打印输出”,在这一描述中“成绩优秀”就很不明确,是每门功课均为95分以上?还是指
10、总成绩在多少分以上?,算法中描述的每一步操作都应能有效地执行,并最终得到确定的结果。例如:当Y=0时,X/Y是不能有效执行的。,11,10.2.2 算法的基本特征 一个算法应具有以下5个基本特,10.2.3 算法的表示,用自然语言表示 用流程图表示 用伪代码表示 计算机语言表示算法,自然语言可以是中文、英文、数学表达式等。用自然语言表示通俗易懂,缺点是可能文字过长,不太严格,表达分支和循环的结构不很方便。【例10.2.2】求1+2+m的值N,当N10000时结束。算法可表示如下:n=0m=0m加1N加m判N是否大于10000,如果满足关系结束;不满足关系继续执行。,伪代码是用介于自然语言和计算
11、机语言之间的文字和符号来描述算法的,它不用图形符号,因此,书写方便,格式紧凑,也容易懂,同时也便于向计算机语言算法的转换。【例10.2.4】用伪代码表示求10!的算法。begin(开始)置t的初值为1(1t)置i的初值为2(2i)当(while)i=10,执行(do)begin 使t=ti 使i=i+1 end 打印t的值(print t)end(结束)。,计算机是无法识别流程图和伪代码形式,只有用计算机语言编写的程序才能被计算机执行。因此在用流程图和伪代码形式描述出算法后,还要将它转换成计算机语言程序。【例10.2.5】用C语言程序来描述求10!。#include void main(voi
12、d)long i,t;t=1L;i=2L;while(i=10L)t=t*i;i=i+1;printf(%ldn,t);。,12,10.2.3 算法的表示 用自然语言表示 自然语言可以是,C数据类型,基本类型,构造类型,指针类型,空类型void,字符类型char,枚举类型enum,整 型,实型,数组,结构体struct,共用体union,数据类型决定:1.数据占内存字节数2.数据取值范围3.其上可进行的操作,本节所介绍的数据类型,10.3 基本数据类型,10.3.1 数据概述,13,C基本类型构造类型指针类型空类型void字符类型char枚举,常量与符号常量.常量定义:程序运行时其值不能改变的
13、量(即常数)常量的分类:直接常量(值常量)整型常量 如,15、0、7浮点型常量 如,5.0、12.36字符型常量 如,A、a 指针常量 如,NULL字符串常量 如,”ABC”符号常量 用标识符来代表常量。其定义格式为:,#define 符号常量 常量,#define NUM 20#define PI 3.1415926,【例10.3.1】#include#define PI 3.14 main()float area;area=10*10*PI;printf(“area=%fn”,area);,运行结果:area=314.000000,行尾不能有分号 define前面一定要有#符号常量名最好使
14、用大写 符号常量名最好有意义,14,常量与符号常量#define 符号常量,变量定义:程序运行时其值可以被改变的量 变量的两要素:变量名、变量值变量的使用:先说明,后使用,例:int x,y,z;float radius,length,char ch;,例:int a=2,b,c=4;float data=3.67;char ch=A;int x=1,y=1,z=1;int x=y=z=1;,15,变量例:例:15,10.3.2 整型数据,1.整型常量,十进制整数:由数字09和正负号表示.如:123,-456,0八进制整数:由数字0开头,后跟数字07表示.如:0123,011十六进制整数:由0
15、 x或0X开头,后跟09,af,AF表示.如0 x123,0Xff,2.整型变量,整型变量的分类,16,10.3.2 整型数据1.整型常量 十进制整数:由数字0,变量的说明,也即变量的定义,一般形式为:类型说明符 变量名标识符1,变量名标识符2,.;例如:int a,b,c;/*a,b,c为整型变量*/long m,n;/*m,n为长整型变量*/unsigned p,q;/*p,q为无符号整型变量*/在书写变量说明时,应注意以下几点:允许在一个类型说明符后,说明多个相同类型的变量。各变量名之间用逗号间隔。类型说明符与变量名之间至少用一个空格间隔。最后一个变量名之后必须以“;”号结尾。变量说明必
16、须放在变量使用之前。也可在说明变量为整型的同时,给出变量的初值。其格式为:类型说明符 变量名标识符1=初值1,变量名标识符2=初值2,.;,整型变量的说明,【例10.3.2】main()int a=3,b=5;printf(“a+b=%dn”,a+b);程序的运行结果为:a+b=8,17,变量的说明,也即变量的定义,一般形式为:整型变量的说明,5.10.3.3 实型数据,实型常量(实数或浮点数),十进制小数形式:由数字09和小数点组成.如:0.0,5.6,-5.指数形式:由十进制数,加阶码标志e或E以及阶码(只能为整数,可以带符号)组成.其一般形式为:aEn 其中:a为十进制数,n为十进制整数
17、,都不可缺少。其可表示为a10n,合法的实数表示:2.1E5 表示2.1105,3.7E-2 表示3.710-2。,非法的实数表示:345(无小数点),E7(阶码标志E之前无数字),-5(无阶码标志),50.-E3(负号位置不对),实型变量,单精度实型(float)float f=3.14,g;这种定义的变量在内存中占4个字节(32位)的存储单元。双精度实型(double)double x,y;这种定义的变量在内存中占8个字节(64位)的存储单元。,注意:实型常量不分单精度和双精度。一个实型常量可以赋给一个float或double型变量,根据变量的类型截取实型常量中相应的有效位数字。【例10.
18、3.3】main()float a;a=0.123456789;printf(a=%f,a);运行结果为:a=0.123457,18,5.10.3.3 实型数据实型常量(实数或浮点数),10.3.4 字符型数据,字符型常量,定义:用单引号括起来的单个普通字符或转义字符.,如 a A?n 101,字符常量的值:该字符的ASCII码值,如 A65,a97,048,n10,转义字符:反斜线后面跟一个字符或一个代码值表示,19,10.3.4 字符型数据字符型常量 定义:用单引号,字符型变量 字符型数据类型符是char(字符character)在内存中占1个字节(16位)字符变量存放字符ASCII码 c
19、har与int数据间可进行算术运算 存在有符号和无符号之分。默认情况下为有符号,例:char ch;unsigned char C=B;,例:a=D;/a=68;x=A+5;/x=65+5;s=!+G/s=33+71;,【例10.3.4】main()char a,b;a=120;b=121;printf(%c,%cn%d,%dn,a,b,a,b);程序运行结果为:x,y120,121(思考?),20,字符型变量例:例:【例10.3.4】20,基本算术运算符:+-*/%结合方向:从左向右 优先级:-*/%-+-(2)(3)(4)说明:“-”可为单目运算符时,右结合性 两整数相除,结果为整数%要求
20、两侧均为整型数据,例:5/2=-5/2.0=,例:5%2=-5%2=1%10=5%1=5.5%2,2,-2.5,1,-1,1,0,(),10.3.5算术运算符和算术表达式,21,基本算术运算符:+-*/%例:5,自增、自减运算符+-作用:使变量值加1或减1 种类:前置+i,-i(先执行i=i+1或i=i-1,再使用i值)后置 i+,i-(先使用i值,再执行i=i+1或i=i-1),例:j=3;k=+j;j=3;k=j+;j=3;printf(“%d”,+j);j=3;printf(“%d”,j+);a=3;b=5;c=(+a)*b;a=3;b=5;c=(a+)*b;,/k=4,j=4,/k=3
21、,j=4,/4,/3,/c=20,a=4,/c=15,a=4,22,自增、自减运算符+-例:j=3;k=,表达式和算术表达式,表达式:用运算符和括号将运算对象(常量、变量和函数等)连接起来的、符合语言语法规则的式子。算术表达式:表达式中的运算符都是算术运算符的表达式。,例:3+5*8、(x+y)/2-1等,23,表达式和算术表达式 表达式:用运算符和括号将运算对象(常量,10.4 顺序结构程序设计,10.4.1 C语言语句1.控制语句:完成一定功能的语句称为控制语句。C语言有9种控制语句,参见表10.4-1。2.表达式语句 由一个表达式构成一个语句,称为表达式语句。一般形式为:表达式;表达式语
22、句可分为:(1)赋值语句 赋值语句由赋值表达式后跟一个分号组成。例如:a=3;(2)函数调用语句 函数调用语句由函数调用表达式后跟一个分号组成。例如:printf(“This is a C statement.”);(3)空语句 空语句是只有一个分号而没有表达式的语句。,24,10.4 顺序结构程序设计10.4.1 C语言语句24,3.特殊语句C语言中还包括一些其他语句,如复合语句等。把多个语句用花括号括起来组成的语句称复合语句。在程序中可以把复合语句看成是一条语句,而不是多条语句。例如:x=y+z;a=b+c;printf(“%d%d”,x,a);注:复合语句内的各条语句都必须以分号“;”结
23、尾,在括号“”外不能加分号。,25,3.特殊语句25,10.4.2 printf函数,1.一般格式,printf(格式控制字符串,表达式1,表达式2,表达式n);,功能,按照“格式控制字符串”的要求,将表达式1,表达式2,表达式n的值显示在计算机屏幕上。,说明,格式控制字符串用于指定输出格式。它包含两类字符:常规字符:包括可显示字符和用转义字符表示的字符。格式控制符:以%开头的一个或多个字符,以说明输出数据的类型、形式、长度、小数位数等。其格式为:,%修饰符格式转换字符,例:long int x=0 x8AB6;printf(“The Value of x is%ldn”,x);,常规字符,常
24、规字符(转义符),格式控制符(修饰符),格式控制符(格式转换符),26,10.4.2 printf函数1.一般格式print,2.转义字符 就以一个“”开头的字符序列,称为转义字符,【例10.4.1】转义字符的使用main()char a,b,c;a=n;b=e;c=167;/*8进制数167代表的字符w*/printf(“%c%c%cn”,a,b,c);/*以字符格式输出*/printf(“%ct%ct%cn”,a,b,c);/*每输出一个字符跳到下一输出区*/printf(“%cn%cn%cn”,a,b,c);/*每输出一个字符后换行*/,运行结果如下:new new“”代表空格,下同 n
25、 e w,27,2.转义字符字符形式含 义ASCII代码n换行,将当,3.printf函数的调用 格式控制用于指定输出参数的输出格式,格式控制由两部分组成:格式说明和普通字符。普通字符(包括转义字符)将被简单地复制显示(或执行)。一个格式说明项将引起输出参数项的转换与显示。例如:main()int a=3,b=4;printf(“a=%db=%dn”,a,b);输出结果为:a=3b=4,“n”为转义字符,【例10.4.2】main()char ch1=a,ch2=b;printf(“ch1=%c,ch2=%cn”,ch1,ch2);printf(“ch1=%d,ch2=%dn”,ch1,ch2
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 10 语言程序设计 初步 课件
链接地址:https://www.31ppt.com/p-2108280.html