大学C语言课件及复习答案.ppt
《大学C语言课件及复习答案.ppt》由会员分享,可在线阅读,更多相关《大学C语言课件及复习答案.ppt(50页珍藏版)》请在三一办公上搜索。
1、C语言程序设计-第1章 C语言的程序结构,1,C语言程序,C语言函数的一般结构,数据类型,运算符和表达式,C语言程序设计-第1章 C语言的程序结构,2,从实例分析着手,使同学们了解并掌握C语言三种基本流程控制结构:顺序、选择、循环结构,加深对C语言程序开发设计过程的感性认识,强化培养编程思路,为进一步进行C语言程序设计打下基础。,C语言的程序结构,C语言程序设计-第1章 C语言的程序结构,3,若要使a=6,b=7,c=9;以下语句的如何输入?,scanf(“%d%d%d”,C语言程序设计-第1章 C语言的程序结构,4,若有如下定义:int a=5;以下语句的输出分别是什么?,1)printf(
2、“I am a student.n”);2)printf(“%d”,a+2);3)printf(“a=%d,b=%dn”,a,a+14);,C语言程序设计-第1章 C语言的程序结构,5,C语言的程序结构,程序(源代码)C程序的基本结构 算法 结构化程序设计方法选择结构,C语言程序设计-第1章 C语言的程序结构,6,程序,Nikiklaus Wirth(沃思)提出的公式:程序=数据结构+算法程序=算法+数据结构+程序设计方法+语言工具和环境算法:即(Algorithm),对操作的描述,即操作步骤,解决问题的方法。算法是程序的灵魂。数据结构:(data structure),对数据的描述:在程序中
3、要指定数据的类型和数据的组织形式。程序设计方法:结构化程序设计,面向过程程序设计,面向对象程序设计,模块化程序设计,分布式程序设计,多层程序设计,XP极限程序设计。程序(Program)对算法的具体实现。程序的效率不可能超过算法的限制。,C语言程序设计-第1章 C语言的程序结构,7,算法Algorithm,为解决一个问题而采取的方法和步骤,就称为算法。计算机算法:计算机能够执行的算法。简单算法举例:求12345。最原始方法:步骤1:先求12,得到结果2。步骤2:将步骤1得到的结果2乘以3,得到结果6。步骤3:将6再乘以4,得24。步骤4:将24再乘以5,得120。这样的算法虽然正确,但太繁。,
4、改进的算法:S1:使t=1S2:使i=2S3:使ti,乘积仍然放在在变量t中,可表示为ttiS4:使i的值+1,即i=i+1S5:如果i5,返回重新执行步骤S3以及其后的S4和S5;否则,算法结束。如果计算100!只需将S5:若i5改成i100即可。,C语言程序设计-第1章 C语言的程序结构,8,求1357911,算法也只需做很少的改动:S1:1tS2:3iS3:titS4:i+2iS5:若i11,返回S3,否则,结束。,求24681012,该算法不仅正确,而且是计算机较好的算法,因为计算机是高速运算的自动机器,实现循环轻而易举。,C语言程序设计-第1章 C语言的程序结构,9,算法的特性,有穷
5、性:一个算法应包含有限的操作步骤而不能是无限的。确定性:算法中每一个步骤应当是确定的,而不能应当是含糊 的、模棱两可的。输入:有零个或多个。输出:有一个或多个。有效性:算法中每一个步骤应当能有效地执行,并得到确定的 结果。,对于程序设计人员,必须会设计算法,并根据算法写出程序。,C语言程序设计-第1章 C语言的程序结构,10,怎样表示一个算法,1、用自然语言表示算法:除了很简单的问题,一般不用自然语言表示算法。2、用流程图表示算法:流程图表示算法,直观形象,易于理解。,说明:各类框表示相应操作;带箭头的流程线;框内外必要的文字说明。,C语言程序设计-第1章 C语言的程序结构,11,求5!的算用
6、流程图表示,C语言程序设计-第1章 C语言的程序结构,12,C程序三种基本算法结构,顺序结构(逐条执行)选择结构(分支结构)循环结构(重复结构)当型循环(While型循环)直到型循环(Until型循环),结构化算法:由基本结构顺序组成的算法结构,C语言程序设计-第1章 C语言的程序结构,13,顺序结构,#include void main()float x,y,z,s,v;scanf(“x=%f,y=%f,z=%f”,&x,&y,&z);s=x*y;v=x*y*z;printf(“s=%f,v=%f”,s,v);,C语言程序设计-第1章 C语言的程序结构,14,选择结构,当p为“真”,当p为“
7、假”,C语言程序设计-第1章 C语言的程序结构,15,循环结构,A,a,b,p1,Y,While型循环,N,当p1为“真”,当p1为“假”,A,a,b,p1,N,Until型循环,Y,当p1为“真”,当p1为“假”,C语言程序设计-第1章 C语言的程序结构,16,两种循环结构的比较,While型循环,Until型循环,两个循环结构的判断条件相反,A一次也没有执行,A执行了一次,当首次判断p即为“假”(!p为“真”),当执行一次A后,判断p为“假”(!p为“真”),A执行了一次,C语言程序设计-第1章 C语言的程序结构,17,三种基本算法结构的共同特点,只有一个入口只有一个出口结构内每一部分都有
8、机会被执行到结构内不存在“死循环”,C语言程序设计-第1章 C语言的程序结构,18,选择结构程序设计,要设计选择结构程序,要考虑两个方面的问题:一是在C语言中如何来表示条件,二是在C语言中实现选择结构用什么语句。在C语言中表示条件,一般用关系表达式或逻辑表达式,实现选择结构用if语句或switch语句。回顾:关系运算及其表达式 逻辑运算及其表达式if语句switch语句选择结构程序举例,C语言程序设计-第1章 C语言的程序结构,19,关系运算,所谓“关系运算”实际上就是“比较运算”,即将两个数据进行比较,判定两个数据是否符合给定的关系。关系运算符C语言提供6种关系运算符:(大于),=(大于或等
9、于)=(等于),!=(不等于)关系运算符的优先级:低于算术运算符,但高于赋值运算符。ca+b,C语言程序设计-第1章 C语言的程序结构,20,关系表达式,1、关系表达式的概念 所谓关系表达式是指,用关系运算符将两个表达式连接起来,进行关系运算的式子。例如:下面的关系表达式都是合法的aba+bc-d,(a=3)=b,(ab)=(bc)2、关系表达式的值逻辑值(非“真”即“假”)。由于语言没有逻辑型数据,所以用整数“”表示“逻辑真”,用整数“”表示“逻辑假”。,C语言程序设计-第1章 C语言的程序结构,21,例如:假设num1=3,num2=4,num3=5,则:num1num2 值=0(num1
10、num2)!=num3 值=1num1num2num3 值=1(num1num2)+num3 值=6再次强调:C语言用整数“1”表示“逻辑真”,用整数“0”表示“逻辑假”。所以,关系表达式的值,还可以参与其它种类的运算,例如算术运算、逻辑运算等。,C语言程序设计-第1章 C语言的程序结构,22,逻辑运算及其表达式,关系表达式只能描述单一条件,例如“x=0”。如果需要描述“x=0”、同时“x=0)&(x5);!(x=0),假定x=5,则(x=0)&(x5)的值为“假”。,C语言程序设计-第1章 C语言的程序结构,23,2、逻辑运算符的运算优先级(1)同类中逻辑非的优先级最高,逻辑与次之,逻辑或最
11、低,即:!(非)&(与)|(或)(2)其它种类运算符的优先关系!算术运算 关系运算&|赋值运算逻辑表达式:所谓逻辑表达式是指,用逻辑运算符将1个或多个表达式连接起来,进行逻辑运算的式子。在C语言中,用逻辑表达式表示多个条件的组合。例如:闰年:被4整除而不能被100整除或被400整除为闰年。下面就是一个判断一个年份是否是闰年的逻辑表达式。(year%4=0)&(year%100!=0)|(year%400=0)逻辑表达式的值也是一个逻辑值(非“真”即“假”),C语言程序设计-第1章 C语言的程序结构,24,1、if语句的一般格式 if(表达式)语句组1;else 语句组2;if语句中的“表达式”
12、必须用“(”和“)”括起来。else子句(可选)是if语句的一部分,必须与if配对使用,不能单独使用。当if和else下面的语句组,仅由一条语句构成时,也可不使用复合语句形式(即去掉大括号同时也不要中括号)。2、if语句的执行过程(1)缺省else子句时 当“表达式”的值不等于0(即判定为“逻辑真”)时,则执行语句组1,否则直接转向执行下一条。,if语句,例:if(xy)printf(“%d”,x);,C语言程序设计-第1章 C语言的程序结构,25,(2)指定else子句时当“表达式”的值不等于0(即判定为“逻辑真”)时,则执行语句组1,然后转向下一条语句;否则,执行语句组2。3、if语句的嵌
13、套与嵌套匹配原则 if语句允许嵌套。所谓if语句的嵌套是指,在“语句组1”或(和)“语句组2”中,又包含有if语句的情况。if语句嵌套时,else子句与if的匹配原则:与在它上面、距它最近、且尚未匹配的if配对。为明确匹配关系,避免匹配错误,强烈建议:将内嵌的if语句,一律用花括号括起来。,C语言程序设计-第1章 C语言的程序结构,26,4说明if后面的“表达式”,除常见的关系表达式或逻辑表达式外,也允许是其它类型的数据,如整型、实型、字符型等。if语句允许嵌套,但嵌套的层数不宜太多。在实际编程时,应适当控制嵌套层数(2-3层)。“语句组1”和“语句组2”,可以只包含一个简单语句,也可以是复合
14、语句。务必牢记:不管是简单语句,还是复合语句中的各个语句,每个语句后面的分号必不可少!例如:求二个数中的最大值。if(num1num2)max=num1;else max=num2;说明:if行后面的赋值语句“max=num1;”分号不能省略。但不要误认为if和else是2个独立的语句,它们都属于if语句中的一部分,else是if语句的子句。,C语言程序设计-第1章 C语言的程序结构,27,试说明俩种的区别,C语言程序设计-第1章 C语言的程序结构,28,#include main()int x,y;printf(Enter an integer:);scanf(%d,例 求一个数的绝对值,运
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 大学 语言 课件 复习 答案

链接地址:https://www.31ppt.com/p-5954111.html