1、1,大学C+程序设计教程,C+基础小结 (18章),2,C+程序的基本结构,全局变量说明 #include 子函数1 (形式参数) 子函数局部变量说明语句序列 。 int main( ) 局部变量说明语句序列return 0; ,C+程序由函数组成;至少包括主函数main()和(或)若干个子函数。一个函数又由变量及参数说明语句和语句序列构成。每个语句必须用分号结尾。一个语句行可以写多个语句,一个语句可以写在多行上。C+语言允许在程序中插入注释行。C+语言提供了包括I/O功能在内的大量标准库函数,但调用这些函数时,必须在程序头部包含头文件。,函数体,3,三大基本结构示意图,顺序结构选择结构,循环
2、结构,模块(语句)A,模块(语句)B,条件,程序模块1,成立,不成立,程序模块2,条件,程序模块,不成立,成立,(当型循环),程序模块,成立,不成立,条件,(直到型循环),4,1、顺序结构,r = p; p = q; q = r;,5,2、选择结构(之一),一路分支语句格式: if (表达式)语句序列,条件?,成立,不成立,语句序列,两路分支语句格式:if (表达式)语句序列1else语句序列2,条件?,语句序列 1,成立,不成立,语句序列 2,语句序列可以是一个语句,也可以是复合语句结构(分程序),6,分程序,分程序在语法上是一个整体,相当于一个语句。 分程序中也可以再嵌套新的分程序,用以构
3、成更加复杂的控制结构。,7,选择结构(之二),多路(开关)选择语句 :switch(整数表达式)case 数值1:语句序列1;.case 数值n:语句序列n;default :语句序列n+1;,计算整型表达式,值 = ?,语句 序列1,.,语句 序列2,语句 序列n,带break语句的多分支结构,8,3、循环结构(之一),当型循环语句格式:while (表达式) 语句序列 ,直到型循环语句格式:do语句序列 while (表达式);,循环体,循环体,条件?,语句序列,成立,不成立,语句序列,不成立,成立,条件?,9,循环结构(之二),for语句用来实现计数循环:for (; ; ),10,C+
4、数据类型的分类,11,类型不同的数据之间的混合算术运算,不同类型的数据在参加运算之前会自动转换成相同的类型, 然后再进行运算。 转换规则 转换的原则是由低级向高级转换char - int - float - double例: int a; a= 5/2 ,结果a为2 强制类型转换格式:(类型语句)e例: int i1=1,i2=2;double d1;d1 = (double)i1/i2;结果d1为0.5,12,数组,数组: 具有相同类型的数据的集合。 数组用数组名来标识。 其中的每个变量(数组元素)通过该变量在数组中的相对位置(下标)来引用。 特点: 常用于处理大批量数据; 数据特点:存在内
5、在联系; 数组具有相同数据类型的变量集合; 这些变量都有相同名字,但下标不同; 称这些变量为数组元素; 只有一个下标一维数组; 有两个下标二维数组。,13,字符型数组和字符串处理库函数,字符是用单引号括起来的单个字符,它在存储器中占1个字节。例如,A字符串是用双引号括起来的一串字符,它在存储器中占n+1个字节,即字符串的结束符0也占1个字节的位置。例如,”abc”;有效字符的个数称为字符串长度。 例如,”abc”的长度为3,但占4个字节 (0占一位)。字符串是用字符型数组存放的。,14,字符串长度与字符数组大小的关系,char A10=“China”;,A5,A6,A7,A8,A9,A0,A1
6、,A2,A3,A4,0,?,?,?,?,C,h,i,n,a,15,函数的定义,函数必须先定义,后使用。定义函数的一般格式为:(),函数体,16,函数的调用,函数要先定义,后调用。调用函数时要考虑到函数本身的参数; 调用标准库函数时,要包含相应的头文件 输入/输出函数 iostream.h 字符串函数 string.h 常用数学函数 math.h 调用自定义函数时,要定义相应的实参,并给这些实参赋值。实参与形参必须一一对应: “类型一致、位置一致、个数一致”实参与形参有3种结合方式:值调用、引用调用和地址调用。,17,指针型变量的定义,一般格式:类型描述符 *指针变量名表;例:int * ptr
7、; float *array; char *s1,*s2;指针类型内存地址值是固定不变的,不同类型的指针本身所占据的存储区域都一样大。 规定了用指针间接访问数据时的访问方式 为指针的算术运算提供依据,18,“*”和“&”运算符,“,19,自顶向下, 逐步求精,结构化程序设计支持“自顶向下, 逐步求精”的程序设计方法。 “自顶向下” 是将复杂、大的问题划分为小问题,找出问题的关键、重点所在,然后用精确的思维定性、定量地去描述问题。 “逐步求精” 是将现实世界的问题经抽象转化为逻辑空间或求解空间的问题。复杂问题经抽象化处理变为相对比较简单的问题。经若干步抽象(精化)处理,最后到求解域中只是比较简单
8、的编程问题。,20,基本思想和方法,基本思想 从问题本身开始,经过逐步求精,将解决问题的步骤分解为由基本程序结构模块组成的结构化程序框图,据此编写程序。基本方法 从题目本身开始, 找出解决问题的基本思路, 将其用结构化框图(可能是非常粗糙)表示。 对框图中的比较抽象的、用文字描述的模块进一步分析细化,结果仍用结构化框图表示。 将所求解问题的所有细节都弄清楚后, 再可以根据框图直接写出相应程序代码。,21,完全数,找出210000之内的所有完全数。 所谓完全数,即其各因子之和正好等于本身的数。 如6=1+2+3,28=1+2+4+7+14,所以6,28都是完全数。#include void ma
9、in() int k;for(int n=2;n10000;n+)k=0;for(int m=1;m=n/2;m+)if(n%m=0)k=k+m;if(k=n)coutkendl; ,22,自顶向下, 逐步求精的解法,void main() for(int i=2;i=10000;i+)if(iscomplete(i)coutiendl; bool iscomplete(int n) int s=0;for(int i=1;i=n/2;i+)if(isfactor(i,n)s=s+i;return s=n; bool isfactor(int i,int n) return n%i=0;,23,学好程序设计语言的唯一途径是你的编程能力与你在计算机上投入的时间成,结 束 语,上机练习,正比,