第1章程序设计与C语言概述课件.ppt
第1章 程序设计与 C语言概述,1,C 语言程序设计,2022/12/11,2,1.1 程序与程序设计1.2 程序设计语言1.3 C语言概述1.4 程序开发环境与程序调试,本章主要内容,1.1 程序与程序设计,1.1.1 程序1.1.2 算法1.1.3 程序设计方法和风格,2022/12/11,3,返回,1.1.1 程序,程序是指存储在计算机内部存储器中可以连续执行的一条条指令的集合。著名计算机科学家沃思(Nikiklaus Wirth)提出一个公式:程序=数据结构+算法。即一个程序应该包括两方面的内容:数据结构和算法。,2022/12/11,4,1.1.1 程序,数据结构(data structure)是对数据的描述,在程序中要指定数据的类型和数据的组织形式。 算法(algorithm)是对操作的描述,即操作步骤。是用来解决做什么和怎么做的问题。计算机算法可分为两大类:数值运算算法和非数值运算算法。,2022/12/11,5,1.1.1 程序,设计一个程序时,除了考虑数据结构和算法这两个因素之外,还应当采用程序设计方法进行程序设计,并且考虑用一种语言来表示。因此,一个程序应该表示为:,2022/12/11,6,程序=数据结构+算法+程序设计方法+语言工具和环境,1.1.2 算法,1算法概述 算法是指为解决某个问题而采用的方法和步骤。这些步骤是按一定的顺序进行的,每个步骤不能缺少,它们之间的次序也不能颠倒。算法体现了人们解决某一类问题时的思维方法和过程,描述了人类解决某类问题所依据的规则和操作。,2022/12/11,7,1.1.2 算法,计算机算法可分为两大类:数值运算算法和非数值运算算法。 数值运算算法主要用于求解数值问题,如求函数值、求方程的根等。一般数值运算有现成的模型,可以运用数值分析方法,因此对数值运算的算法的研究比较深入,各种数值运算都有比较成熟的算法可供选用。非数值运算算法常用于事务管理领域,如人事管理、行车调度管理等。由于非数值运算要求各异,很难规范化,因此一般只对一些典型的非数值运算算法作比较深入的研究。,2022/12/11,8,1.1.2 算法,2算法的特性 有穷性:一个算法应包含有限的操作步骤,且每一步都可在有穷的时间内完成。 确定性:算法中每一个步骤必须有确切的含义,并且在任何条件下,算法只有惟一的一条执行路径,即对于相同的输入只能得出相同的输出。 可行性:一个算法是能行的,即算法中描述的操作都是可以通过已经实现的基本运算执行有限次来实现的。,2022/12/11,9,1.1.2 算法,有零个或多个输入:这些输入取自于某个特定的对象的集合。有一个或多个输出:这些输出是同输入有着某些特定关系的量,在一个完整的算法中至少会有一个输出。,2022/12/11,10,1.1.2 算法,3算法的描述方法 1966年,Bohra和jacopini证明了任何单入口单出口没有死循环的程序都可以由三种基本的控制结构构造出来。这三种基本结构就是顺序结构、选择结构和循环结构,它们作为表示一个良好算法的基本单元。,2022/12/11,11,1.1.2 算法,算法的表示方法很多,常用的有自然语言、传统流程图、N-S流程图、伪代码、计算机语言等。,2022/12/11,12,1.1.2 算法,(1)用自然语言表示算法 自然语言就是人们日常使用的语言,可以是汉语、英语或其他语言。 下面通过实例来说明用自然语言来描述三种基本结构的算法。,2022/12/11,13,1.1.2 算法,【例1-1】 已知a的值是7,b的值是10,将a、b的值互换,互换后a的值为10、b的值为7,然后输出交换后a、b的值。步骤1:把7赋给变量a步骤2:把10赋给变量b步骤3:将变量a的值赋给变量c步骤4:将变量b的值赋给变量a步骤5:将变量c的值赋给变量b步骤6:输出变量a和变量b的值步骤7:算法结束。,2022/12/11,14,1.1.2 算法,【例1-2】 输出a、b两个不同数中的较大数。步骤1:输入a和b的值步骤2:判断a大于b否,如果a大于b,执行第3步,否则执行第4步步骤3:输出a的值步骤4:输出b的值步骤5:算法结束。,2022/12/11,15,1.1.2 算法,【例1-3】求1+2+3+100。步骤1:使p=1步骤2:使q=2步骤3:使p+q,和仍放在p中,可表示为 p+qp步骤4:使q的值加1,即q+1q。步骤5:如果q不大于100,返回重新执行步骤3、步骤4和步骤5。否则,算法结束。最后得到p的值就是1+2+3+100的和。,2022/12/11,16,1.1.2 算法,(2)用流程图表示算法 流程图是用一些图框表示各种操作。美国国家标准化协会ANSI规定了一些常用的流程图符号,已为世界各国程序工作者普遍采用。流程图符号如图1-1所示。,2022/12/11,17,图1-1,1.1.2 算法,【例1-4】已知a的值是7,b的值是10,将a、b的值互换,互换后a的值为10、b的值为7,然后输出交换后a、b的值。用流程图表示算法。流程图如图1-2所示。,2022/12/11,18,图1-2,1.1.2 算法,【例1-5】输出a、b两个不同数中的大数。用流程图表示算法。流程图如图1-3所示。,2022/12/11,19,图1-3,1.1.2 算法,【例1-6】求1+2+3+100。算法用流程图表示。流程图如图1-4所示。,2022/12/11,20,图1-4,1.1.2 算法,用流程图表示算法直观形象,易于理解,不会产生“歧义性”。三种基本结构的共同特点:只有一个入口只有一个出口结构内的每一部分都有机会被执行到结构内不存在“死循环”,2022/12/11,21,1.1.2 算法,(3)用N-S流程图表示算法 N-S流程图是美国学者I.Nassi和B.Shneiderman于1973年提出的一种新的流程图。N-S流程图的主要特点是取消了带箭头的流程线,全部算法写在一个矩形框内,在该框内还可以包含其他的从属于它的框。 N-S流程图如同一个多层的盒子,又称盒图。,2022/12/11,22,1.1.2 算法,图1-5表示顺序结构 图1-6表示选择结构,2022/12/11,23,图1-5,图1-6,1.1.2 算法,图1-7表示当型循环结构 图1-8表示直到型循环结构,2022/12/11,24,图1-7,图1-8,1.1.2 算法,已知a的值是7,b的值是10,将a、b的值互换,互换后a的值为10、b的值为7,然后输出交换后a、b的值。用N-S流程图表示算法。如图1-9所示。,2022/12/11,25,图1-9,1.1.2 算法,输出a、b两个不同数中的大数。用N-S流程图表示算法。如图1-10所示。,2022/12/11,26,图1-10,1.1.2 算法,求1+2+3+100。用N-S流程图表示算法。如图1-11所示。,2022/12/11,27,图1-11,1.1.2 算法,(4) 用伪代码表示算法 伪代码是用介于自然语言和计算机语言之间的文字和符号来描述算法的。 用伪代码表示算法时,可以用英文伪代码,也可以用汉字伪代码,还可以中英文混用。,2022/12/11,28,用伪代码写算法并无固定的、严格的语法规则,只要用清晰易读的形式把意思表达清楚即可。,1.1.2 算法,【例1-7】求1+2+3+100。用伪代码表示算法。BEGIN(算法开始)1p2qwhile q=100p+qpq+1qprint pEND(算法结束),2022/12/11,29,1.1.2 算法,(5)用计算机语言表示算法 要完成一项工作,包括设计算法和实现算法两个部分。前面介绍的只是描述算法,计算机无法识别流程图和伪代码,只能识别并执行用计算机语言编写的程序,因此,用流程图或伪代码描述出一个算法后,还要将它转换成计算机语言程序。 用计算机语言表示算法必须严格遵循所用语言的语法规则。下面用C语言表示一个算法。,2022/12/11,30,1.1.2 算法,【例1-8】 将变量a,b的值互置。用C语言表示。,2022/12/11,31,#include void main()int a,b,c; /*定义a,b,c为整型变量*/a=7; /*给a赋以整数7*/b=10; /*给b赋以整数10*/c=a; /*把a的值赋给c*/a=b;b=c;printf(“a=%d,b=%dn”,a,b); /*输出变量a,b的值*/,1.1.2 算法,【例1-9】 输出a,b两个不同数中的大数。用C语言表示算法。#include void main()int a,b,c;scanf(%d%d, ,2022/12/11,32,1.1.2 算法,【例1-10】 求1+2+3+100)用C语言表示算法。#include void main()int p,q; p=1;q=2; while(q=100) p=p+q; q=q+1; printf(1+2+3+100=%dn,p);,2022/12/11,33,1.1.3 程序设计方法和风格,程序设计(Programming)是指对提出的问题进行分析、确定数据模型、设计算法、编写源代码、调试并运行程序的方法和过程。 按照结构性质,程序设计分为非结构化程序设计和结构化程序设计。 非结构化的程序设计方法设计出来的程序无章可循,程序常常带有强烈的个人色彩。这样的程序可读性差,编写、调试和维护工作都十分困难。,2022/12/11,34,1.1.3 程序设计方法和风格,结构化程序设计强调从程序的结构上和风格上来研究程序设计方法,提倡利用三种基本结构进行规范化程序设计,使程序具有良好的结构框架。用结构化程序设计方法得到的程序不仅在结构上良好、清晰易读易写,而且易维护、易排错、易验证正确性。 在前面介绍的算法中,顺序、选择和循环就是结构化程序设计方法强调使用的三种基本结构。,2022/12/11,35,1.1.3 程序设计方法和风格,程序设计风格是指编写程序时表现出的特点、习惯和逻辑思路。良好的程序设计风格是程序质量的重要保证,因为良好的程序设计风格使程序结构清晰合理,便于阅读和维护,提高软件的开发效率。,2022/12/11,36,1.2 程序设计语言,程序设计语言(Programming Language)就是计算机所能识别的代码,计算机代码通常要能够向计算机描述清楚做什么,用什么做这两个问题,因此计算机代码的一般形式是:,2022/12/11,37,操作码 目的操作数 源操作数,1.2 程序设计语言,程序设计语言按照语言级别可以分为低级程序设计语言和高级程序设计语言。 低级程序设计语言提供的语句是计算机所能进行的基本操作,如:数据传送指令,算术运算指令,逻辑运算指令等。 高级程序设计语言是接近于自然语言或数学语言的计算机语言。高级语言不再面向机器,而是面向解题的过程,因而又称为算法语言或称为过程语言。,2022/12/11,38,1.2 程序设计语言,对于计算机本身来说,它并不能直接识别由高级语言编写的程序,它只能接收和处理由0和1的代码构成的二进制指令或数据,这种形式的指令是面向机器的,因此也称为“机器语言”。计算机所能直接接受的是二进制信息,利用高级语言编写的程序,应转变为机器代码,才能在计算机上运行。,2022/12/11,39,1.2 程序设计语言,利用高级语言编写程序的过程是:借助每种语言提供的各自的编辑软件生成各自的高级语言源程序,利用各自的翻译程序(编译或解释程序)将高级语言源程序自动翻译成目标程序(.obj文件),再将目标程序与高级语言提供的各种库函数进行连接,生成一个可执行文件(.exe文件)。,2022/12/11,40,1.2 程序设计语言,2022/12/11,41,利用高级语言编写程序的过程可以用图1-12表示。,图1-12,1.3 C语言概述,2022/12/11,42,1.3.1 C语言的发展过程1.3.2 C语言的特点,返回,1.3.1 C语言的发展过程,C语言是在B语言的基础上发展起来的,它的根源可以追溯到ALGOL语言(算法语言)。1972年,贝尔实验室的Dennis Ritchie对B语言进行了扩充和完善,并取BCPL的第二个字母C作为新语言的名称,这就是C语言。 1983年,美国国家标准研究所(ANSI)为C 语言制定了一套ANSI标准,成为现行的C语言标准,称之为ANSI C。,2022/12/11,43,1.3.1 C语言的发展过程,为了对C语言先有一个直观的了解,来看几个简单的C程序例子。【例1-11】编写一个C语言程序,在屏幕上显示一行字符“You are welcome!”.main() printf(You are welcome!n);,2022/12/11,44,运行结果:You are welcome!,1.3.1 C语言的发展过程,【例1-12】编程实现从键盘输入两个整数,求和并将其结果显示在屏幕上。#include main() int a,b,c; scanf(%d,%d, ,2022/12/11,45,程序运行情况如下:5,10The sum is 15,1.3.1 C语言的发展过程,源程序的结构特点:(1)C程序是由函数构成的。一个C源程序至少有且只能有一个main函数(即主函数),可以包含若干个其他函数。因此,函数是C程序的基本单位。(2)函数由函数首部和函数体两部分组成。函数的第一行是函数首部,包含函数类型、函数名、函数参数等。函数体是由一对花括号“”括起来的语句集合,函数体中一般包含变量声明和执行语句。,2022/12/11,46,1.3.1 C语言的发展过程,(3)C程序的函数可以是用户自定义的函数,也可以是系统提供的标准函数(如printf函数、math函数等)。(4)在C程序中,main函数可以放在程序最前,也可以放在程序最后。不论main函数在整个程序中的位置如何,C程序总是从main函数开始执行。(5)C程序中的每一个变量声明和语句都必须以分号结束,分号是C语句的必要组成部分。(6)C语言本身没有输入输出语句,输入和输出的操作是由库函数scanf和printf等函数来完成的。,2022/12/11,47,1.3.1 C语言的发展过程,(7)C程序书写格式自由,一行内可以写几个语句,一个语句也可以分写在多行上,C程序没有行号。(8)C语言用“/*/”对程序进行注释,注释可以出现在程序中任意合适的位置,它对程序的运行不起作用。一个好的C程序应有必要的注释,以便阅读。,2022/12/11,48,1.3.1 C语言的发展过程,书写C程序时应遵循以下规则: (1)一个说明或一个语句最好独占一行。(2)用“”括起来的部分,通常表示程序的某一种层次结构,“”一般与该结构语句的第一个字母对齐,并独占一行。(3)低一层次的语句或说明可比高一层次的语句或说明缩进若干空格后书写,以提高程序的可读性。(4)为源程序添加注释部分,以增加程序的可读性。,2022/12/11,49,1.3.2 C语言的特点,C 语言主要具有下列特点:(1)C语言简洁、紧凑,使用方便。C语言一共有32个关键字(请见附录),9种控制语句,程序书写自由。(2)运算功能丰富。C语言不仅提供了34种运算符(请见附录),还提供了强大的库函数(见附录),从而使C语言的运算类型极为丰富。,2022/12/11,50,1.3.2 C语言的特点,(3)数据结构丰富。C语言具有现代化语言的各种数据结构,C语言的数据类型有整型、实型、字符型、数组类型、指针类型、结构体类型、共用体类型等,能用来实现各种复杂的数据结构运算。(4)C语言具有结构化的特点。以函数为单位,通过结构化的控制语句(如ifelse语句、switch语句、for语句、while语句等),实现了程序的模块化。(5)语法规则相对宽松,程序设计自由度大。,2022/12/11,51,1.3.2 C语言的特点,(6)生成目标代码质量高,程序执行效率高。(7)C语言允许直接访问物理地址,能进行位操作等,具有汇编语言的大部分功能。(8)可移植性好。基本上不做修改就能用于各种型号的计算机和各种操作系统。,2022/12/11,52,1.4 C程序开发环境与程序调试,对C程序进行编译的系统比较多,大多数C编译系统都是集成环境,即把编辑、编译、连接和运行等操作全部集成在一个界面中进行。常用的有Turbo C 2.0、Turbo C+ 3.0、Visual C+等。由于Turbo C 2.0是用于DOS环境的,在进入Turbo C 2.0环境后,不能用鼠标操作,主要用键盘操作,所以,目前用的比较少。,2022/12/11,53,1.4.1 Turbo C+ 3.0集成开发环境,Turbo C+ 3.0是美国Borland公司为C+程序的编辑、编译、连接和运行而研制的集成开发环境,由于C+是从C语言发展而来的,C+对C程序是兼容的,因此可以用C+的编译系统对C程序进行编译。 Turbo C+ 3.0是DOS环境下的集成环境,但是可以把启动Turbo C+ 3.0集成环境的DOS执行文件“tc.exe”生成快捷方式,并以图标的形式放在Windows桌面上,只要双击该图标,就能进入Turbo C+ 3.0环境,并能用鼠标操作菜单。,2022/12/11,54,1.4.1 Turbo C+ 3.0集成开发环境,1打开Turbo C+ 3.0集成环境 在Windows环境下,安装Turbo C+ 3.0时会在桌面上生成一个快捷方式图标,双击该图标即可进入Turbo C+ 3.0集成开发环境。Turbo C+ 3.0集成环境如下图所示。,2022/12/11,55,请进入Turbo C+ 3.0集成环境对其进行介绍,1.4.1 Turbo C+ 3.0集成开发环境,2编辑源文件 单击“File”“New”菜单命令,新建一个C源程序,在集成环境的上部出现了编辑窗口,供用户输入C源程序。如果想对已经保存过的C源程序文件进行修改,单击“File”菜单项,从其下拉菜单中选择“Open”菜单命令,在Name下面输入文件所在的文件路径和文件名,然后单击【Open】按钮,系统将把指定的C源程序调入内存并显示在编辑窗口中。可以对打开的源文件进行插入、删除或修改,直到满意为止。,2022/12/11,56,1.4.1 Turbo C+ 3.0集成开发环境,3保存源文件 对C程序完成编辑之后,应该保存它。如果需要保存的C源文件是新创建的,选择“File”下拉菜单中的“Save”菜单命令,弹出“Save File As”对话框,在“Save File As”下方的输入框中,输入文件的保存路径和文件名,然后单击【OK】按钮。,2022/12/11,57,1.4.1 Turbo C+ 3.0集成开发环境,需要说明的是,保存源文件时文件没有加后缀,系统会认为其是C+程序,将自动加上后缀“.cpp”。所以,保存C源程序时需要加上后缀“.c”,在编译时系统能识别并编译以“.c”为后缀的C程序。,2022/12/11,58,1.4.1 Turbo C+ 3.0集成开发环境,4编译源程序 编写好一个C源程序后,系统需要对程序进行编译,生成“.obj”目标文件。选择“Compile”“Compile”菜单命名,或者按下组合键,会在屏幕上出现一个编译消息框,显示出编译的信息。如果源程序有语法错误,系统将在编译消息框中显示出错信息,用户根据信息对程序进行修改,然后再进行编译,直到不再出现错误或警告信息为止。按下任意键消息框消失。,2022/12/11,59,1.4.1 Turbo C+ 3.0集成开发环境,5连接生成可执行文件 C源程序经过编译后生成目标代码文件,其后缀为“.obj”,需要让其和系统提供的函数库连接成为一个整体,生成可执行文件,其后缀名为“.exe”。方法是选择“Compile”“Line”菜单命令,或按下键。直接按下键,系统会把编译和连接合为一个步骤来进行。,2022/12/11,60,1.4.1 Turbo C+ 3.0集成开发环境,6执行C源程序文件 选择“Run”“Run”菜单命名,或按下组合键,系统会执行已经编译和连接好的可执行文件。若程序需要输入数据,屏幕会切换到运行窗口。输入数据后,将把执行结果输出在运行窗口中。为了查看程序的运行结果,按下组合键,或选择“Window”“User screen”菜单命令,均可切换到程序运行窗口。 选择“File”“Quit”菜单命令,即可退出Turbo C+ 3.0集成环境。,2022/12/11,61,1.4.2 Microsoft Visual C+ 6.0集成环境,1启动Microsoft Visual C+ 6.0 启动Microsoft Visual C+ 6.0可以通过“开始”菜单,也可以通过桌面快捷方式等方式。启动Microsoft Visual C+ 6.0后的开发环境如图1-19所示。,2022/12/11,62,1.4.2 Microsoft Visual C+ 6.0集成环境,2创建一个工程3修改新工程的配置 4确认创建新工程5创建一个C源程序文件到空的工程中6编写C源代码7编译C程序 8运行程序,2022/12/11,63,1.4.2 Microsoft Visual C+ 6.0集成环境,9调试程序(1)设置断点:将鼠标停留在要被暂停的那一行,单击工具栏中的按钮,即可在指定的位置添加一个红色圆形的断点。再次单击工具栏中的按钮,将删除设置的断点。 (2)开始调试:选择“BuildStart Debuggo”菜单命令,或单击按钮,或按下F5键,均可开始调试程序。VC环境将进入调试模式,并且目标程序会在断点处被暂停。,2022/12/11,64,1.4.2 Microsoft Visual C+ 6.0集成环境,(3)单步运行 选择“DebugStep Over”菜单命令或者单击工具栏中的按钮,或者按下F10键,均可进行程序的单步运行。 (4)动态察看变量的值 对于含有变量的C程序,在单步调试程序的过程中,可以在“Watch”窗口中动态地察看变量的值。如果本地变量比较多,自动显示的窗口比较混乱,可以在“Watch”列表中添加自己想要监控的变量名。添加结束后,该变量的值会被显示出来,并且随着单步调试的进行,会看到变量值的变化情况。,2022/12/11,65,返回,1.5 实训,一、实训目的熟悉TC的运行环境。理解算法的特性和描述方法。掌握简单C源程序的运行过程和调试方法。二、实训内容 请见教材具体要求。,2022/12/11,66,返回,