《高级语言程序设计》.ppt
目 录第一章 概述第二章 基本数据类型第三章 基本结构程序设计第四章 数组第五章 函数第六章 结构体与共用体第七章 指针第八章 文件,基础知识(有关概念)一、计算机系统 由硬件系统和软件系统组成,它们是相辅相成,缺一不可的。没有软件控制,硬件系统是一堆费铁,而没有硬件平台支撑的软件,则一事无成。,二、程序和程序设计 程序是为完成某一特定功能,由编程人员指定的、控制计算机按顺序执行一系列动作的、计算机能够识别的指令集合体。程序设计就是为计算机编制程序的过程,它涉及程序设计方法和程序设计语言等内容。,三、软件 软件是与计算机系统的操作有关的计算机程序、规程、规则,以及可能有的文件、文档及数据。(不能认为软件就是程序,程序只是完整软件产品的一部分),四、程序设计语言 用于书写计算机程序所使用的语言称为程序设计语言。它是由人工设计的语言,是人与计算机之间交互的工具。程序设计语言按照书写形式以及思维方式的不同,一般分为低级语言和高级语言两大类,低级语言包括机器语言和汇编语言。,1、机器语言 是以二进制代码形式(0和1)表示的机器基本指令的集合,是计算机系统唯一不需要翻译可以直接识别和执行的程序设计语言。特点:运算速度快 缺点:机器语言随计算机机型的不同而不同,难阅读、难查错、难修改。,2、汇编语言 用一组字母、数字或字符来代替机器指令的语言称为汇编语言。与机器语言相比,使用汇编语言编写程序可以用助记符来表示指令的操作码和操作对象,也可以用标号和符号来代替地址。特点与缺点:,特点:便于识别和记忆,执行效率较高。缺点:(1)计算机不能直接执行,必须通过“翻译”程序“汇编程序”的帮助,才能转换成相应的机器代码,才能被执行。(2)不同CPU的指令系统其相应的汇编语言不同从而形成了对机器有依赖性。,3、高级语言 是一种接近人们熟悉、习惯的自然语言和数学语言描述的程序设计语言。程序中可以采用具有一定含义的数据命名和容易理解的执行语句。这些语句易学、易用、易维护,且在一定程度上与机器无关,给编程带来了极大的方便。特点与缺点:,特点:程序易设计、理解与维护,容易保证程序正确性。缺点:执行速度没有低级语言高,因为计算机硬件不能直接识别高级语言中的语句,需要先“翻译”,再执行。,五、程序设计步骤 1、明确问题(弄清楚做什么)2、系统设计(怎么做:抽象出数据结构设 计对数据的操作)3、用计算机语言编制程序 4、调试程序,六、机器数及表示方法 计算机中的数是用二进制来表示和存储的,数的符号也是用二进制来表示的(1代表负数;0代表正数)。机器数:把一个数连同其符号在内在机器中的表示加以数值化,这样的数称为机器数。,机器数的表示方法:计算机中通常使用二进制补码 的形式来表示一个数。(因为补码运算可以连同符号位一起参与运算,这便于运算器的设计与实现),七、字符表示法 计算机系统可以识别及处理的字符在机器中用二进制数来表示。常采用ASCII码(美国信息交换标准代码)来表示。这种代码用一个字节(8位二进制码)来表示一个字符,其中低7位为字符的ASCII码值,最高位一般用作校验位。,第 1 章 概述1.1 C语言简介 C语言是一种流行的计算机高级程序设计语言,它设计精巧,功能齐全,不仅是开发系统软件的理想工具,也是开发应用软件的理想程序设计语言。C语言能够在多种操作系统下运行。,1.2 C语言的特点 C语言之所以能成为应用很广的计算机高级程序设计语言之一,是因为它有以下特点:1、语言短小精悍,基本组成部分紧凑、简洁。C语言只有32个标准关键字、42个标准运算符和9种控制语句,语言的组成精练、简洁,而且使用方便灵活。,2、运算符丰富,表达能力强。C语言具有“高级语言”和“低级语言”的双重特点,其运算符包含的内容广泛,所生成的表达式简练、灵活,有利于提高编译效率和目标代码的质量。,3、数据类型丰富,结构化好。C语言提供了编写结构化程序所需要的各种数据类型和控制结构,这些丰富的数据类型和控制结构以及以函数调用为主的程序设计风格,保证了利用C语言所编写的程序能够具有良好的结构化。,4、提供了某些接近汇编语言的功能,有利于编写系统软件。这些功能包括:可以直接访问物理地址,并能进行二进制位运算等。,5、C程序所生成的目标代码质量高 C程序所生成的目标代码的效率仅比用汇编语言描述同一个问题低20%左右,C语言描述问题直观、快捷、工作量小、可读性好、易于调试、修改和移植。因此,C语言编写的程序执行效率高。,6、C程序的可移植性好 在C语言提供的语句中,没有直接依赖与硬件的语句和与硬件有关的操作。因此,用C程序编写的程序能够很容易地从一种计算机环境移植到另一种计算机环境中。,弱点:1、运算符的优先级太多不易记忆,且与日常习惯不完全一致。2、由于语言的语法限制不太严格,在增加了程序设计灵活性的同时,在一定程度上也降低了某些安全性。(这对程序设计人员提出了更高的要求)3、类型检查机制弱,导致有些错误不能在编译时发现。,1.3 C程序结构和书写风格 用C语言编写的程序,称为C语言源程序,简称C程序。任何一种计算机语言,与人类自然语言一样,都有特定的语法规则和特定的表现形式。用一种计算机语言所编写的程序,其书写格式和程序结构的构成规则,就是该种语言特点的具体体现。,1.3.1 简单C程序介绍 程序1:编写一个C程序,程序功能为在标准输出设备(显示器)上显示指定字符串:“welcome to use C”。源程序为:#include main()printf(“welcome to use C n”);程序运行结果为:welcome to use C,程序2:计算两个整数之和并显示其结果#include main()int x,y,sum;x=32;y=67;sum=x+y;printf(“%d+%d=%d n”,x,y,sum);显示结果格式为:32+67=99,程序3:用函数调用法求任意两个整数中的较大者。#include main()int a,b,c;scanf(“%d,%d”,1.3.2 C 程序结构 从前述例子,可总结C程序结构的特点:(1)C程序可以由一个或多个函数构成,但任何一个完整的C程序都必须包含一个且只能包含一个主函数(main函数)。在程序中,无论main函数在何位置,执行程序时总是从main函数开始执行,且在主函数中结束整个程序的执行,即主函数的结束就是整个程序的结束。,(2)函数是程序的基本单位,一个程序功能的实现需通过各个函数的功能来实现,而函数的功能是通过函数之间的相互调用来实现。程序中所使用的函数可以是系统提供的标准库函数,也可以是用户根据需要自定义的函数。,(3)一个函数是由函数首部和函数体构成,函数首部包括函数名、函数类型和函数参数等。函数体是用左右花括号括起来的部分,它包括局部变量的定义和一组执行语句。函数的功能就是由函数体中的语句完成的。C程序中用到的所有变量都必须遵循“先定义后使用”的原则,每一个执行语句必须由“;”(分号)结束。,(4)在函数之外还可以包含一个说明部分,称为外部说明,它可以包括预编译命令、外部变量的说明等。(5)在程序中可以加入注释,格式为:/*注释内容*/,注释为非执行语句,它对程序的编译和执行结果无任何影响,使用的目的是增强程序的可读性。,1.3.3 C 程序的书写风格(1)为了提高程序的可读性,在书写程序时建议使用“锯齿形”的书写方式,即根据语句的从属关系,以缩进书写的形式来体现语句的层次关系。即在语句之前加上适当的空格字符,使处于同一层次的语句从同一列开始书写;,(2)建议一行只写一个语句(C 允许在一行内写多个语句);(3)用小写字母书写程序,大写字母一般用作符号常量或其它用途;(4)标识符(变量名、函数名等)的定义应尽量做到“见名知意”;(5)适当地使用输入/输出时的提示信息,以增强程序的可读性和方便程序的调试。,1.4 C程序的编辑、编译和运行 从编写一个源程序到在计算机上得到运行结果,基本步骤有编辑、编译、连接和运行,每一步的大致含义是:,(1)编辑(输入/修改源程序的过程)用某种编辑软件,将C语言源程序输入到计算机,并以文件的形式存入到磁盘(外存)中。经过编辑后得到的文件以.C或.CPP为文件类型名,称为C或C+源文件。(ASCII码组成的文件,其中的代码机器不能识别),(2)编译(检查程序中语法错误并生成目标代码的过程)对编辑的源文件进行编译(翻译)以产生目标代码文件(将高级语言源程序翻译成机器代码)。编译的过程同时也是检查源程序中各语句是否存在语法错误的过程,当排除了源程序中的所有的语法错误后,可得到相应的目标文件,目标文件以.OBJ 为文件类型名。,(3)连接(将生成的目标代码与库函数等连接的过程)经过编译后的目标文件是不能直接运行的,需要经过连接后才能生成可执行代码(可执行文件),可执行文件是以.EXE 为文件类型名。,(4)运行(检查程序逻辑错误及执行程序获得结果的过程)通过运行可执行文件(.exe文件)可获得程序运行结果。若程序中存在逻辑错误,系统将给予提示,此时需对程序进行相应修改,再重复(1)(4)步。总结上机主要步骤:输入源程序 保存源程序 编译源程序 连接目标代码 运行程序,第 2 章 基本数据类型 任何一种语言都有相应的语法规则,而语法规则是由语言的基本元素构成。C 语言包含以下基本元素。2.1 标识符和关键字 2.1.1 标识符(用户定义的标识符)C 程序中的每一个变量、数组、函数和文件都必须有一个唯一的名称用于系统识别和使用,该名称被称为标识符。(标识符是一个名字,用来标识变量、常量、数组、函数和文件的名字),标识符的定义规则:(1)一个标识符只能由字母、数字和下划线构成,且第一个字符必须是英文字母或下划线。标识符是由用户根据实际问题的需要自己定义的;(2)在定义标识符时,大、小写字母是有区别的,习惯上,标识符用小写字母表示;(3)标识符的长度要求随不同的编译系同而不同,一般最好不要超过八个字符;(4)在定义时,除保证合法性外,最好做到“见名知意”,以提高程序的可读性。,2.1.2 关键字(系统定义的标识符)关键字是一类具有特定含义,专门用作语言的特定成分的标识符。在程序设计中常处于特定的位置,不能当作一般的标识符来使用。在使用关键字时要注意,关键字都是小写的,且书写时不能跨行书写。,2.2 C 语言的数据类型 2.2.1 数据类型概念 算法处理的对象是数据,数据就是程序中的实际数值。数据是以某种特定的形式存在的(如整数、实数、字符等形式)。根据数据的取值范围、可参加的运算以及在计算机中的存储方式等,可以把数据分为各种不同的类型。,2.2.2 程序的概念 一个程序应包含以下两方面的内容:(1)对数据的描述:即在程序中要指定所使用数据的数据类型和数据的组织形式,即描述数据结构;(2)对操作的描述:即对数据的操作步骤的描述,亦即算法描述。即:程序=数据结构+算法,2.2.3 C 语言的数据类型 类型列表见教材(整型、实型、字符型等)C 语言中,所处理的数据根据用途分为不同的数据类型,且分为常量和变量,程序在运行过程中就是通过变量和常量来操作数据的。常量和变量均属于相应的类型。在程序中,对所有用到的数据都必须指定其数据类型,这将关系到数据的正确使用、存储和运算等。,2.3 常量、常量及其分类 2.3.1 有关概念 1、什么是常量?在程序运行过程中,其值不能被改变的量。2、常量的表示方法:直接常量和符号常量 直接常量:在程序中直接出现的常数,例 20,-5,3.14等。其特点是,无需定义,可直接使用;,符号常量:用一个标识符来代表一个常量(该标识符用大写字母表示),在定义了标识符以后,它在程序运行过程中恒代表常量的值。其特点是:需要定义标识符以及它所代表的值,在程序中使用标识符表示常量值(宏替换)。,3、常量的类型 即为在程序中存在的类型。例在语句 lenth=2*3.14*r;中,2为整型常量;3.14为实型常量。4、常量的特点 对于符号常量而言,它一旦被定义,其值在程序中不能被改变,即不能被再赋值。,提示:在程序中应尽量使用符号常量,其好处是:(1)含义清楚,在一个规范的程序中不提倡使用更多的直接常量,过多的常数将导致其含义的混乱,而应该根据常量的用途尽量使用“见名知意”的符号常量;,(2)在需要改变一个常量的值时能做到“一 改全改”。例:#define PRICE 30 main()int num,total;num=10;total=num*PRICE;printf(“total=%d”,total);,2.3.2 常量的分类 1、整型常量 即通常使用的整常数,在 C 语言中有三种表示方法:十进制、八进制和十六进制。亦即,这三种表示方法的常数可出现在 C 表达式中。2、实型常量 即通常使用的小数,有两种表示方法:十进制表示法和指数表示法。前者使用普遍,后者主要用于表示高精度小数。,3、字符型常量 即为一个 C 语言系统能够识别的单字符,其表示方法为用一对单引号 括起来的一个单字符。字符型常量有两种:,(1)作为字符处理的字符常量(例:A、s、+、#、9等)特点:此类常量表现形式为字符,但它们在存储时是按字符在机内的编码值(ASCII码值)存储的,因此,在 C 语言中:字符常量可以参与数值运算 可以把一个字符常量赋给某个字符变量或整型变量(一个字符常量可视为一个字节的整数),(2)起控制作用的特殊字符(转义字符)(例 n、t 等)特点:此类常量用于作为控制代码和输出特殊字符。(在程序中不能像可显示字符一样直接表示字符)控制代码:例 n 表示回车;t 表示跳格;b表示退格等;特殊字符:输出在C语言中有特定含义的字符,例单引号()、双引号(“”)、反斜线()等。例:语句printf(“happy”);将输出“happy”,4、字符串常量 字符串常量是由0个或多个字符构成的字符序列。字符串的表示是用一对双引号 括起来的字符序列。有关字符串的概念:空串:由零个字符构成的字符串,表示方法为“”。字符串长度:字符串中双引号内字符的个数。,字符串常量的存储:在 C 语言中,是用字符数组来存储字符串的,数组中的每一个元素存放一个字符。为了保证字符串存取的正确性,在存储字符串时,系统将自动地在字符串的最后加上一个“空字符”(0),该字符称为字符串结束标记,用来表示字符串的结束(该字符不可显示,亦不产生任何控制作用故称空操作符)。所以,用来存储字符串的存储单元应该比字符串长度至少多一个字节,用以存放 0 字符。提示:a 和“a”有两点不同:表示和存储。,字符常量与字符串常量的区别:表示方法不同;存储方式不同,不能把一个字符串赋给一个字符变量。字符串常量的使用:可由两种方式实现,一是直接使用本身;二是通过对字符数组元素的引用。(见下例),举例:直接使用例输出指定字符串:“How do you do!”。使用语句:printf(“How do you do!”);字符数组元素引用例-输出同上字符串,方法为:定义字符数组:char a20=“How do you do!”;输出:for(i=0;i 20;i+)printf(“%c”,a i);或者:for(i=0;ai!=0;i+)printf(“%c”,a i);,2.4 变量及变量分类 2.4.1 有关概念 1、什么是变量?指在程序运行过程中其值可以被改变的量。在 C 语言中,一个变量实质上就是一个存储空间,在此空间中可进行数据的存储和读取访问。一个变量具有三个方面的含义:一是变量的名字;二是变量的存储单元地址;三是变量的值。,2、变量的定义 由于变量在程序中可代表各种类型的数据,而不同类型的数据又有着不同的存储方式和相应的运算规则,因而,在程序中用到的所有变量都必须在使用之前进行定义,未定义的变量是不能使用的。,定义变量的一般形式是:数据类型说明符 变量名/变量名表;其中:“说明符”表示被定义的变量为何种类型,系统将根据该类型为其分配相应的内存单元;“变量名”是一个合法的标识符,程序中对变量的访问,均是通过变量名进行的。,变量先定义后使用的目的是:(1)保证变量名使用的正确性 未定义的变量编译系统将不接受,因而不可能用到未经定义的变量;(2)保证变量存储的正确性 不同类型的变量将占用不同数量的存储单元,有了存储的正确性,才会有访问的正确性;(3)保证变量运算的合法性 不同类型的变量可进行的运算有所不同,类型的确定将可以避免某些非法运算。,2.4.2 变量的分类 1、整型变量 整型变量用来存放整型数据(整型常量)。根据整型数据不同的数据长度及其相应的取值范围,可将整型变量分为多种类型。(分类有:int、short int、long int、unsigned int等)2、实型变量 实型变量用来存放实型数据(实型常量)。(分类有:float、double等),3、字符型变量(char)字符型变量用来存放字符型常量,一个字符型变量在内存中占一个字节。即一个字符变量只可存放一个单字符。字符型变量使用注意:(1)由于字符型变量只能存放一个字符,所以不能将一个字符串赋给一个字符变量;赋给字符变量的值只能是用单引号括起来的单字符或者与字符相应的 ASCII 码。(赋值问题),(2)字符型数据的存储和使用 存储:一个字符型变量获得值后,其存储单元中存放的是字符对应的 ASCII 码(整数),而非字符本身。(存储方式)例:char a;(定义字符型变量 a)a=B;(将字符 B 赋给变量 a)此时变量 a 中存放的是整数 66(二进制),而非字符 B本身。,使用:由于字符型变量的值实际是一个整数,所以字符型数据与整型数据之间存在一定的通用性,具体体现在:(使用特点)在输出字符型数据时,可以以两种方式输出-整数形式(字符的ASCII 码)和字符形式(ASCII 码对应的字符),不同的输出形式由不同的数据格式来决定;(见下例),例:大小写字母的转换 main()char c1,c2;运行结果为:c1=a;65,66 c2=b;A,B c1=c1-32;c2=c2-32;printf(“%d,%dn”,c1,c2);printf(“%c,%cn”,c1,c2);,字符型数据和整型数据可以相互赋值并进行混合运算,但要注意这两种数据的取值范围是不同的(即要注意变量的类型和赋值的合法性)。,2.5 运算符和表达式 基本概念:1、运算符:是一种对所给的运算对象(操作数)进行何种运算的符号。根据参与运算的操作数的个数不同,C 运算符可分为三类:(1)单目运算符-仅有一个操作数参与运算(!、+、-等)(2)双目运算符-两个操作数参与运算(+、-、|等)(3)三目运算符-三个操作数参与运算(?:唯一一个),2、表达式:用运算符(包括圆括号)将运算对象连接起来,符合 C 语法规则的式子称为表达式。表达式是用来求解和运算的,它总能返回一个值,作为表达式的结果。表达式是构成 C 语句的重要组成部分。,3、运算符的优先级和结合性 对同一个表达式,不同的运算起点和运算顺序将导致不同的运算结果。优先级:一个表达式中若有多种运算(多个运算符),则计算是有先后顺序的,这种运算的先后顺序称为相应运算符的优先级(用小括号可以人为地改变运算符的优先级)。结合性:当一个运算对象(操作数)的两侧的运算符的优先级别相同时,进行运算的结合方向称为运算符的结合性。一般分为左结合(自左向右)和右结合(自右向左)。例:a+b*c/d e 3+5 9&8-8=0,4、数据类型之间的转换(用于表达式计算和赋值运算)C 语言在对表达式进行运算时,运算的原则是:要求表达式中参与运算的数据的数据类型相同。但 C 语言的语法允许不同类型的数据出现在一个表达式中进行混合运算,其中的原理为:在运算之前,系统将对参加运算的各数据进行类型转换,使它们成为相同的类型,再进行运算。类型的转换有两种方式:自动类型转换和强制类型转换。,(1)自动类型转换 亦称作隐式类型转换,即在编译时,系统按照一定的规则自动完成转换。转换规则是:根据各数据数据类型的级别高低,将较低级别类型转换为较高级别类型,然后进行运算,运算结果为较高级别类型。,各类型的级别规定:高 double float long(int)unsigned(int)低 int char,short,其中:横向箭头表示必定转换,例在对字符型或短整型数据进行运算时必定是先转换成 int 型再进行运算;纵向箭头表示当运算对象类型不相同时转换的方向。,使用说明:在类型转换时,非逐级转换。例一个 int 数据与一个 long 型数据进行运算时,是直接将 int 型转换为 long 型,而非逐级转换。数据类型的各种转换只影响表达式的运算结果,并不改变原变量所定义的类型。若进行混合运算,务必要明确所需 计算结果 的数据类型,否则将可能影响结果的准确性或正确性。,(2)强制类型转换 亦称作显示类型转换。即根据程序功能的需要,直接将某数据转换成指定的数据类型。转换方法:在被转换数据(变量或表达式)前加上“目标”类型说明符(类型转换运算符)。一般形式是:(目标类型名)(表达式)或(目标类型名)变量名,使用说明:强制类型转换形式中的表达式,一定要用括号将表达式括起来,否则仅对紧随强制转换运算符的变量进行类型转换。而对单一数值或变量进行强制转换,可不要括号。例:(int)(16.5+10.3)(int)16.5+10.3 其结果不一样。为了获得 5/2=2.5的结果,方法之一是使用强制类型转换:(float)5/2 或 5/(float)2 实现。,强制类型转换的结果是一个指定类型的中间值,而原来变量的类型未被改变。强制类型转换是一种不安全的转换,当强制类型转换出现在将高类型转换为低类型时,有可能造成数据精度的损失。例:double f=3.85;int h;h=(int)f;,第二周实验题一、编程求以下表达式的值,假设:a=6,b=8,x=16.98,y=3.71、x+a%b+(float)(a*a+b*b)+(int)x/(int)y2、(flaot)(a+b)/2+(int)x%(int)y二、编程,从键盘输入一个摄氏温度c,将其转换为华氏温度f和 绝对温度k,输出转换结果。(提示:定义变量c、f、k,输 出结果要求有文字说明)转换公式为:f=9/5c+32 k=273.16+c,2.6 算术运算符和算术表达式 C 语言中的算术运算有基本算术运算和自增1 自减1 运算。1、基本算术运算符(1)运算符:+、-、*、/、%(2)算术表达式:用算术运算符将数值型运算对象连接起来的,符合C语法规则的式子。(3)算术运算符的优先级和结合性 优先级:*、/、%+、-结合性:自左向右(左结合),(4)使用说明:对于除法运算符“/”,若参与运算的两个操作数均为整数,其结果取其商的整数部份,舍去小数部分(截尾取整)。(除数和被除数允许是整型或实型)例:表达式 1/2 的值为0,而非 0.5 对于取余运算符“%”,要求参与运算的两个操作数都必须为整数,不能用于实型数。,2、自增1和自减1运算符 它们是为变量的增1和减1提供的紧凑而简便的格式。(1)运算符:+、-(单目运算符)例:n+等价于 n=n+1-x 等价于 x=x-1(2)使用说明:,+、-运算符的运算对象只能是整型变量、字符型变量和指针变量,不能用于常量和表达式;在使用中,+、-运算符可以作为前缀运算符,格式是:+变量名/-变量名 也可以作为后缀运算符,格式是:变量名+/变量名-,前缀功能:先使变量的值增1/减1之后再引用该变量的值;后缀功能:先引用变量的值,之后变量的值自动增1/减1。例:x=n+相当于 x=n;n=n+1;x=+n 相当于 n=n+1;x=n;,(3)优先级和结合性 优先级:大于算术运算符 结合性:自右向左(右结合),2.7 赋值运算符和赋值表达式 C的赋值运算符包括简单赋值符运算符和复合赋值运算符。1、简单赋值符运算符“=”(1)运算符“=”,由此运算符构成的表达式称为赋值表达式,其形式为:变量名=表达式,(2)赋值表达式的功能 将赋值运算符“=”右边表达式(可以是变量、常量或表达式)的值赋给左边的变量。(3)赋值运算符的优先级和结合性 优先级:仅大于逗号运算符(可用圆括号改变优先级)结合性:自右向左,(4)赋值运算中的类型转换 当运算符“=”两端的类型不一致时,系统会自动进行相应转换,原则是:表达式值(赋值号右边部分)的类型转换为变量(赋值号左边部分)的类型。在转换过程中,可能会发生数据存储形式的变化或者数据丢失。一般而言,运算符“=”两端的类型应尽可能一致。,2、复合赋值运算符 即在运算符“=”之前加上其它运算符构成。例在“=”之前加上算术运算符构成算术复合赋值运算符。算术复合赋值运算符的具体用法是:运算符 名称 使用例 等价语句+=加赋值 x+=y x=x+y-=减 赋值 x-=y x=x-y*=乘赋值 x*=y x=x*y/=除 赋值 x/=y x=x/y%=取余 赋值 x%=y x=x%y 使用注意:复合赋值运算符右边的表达式要视为一个整体,不能将它们分开。(这是由运算符的优先级决定的)例:x-=y+=y*y 相当于 x=x-(y+=y*y),第3章 基本结构程序设计 结构化程序设计的基本思想是:把一个复杂问题的求解过程分步进行,后一步在前一步的基础上细化,这样每步所考虑的子问题都相对易于理解和处理。每一个子问题的细分原则(目标)是功能相对独立。在 C 语言中,每一个目标子问题由一个函数来实现。结构化程序设计是指:任何程序都可以用而且只用三种基本结构来组成,即:顺序结构、选择结构和循环结构。这三种基本结构经反复组合,反复嵌套构成的程序称为结构化程序。,3.1 结构化程序设计的三种基本结构 顺序结构 特点是:程序的流程按语句书写的顺序依次执行,在语句执行的过程中,不会发生流程控制的转移。该结构所包含的语句是简单语句,如赋值语句、输入/输出语句(函数调用语句)、空语句、复合语句等。,3.1.2 选择结构 判断给定条件,根据判断结果(真/假)决定所要执行的操作。该结构会发生流程控制的转移。该结构所包含的语句是选择语句,如 if、if-else、switch语句等。循环结构 用来完成语句的重复执行,即根据给定的条件反复执行某段程序或某个语句。该结构会发生流程控制的转移。该结构所包含的语句是循环语句,如while、do-while和for语句等。,3.2 顺序结构语句 3.2.1 赋值语句 1、一般形式:变量名=常量/表达式;2、功能:与赋值表达式相同。3、与赋值表达式的区别(1)语句后有语句结束符“;”(2)语句和表达式可出现的位置不同,赋值表达式可以出现在任何表达式可以出现的地方。例:printf(“%d”,a=b);合法 printf(“%d”,a=b;);不合法,3.2.2 空语句3.2.3 复合语句 由一对花括号括起来的多个语句组成;复合语句的使用:复合语句在语法上等价于一个语句,其主要作用是用于将多条语句放在程序中只允许放一条语句的地方。使用注意:复合语句中最后一个语句的分号不能少,而“”之后不能有分号。,3.2.4 函数调用语句(数据的输入输出)函数调用语句由一次函数调用后跟一个分号构成。标准的字符输入/输出函数介绍:(在使用以下函数时,程序中必须包含命令:#include“stdio.h”)1、字符输入函数 getchar(1)一般调用格式:getchar()(2)功能:接收从键盘输入的一个字符(执行过程与scanf函数相同)。(3)使用说明:此函数是无参函数,圆括号内不能有空格。,例:#include main()char a;printf(“Enter a character:”);a=getchar();printf(“%c,%d”,a,a);若输入:A 则运行结果为:A,65,2、字符输出函数(1)一般调用格式:putchar(ch)其中:ch 可为一个字符型变量名、字符型常量(转义字符)、整型变量,也可以是某个字符所对应的ASCII代码值。(2)功能:将ch的值(一个字符)输出到标准输出设备(显示器)的当前光标位置。(3)使用说明 该函数不能输出字符串,只能输出一个单字符;无论该函数的参数为何种类型,其函数值均为一个单字符。,例:#include“stdio.h”main()char c1=H,c2=L;putchar(c1);putchar(E);putchar(c2);putchar(76);putchar(117);putchar(n);运行结果:HELLO,3、格式输入函数 scanf(1)一般形式 scanf(“数据格式控制串”,输入项地址序列)例:scanf(“%d%f%c”,其中:“数据格式控制串”一般只包含“格式说明符”,用于指定输入项的数据类型(通常不包含普通字符),该类型即为变量定义的类型。“输入项地址序列”由准备接收数据的变量或数组的地址组成。,(2)功能 按照“格式控制串”中指定的格式从键盘输入一个或多个数据,并送入由“地址序列”中各地址所指示的内存单元中。(3)数据格式字符 d(整型)、ld(长整型)、f(单精度实型)、lf(双精度实型)、c(字符型)、s(字符串型),(4)使用说明(参看教材)使用该函数,一次可以输入多个不同类型的数据,输入多个数据时,数据之间的间隔符默认的可以有三种:空格键、Tab键和回车键。若在“格式控制串”中包含了普通字符,则在输入数据时需原样输入这些字符(注意与printf函数的区别)。在“格式控制串”中不能用指定实数的精度,即不能使用“%m.nf”格式指定输入数据的形式,数据形式由用户按类型输入。,(5)执行过程 在程序运行过程中,当执行到该函数时停止运行,等待用户从键盘输入数据,之后再继续运行。(建议与printf函数联用,即在使用该函数之前先输出有关提示信息,以提示输入),数值型数据与字符型数据的混合输入例:,4、格式输出函数 printf(1)一般形式 printf(“数据格式控制串”,输出项序列)例:printf(“x=%d,y=%f,z=%cn”,x,y,z);其中:“数据格式控制串”用于指定输出项的数据类型和输出格式。(其中包含普通字符和格式说明符)“输出项序列”由需输出的数据项组成,可以是多个数据、多种类型,这些数据项可以是常量、变量或表达式。,(2)功能 按照“格式控制串”中给定的输出格式,将“输出项序列”中的各数据输出到标准输出设备(显示器)上。注意:每一个输出项都必须用一个“格式说明符”指定输出格式。“格式说明符”的类型必须与相应输出项的类型一致。(输出项的类型即是变量定义的类型)(3)数据格式字符 d(整型)、ld(长整型)、f(单精度实)、(双精度实型)、c(字符型)、s(字符串型),(4)使用说明 函数中“输出项”与“格式说明符”的类型、个数和顺序要匹配,否则将导致错误;可以使用辅助格式符对格式“c、s、d、f”指定输出字段的宽度(一般而言,除非特殊需要,都直接利用系统隐含的输出宽度)除格式说明符及输出字段的宽度外,“在格式控制串”中的其它字符,均按原样输出。,例:有如下输出#include main()int i=10;float f=2.5;printf(“i=%d,f=%4.2f”,i,f);输出结果:i=10,f=2.50 程序中:“i=,f=”是需原样输出的字符,3.2.5 变量的初始化 是一种为变量赋初值的方法,即:在定义变量的同时为变量赋初值。一般形式:数据类型说明符 变量名=常量;为变量赋值可以用三种方法:(1)赋值语句(2)键盘输入(3)变量初始化,顺序结构程序举例 例:从键盘输入一个字符,求出它的前导和后继字符,然后按由小到大的顺序输出这些字符及相应的 ASCII 码值。#include main()char c;程序运行结果:int c1,c2;输入:B c=getchar();输出:A,B,C c1=c-1;65,66,67 c2=c+1;printf(“%c,%c,%cn”,c1,c,c2);printf(“%d,%d,%dn”,c1,c,c2);,顺序结构小结:顺序结构是一种逻辑上最简单的结构,也是程序设计的基础,在顺序结构程序中,一般包含以下两部分。程序头:预处理命令,即文件包含和宏定义命令;顺序结构程序函数主体:函数体主要包括以下内容(按解决问题的逻辑顺序)(1)变量说明(系统按类型分配存储空间并确定运算规则)(2)输入数据(若应用问题存在数据运算,则执行)(3)数据处理语句(4)输出运算结果,3.3 选择结构语句 选择结构是一种通过对给定条件的判断来执行不同操作的结构,该结构的程序设计是由条件语句来实现。条件的判断通过关系运算和逻辑运算来实现。3.3.1 关系运算符和关系表达式 有关概念:(1)逻辑值:用来描述某个命题是否成立,只有两个值“真”和“假”。在C语言中是用数值1来表示“真”,用数字0表示“假”。这样,C语言中的逻辑值也可以作为整数直接参与算术运算。,(2)关系运算:是两个操作量的“比较运算”,判定它们是否符合给定的关系。关系运算一般用来描述某个简单的条件,其运算结果为一个逻辑值。(3)关系运算符及关系表达式(参考教材)(大于)、=(大于等于)、(小于)、=(小于等于)=(等于)、!=(不等于)由以上运算符将两个运算对象连接起来的式子称为关系表达式。例:a=3;b=5;则表达式 a=b 的结果为逻辑值0(“假”)而 ab 的结果为逻辑值1(“真”),(4)关系运算符的优先级和结合性 优先级:一级:、=、=二级:=、!=结合性:均为左结合(5)关系运算符与其它运算符的优先级 算术运算符(高)关系运算符 赋值运算符(低)(6)特别提示:不要将关系运算符“=”(是否等 于)误写成“=”(赋值运算符)。,3.3.2 逻辑运算符和逻辑表达式 有关概念:(1)逻辑量:C语言中,进行逻辑运算时,将所有的非0数值(正/负)都视为逻辑量“真”;把数值0视为逻辑量“假”。(2)逻辑运算:是指对逻辑量进行的运算,一般用来描述由多个条件组合而成的复合条件,运算结果是一个逻辑值。,(3)逻辑运算符及优先级和结合性 运算符:!、&、|优先级:!&|结合性:“!”自右向左(右结合)“&、|”自左向右(左结合)(4)逻辑运算符与其它运算符的优先级 逻辑非(!)(高)算术运算符 关系运算符 逻辑与(&)、逻辑或(|)赋值运算符(低),(5)逻辑表达式:用逻辑运算符将关系表达式或逻辑量连接起来的式子。逻辑表达式的运算结果仍为逻辑值(0/1)。(6)特别提示:要注意区分逻辑值和逻辑量 在逻辑表达式中参与运算的逻辑量可以是任何非零和零的数值,但编译系统在给出其运行结果时,只可能是 0/1 两个整数之一(假或真)。,(7)逻辑运算的真值表(用于进行逻辑运算)运算的两个原则:对于运算符&(逻辑与):只有两个量均为“真”时,其结果才为“真”,其它均为“假”对于运算符|(逻辑或):只有两个量均为“假”时,其结果才为“假”,其它均为“真”,关系运算举例计算下列表达式的值:假设 c=w,a=1,b=2,d=-51、x+1=d+14、3=a&c=z 5、c-1=n|c+1=n6、!x-y!=!y-x-y 7、x|z&(y=1)8、(z=1)|(x=0),逻辑运算真值表 以下表中假设a、b是两个逻辑量,(8)使用说明 C语言在求解逻辑表达式的值时,采用“非完全求解”法,即并非表达式中所有的逻辑运算符所表达的运算都被执行,而是在必须执行某逻辑运算所表达的运算才可能求出整个表达式的值时,才执行该运算规定的操作。例1:a&b&c(a、b、c只要有一为假,则结果为假)a|b|c(a、b、c只要有一为真,则结果为真),例2:判断以下程序的运行结果(逻辑表达式的非完全求解)#include main()int a=3,b=6,c=8,d=2,n=2,m;m=(ab)运行结果:n=2,m=0,补充习题求下列表达式的值:设 a=3,b=4,c=5,m=5,n=2(要求在运算时按照运算符的优先级别写出运算过程)1、a+bc&b=c2、a|b+c&b-c3、!(ab)&!c|14、!