语言教程讲义2001年2月17日_第1页
语言教程讲义2001年2月17日_第2页
语言教程讲义2001年2月17日_第3页
语言教程讲义2001年2月17日_第4页
语言教程讲义2001年2月17日_第5页
已阅读5页,还剩214页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

C语言概 C语言的发展过 当代最优秀的程序设计语 C语言版 C语言的特 面向对象的程序设计语 C和 简单的C程序介 输入和输出函 C源程序的结构特 书写程序时应遵循的规 C语言的字符 C语言词 TurboC2.0集成开发环境的使 TurboC2.0简介和启 TurboC2.0集成开发环 File菜 Project菜 Options菜 Debug菜 Break/watch菜 TurboC2.0的配置文 CC语言C语言的发展过C语言是在70年代初问世的。一九七八年由电报公司(AT&T)贝尔正式了C语言。同时由B.W.Kernighan和D.M.Ritchit合著了著名的“THECNationalStandardsInstitute)在此基础上制定了一个C语言标准,于一九八三年。通常称之为ANSIC。当代最优秀的程序设计语CUNIX系统。由于C语言的强大功能和各方面的优点逐渐为C语言版·C或称MS·BorlandTurboCTurbo·AT&TC语言的特1·C语言简洁、紧凑,使用方便、灵活。ANSIC32个关键字 hugeinterruptnear 2·34种。CC的运6·C语言允许直接物理地址,能进行位(bit)操作,能实现汇编语言的大部分功能,但是,CC写程序会感到限制少、灵活性大,功能强,但较其他高级语言在学习上要一些。面向对象的程序设计语在C的基础上,一九八三年又由贝尔的BjarneStrou-strup推出了C++。C++进BorlandC++,SymantecC++和VisualC++。C和再进一步学习C++就能以一种熟悉的语法来学习面向对象的语言,从而达到事半功倍的目简单的C程序介一个C源程序的基本部分和书写格式。{printf("世界,您}【例1.2】{doubleprintf("sineof%lfis}main程序的功能是从键盘输入一个数x,求x的正弦值,然后输出结果。在main()之前的两行称为预处理命令(详见后面)include称为文件包含命令,含该函数原型所在的头文件。在本例中,使用了三个库函数:输入函数scanf,正弦函数sin,输出函数printf。sin函数是数学函数,其头文件为math.h文件,因此在程序的主函数前用include命令包含了math.h。scanf和printf是标准输入输出函数,其头文件为stdio.h,在主函数前也用include命令包含了stdio.h文件。需要说明的是,Cscanfprintf这两个函数可以省去对其头文件的包含命1BAIC语言是不同的。说明部分是C源程序结构中很重要的组成部分。本例中使用了两个变量xs,用来表示输入的自变量和sin函数值。由于sin函数double语句,printf函数在显示器上输出提示字符串,请操作人员输入自变量xcanfxsinsfsx输入和输出函scanfprintf这两个函数分别称为格式输入函数和格式输出函数。其意义是按指定的printf("sineof%lfisintmax(inta,int {int intmax(inta,intb); printf("inputtwonumbers:\n"); /*输入x,y值*/ }intmax(inta,int {if(a>b)returna;elsereturn }max函数。函数之间是并列关系。可从主函数中调用其它函数。max函数的功能是比较两个数,然后把较大的数返回给主函数。max函数是一个用户自定函数的参a,bmax函数中比a,b的大小,把大者返回给主函数的z,最后在屏幕上输出z的值。C源程序的结构特书写程序时应遵循的规用括起来的部分,通常表示了程序的某一层次结构。{}一般与该结构语句的第一C语言的字符a~z26个0~910C语言词外,其余都由用户自定义。C规定,标识符只能是字母(A~Z,a~z)、数字(0~9)、下划线a,x, 以下标识符是的: 出现字符- 以减号开bowy- 标准CC语言编译系统限制,同时也受到BOOKbook类型说明语句定义预处理命令inta;inta;CintaC语言中使用的常量可分为数字常量、字符常量、字符串常量、符号常量、转义字符C语言的注释符是以“/*”开头并以“*/”结尾的串。在“/*”和“*/”之间的即为注TurboC2.0集成开发环境的TurboC2.0简介和统支持下的软件,在windows98环境下,可以在DOS窗口下运行。D盘根下建立一个TCTurboC2.0TC下还建立了两个了LIBINCLUDELIB子中存放库文件,INCLUDE子中存放所DOS环境下或在windows98DOS窗口下运行运行TurboC2.0时,只要在TC子目录下键入TC并回车TurboC2.0集成开发环境。windows98环境下,也可以选运行菜单,然后键入d:\tc\tc即可,也可以在tc文件夹tc.exe文件,然后用鼠标双击该文件名也可进入TurboC2.0集成开发环境。TurboC是Borland公司的产品,Borland公司是一家专门从事软件开发、研制的大Turbo系列软件如TurboBASIC,TurboPascal,TurboProlog,这些软件很受用户欢迎。该公司在1987TurboC1.0产品,其中使用了全然一新的集成开发环境,即使用了一系列下拉式菜单,将文本编辑、程序编译、连接以及程序运行一体化,大大方便了程序的开发。1988年BorlandTurboC1.5版本,增加了图形库和文本窗口函数库等,而TurboC2.0则是该公司1989年的。TurboC2.0在原来集成开发环境的基础上增加了查错功能,并可以在Tiny模式下直接生成.COM数据、代码、堆栈64K内存中)(8087/80287/80387等)进行仿真。BorlandTurboC++,TurboC2.0的集成开发环境,并包含了面向对象的基本思想和设计方法。1991年为了适用公Windows3.0版本,BorlandTurboC++作了更新,TurboC的新一代产品BorlandcC++也已经问世了。TurboC2.0集成开发环TurboC2.0集成开发环境中后,屏幕上显示其中顶上一行为TurboC2.0主菜单,中间窗口为编辑区,接下来是信息窗口,最TurboC2.0的主屏幕,TurboC2.0主屏幕顶上一行,显示下列内容FileEditRunCompileProjectOptionsDebugEdit外,其它各项均有子菜单,Alt加上某项中第一个字母,就可进入该项的File菜Alt+FFile菜单,如图Load:装入一个文件,DOS的通配符(如*.C)进入该项,而不需要先进入File菜单再选此项。Pick8个文件列成一个表让用户选择,选择后将该程序装入编辑区,并将光标置在上次修改过的地方。其热健为Alt-F3。,Save:将编辑区中的文件存盘,NONAME.C时,将询问是否更改文件名,其F2。Writeto:可由用户给出文件名将编辑区中的文件存盘,若该文件已存在,则询问要不要覆盖。 中的文件,并可由用户选择Changedir:显示当前默 ,用户可以改变默 Oss TurboC2.0DOS提示符下,DOS命令,若想回TurboC2.0中,DOSEXIT即可。,以上各项可用光标键移动色棒进行选择回车则执行。也可用每一项的第一个大写字母Esc键TurboC2.0所有菜单均采用这种方法进行操作,以下不再说明。Edit菜按Alt+E可进入编辑菜单,若再回车,则光标出现在编辑窗口,编辑。编辑方法基本与wordstar相同,可用F1键获得有关编辑方法的帮助信息。与编辑有关的功能键如下 删除光标所在的一行 TurboC2.0库函数, TurboC2.0双界符的后匹配 TurboC2.0的双界符包括以下几种符号 花括 尖括 圆括(和 方括[和 注释 双引" 单引'TurboC2.0在编辑文件时还有一种功能,就是能够自动缩进,即光标定位和上一个非空字符对齐。在编辑窗口中,Ctrl+OL为自动缩进开关的控制键。Run菜Alt+RRun菜单,RunProject/Projectname项指定的文件名或当前编辑区的文件。如果对上次编译后的源代码未做过修改,则直接运行到下一个断点(没有断点则运行到结束)。否则先进行编译、连接后才运行,其热键为Ctrl+F9。Programreset:中止当前的调试,释放分给程序的空间,Ctrl+F2Gotocursor::调试程序时使用选择该项可使程序运行到光标所在行。光标所在行必须为一条可执行语句,否则提示错误。其热键为F4。Traceinto:在执行一条调用其它用户定义的子函数时Traceinto项则执行长条将到该子函数内部去执行,其热键为F7。Stepover:执行当前函数的下一条语句,即使用户函数调用,执行长条也不会进,Compile,CompiletoOBJ:将一个C源文件编译生成.OBJ目标文件,同时显示生成的文件名。其Alt+F9。MakeEXEfile:此命令生成一个.EXE的文件并显示生成的.EXE文件名。其中.EXE文Project/Projectname说明的项目文件名若没有项目文件名,PrimaryCfile若以上两项都没有文件名 则为当前窗口的文件名LinkEXEfile:把当前.OBJ文件及库文件连接在一起生成.EXEBuildall:重新编译项目里的所有文件,并进行装配生成.EXE文件。该命令不作过时检(上面的几条命令要作过时检查,即如果目前项目里源文件的日期和时间与目标文件相同或更早,则对源文件进行编译)。PrimaryCfile:当在该项中指定了主文件后,在以后的编译中,C文件,C

如果编译中有错误,则将此文件调入编辑窗口 Project,Projectname:项目名具有.PRJ的扩展名,其中包括将要编译、连接的文件名。例一file1.c,file2.c,file3.c组成,3file.exe的执行文件,可以先建立一个file.prj的项目文件,其内容如下:file.prjProjectname项中,以后进行编译时将自动对项目文件中规定的三个file.exe文件。如果其中有些文件已经编译成.OBJ,,,当项目文件中的每个文件无扩展名时,均按源文件对待,另外,其中的文件也可以是库文件,但必须写上扩展名.LIB。Make编译,否则不进行检查。OptionsAlt+OOptions菜单,该菜单对初学者来说要谨慎使用,该菜单有以下几个内 Define:打开一个宏定义框,同户可输入宏定义。多重定义可同分号,赋值可用等Codegeneration:它又有许多任选项,这些任选项告诉编译器产生什么样的目标代CallingconventionCPascalInstruction Floating Defaultchar Mergeduplicatestrings作优化用,将重复的字符串合并在一起StandardstackframeTeststackoverflowLine OBJdebuginformation在.OBJOptimization:它又有许多任选项UseregistervariableJumpoptimization通过去除多余的跳转和调整循环与开关语句的办法,压缩代Source:它又有许多任选Indentifierlength说明标识符有效字符的个数,32 Errorstopafter多少个错误时停止编译,25Warningstopafter多少个警告错误时停止编译,100DisplayPortabilitywarningANSIViolations了ANSI关键字的警告错误LesscommonerrorLinker:本菜单设置有关连接的选择项,Map 选择是否产生.MAPDevaultlibraries是否在连接其它编译程序产生的目标文件时去寻找其缺省Warnduplicatesymbols当有重复符号时产生警告信MessageCurrentfile在编辑窗口中的文件错误Allfiles所有文件错误Off不Configautosave:选on时,在Run,S或退出集成开发环境之前,如果TurboC的配置被改过,offEditautosave:是否在Run或S之前,自动编辑的源文件Backupfile:是否在源文件存盘时产生后备文件(.BAK文件),,Directories:规定编译、连接所需文件的路径,Includedirectories:包含文件的路径,多个 用";"分开Librarydirectories:库文件路径,多个 用";"分开Outputdirectoried:输出文件(.OBJ,.EXE,.MAP文件) TurboCdirectoried:TurboC所在 Pickfilenamepick文件名,currentpickfileArguments:允许用户使用命令行参数Saveoptions:保存所有选择的编译、连接、调试和项目到配置文件中缺省的配置文件TCCONFIG.TC。DebugAlt+DDebug菜单,该菜单主要用于查错,Expression要计算结果的表达式Result显示表达式的计算结果CallstackTurboCdebugerBreak/watch菜Alt+BBreak/watch菜单,Removeall:watchesViewnextbreakpointTurboC2.0的配置TurboC2.0有关信息的文件其中存有编译、连接的选择和路径等信息。可以用下述方法建立TurboC2.0的配置:OptionsOptions/Saveoptions命令,将TC时只要在DOS下键入:若设置Options/Environment/Configautosave为on,则退出集成开发环境时,当前的设置TurboC2.0TCCONFIG.TC中。TurboC在启动时会自动寻找这TCINSTTurboC的有关配置TC.EXE中。TurboC在启动时,若没有找到配置文件,则取TC.EXE中的缺省值。程序的—算 算法的概 简单算法举 算法的特 怎样表示一个算 用自然语言表示算 用流程图表示算 三种基本结构和改进的流程 用N-S流程图表示算 用伪代码表示算 用计算机语言表示算 结构化程序设计方 程序的—算对数据的描述。在程序中要指定数据的类型和数据的组织形式,即数据结构(datastructure(algorithmNikiklausWirth公式

C程序,进行编写程序的初步训练,因此,算法的概简单算法举步骤3:将6再乘以4,得24。S1:使t=1S2:使S3:使t×itt×i→tS4:使i的值+1,即i+1→iS5:如果i≤5,S3S4S5如果计算100!只需将S5:若i≤5改成i≤100即可。 如果该求1×3×5×7×9×11,算法也只需做很少的改动:S1:1→tS2:3→iS3:t×i→tS4:S5写成:S5:i<11,S3;S1:S2:如果gi≥80,则打印ni和giS3:2.320002500年中的每一年是否闰年,将结果输出。4整除,但不能被100整除的年份设y为被检测的年份,则算法可表示如下:S1:然后转到S6S7:y≤2500时,S21111...1 100S1:sigh=1S2:sum=1S3:S4:sigh=(-S5:term=sigh×(1/deno)S6:term=sum+termS7:deno=denoS8:若deno≤100,返回S4;否则,结束S1:输入nS2:S5:i+1→inS6:如果 ,返回S3;否则打印n“是素数”;然后算法结束n算法的特怎样表示一个算用自然语言表示算用流程图表示算

1111...1 100三种基本结构和改进的流程N-S流程图表示算1973年学者提出了一种新型流程图:N-S流程图。用伪代码表示算用计算机语言表示算}}{int{sigh=-sigh;}}结构化程序设计方数据类型、运算符与表达 C语言的数据类 常量与变 常量和符号常 变 整型数 整型常量的表示方 整型变 实型数 实型常量的表示方 实型变 实型常数的类 字符型数 字符常 转义字 字符变 字符数据在内存中的形式及使用方 字符串常 符号常 错误!未定义书签变量赋初 各类数值型数据之间的混合运 算术运算符和算术表达 C运算符简 算术运算符和算术表达 赋值运算符和赋值表达 逗号运算符和逗号表达 小 C的数据类 基本类型的分类及特 常量后 常量类 数据类型转 运算符优先级和结合 表达 数据类型、运算符与表达C语言的数据类·类实型(浮点型共空类一定的数据类型的,应在函数定义及函数说明中给以说明,例如在例题中给出的max函数定义中,函数头为:intmax(inta,intb);其中“int”类型说明符即表示该函数的返sin,由于系统规定其函数返回值为双精s=sinx);中,ssin函数的常量与变举变量。在程序中,常量是可以不经说明而直接的,而变量则必须先定义后使用。整常量和符号常#define#definePRICE30{intnum,total;}变 33单元整型数整型常量的表示方值为0~7。八进制数通常是无符号数。015(十进制为13)、0101(十进制为65)、 256(无前缀0)、03A2(包含了非八进制数码)、-0127(出现了负号)十六进制整常数:十六进制整常数的前0X0x。其数码取0~9,A~Fa~f(整型常数的后缀:在16位字长的机器上,基本整型的长度也为16位,因此表示的数的范围也是有限定的。十进制无符号整常数的范围为0~65535,有符号数为-32768~。八进制无符号数的表示范围为0~。十六进制无符号数的表示范围为0X0~0XFFFF0x0~0xFFFF。如果使用的数超过了上述范围,就必012L(十进制为10)、077L(十进制为63)、 0XA5Lu表示十六进制无符号长整数A5,其十进制为165。整型变i:inti; 0000000000001010000000000000000000101011111111111101011111111111110110整型变量的分基本型:类型说明符为int,在内存中占2个字节短整量:类型说明符为shortint或short。所占字节和取值范围均与基本型相长整型:类型说明符为longintlong,在内存4个字节无符号型:类型说明符为unsignedunsignedint或unsigned01111111111111111111111111111111-即-215~(215-2unsigned0~(216-2short-即-215~(215-2unsignedshort0~(216-2long 即-231~(231-4unsigned0~(232-413int00unsignedshortintunsignedlongint整型变量的定类型说明符变量名标识符,变量名标识符,...;inta,b,c;(a,b,c为整型变量)longx,y;x,y为长整型变量unsignedp,q;(p,q为无符号整型变量){inta,b,c,d;unsignedu;}整型数据的溢{inta,b;}0111111111111111-1000000000000000longx,y;}运算结果为长整型。但c,d被定义为基本整型,因此最后结果为基本整型。本例说明,不实型数实型常量的表示方aEn(a为十进制数,n为十进制整数)其值为a*10n。-2.8E-2(等于-2.8*10-345无小数点-5(无阶码标志53.-E3负号位置不对 printf("%f\nprintf("%f\n",356);}实型变+1数 指实型变量的分实型变量分为:单精度(float型、双精度(double型)和长双精度(longdouble型)1.7E+30816比特数(字节数longfloatx,y;(x,y为单精度实型量){floata,b;}{floata;}bTurboC规定小数后最多保留六位,其余部实型常数的类字符型数字符常'a'、'b'、'='、'+'、字符常量只能用单引号括起来,不能引号或其它括号字符常量只能是单个字符,不能是字符字符可以是字符集中任意字符。但数字被定义为字符型之后就不能参与数值运如'5'5是不同的。'5'转义字常用的转义字符及其ASCII代98反斜线符7广义地讲,C语言字符集中的任何一个字符均可用转义字符来表示。表中的\ddd和\xhh{inta=5;b=6; }字符变charchar字符数据在内存中的形式及使用方0111100111100001111001{}{}本例中,a,b被说明为字符变量并赋予字符值,C语言允许字符变量参与数值运算,字符串常字符串常量是由一对双引号括起的字符序列。例如:"CHINA",“Cprogram”"$12.5"字符常量由单引号括起来,字符串常量由双引号括起字符常量只能是单个字符,字符串常量则可以含一个或多个字符BASIC语言不同的。但是可以用1。增加的一个字节中存放字符"\0"(ASCII0)。这是字符串结束的标志。"Cprogram"Cprogram字符常量'a'和字符串常量"a"虽然都只有一个字符,但在内存中的情况是不同aa"a"在内存中占二个字节,可表示aa变量赋初在程序中常常需要对变量赋初值,以便使用变量。语言程序中可有多种方法为变量提1=12=2,……;inta=3;intcharch1='K',ch2='P';{}各类数值型数据之间的混合运若参与运算量的类型不同,则先转换成同一类型,然后进行运int型和long型运算时,先把int量转成long型后再进行运算。要先转换成double型,再作运算。charshort型参与运算时,必须先转换成int ints,r=5;}doubles为整型,故赋值结果仍为整型,舍去了小数部分。(类型说明符 (表达式(float) a转换为实 类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)floatf=5.75;}改变。因此,(int)f的值为5(删去了小数)f的值仍为5.75。算术运算符和算术表达C运算符逻辑运算符:用于逻辑运算。包括与(&&)、或(||)、非(!)三种求字节数运算符:用于计算数据类型所占的字节数(sizeof)算术运算符和算术表达算,如-x,-5等具有左结合性。}本例中,20/7,-20/720.0/7和-20.0/7由于有实数}算术表达式:用算术运算符和括号将运算对象(也称操作数)C语(x+r)*8-合性(自右至左)。例如算术运算符的结合性是自左至右,即先左后右。表达式x-y+z则y应先与“-”号结合,执行x-y运算,然后再执行+z的运算。这种自左至右的结合算符是赋值运算符。如x=y=z,由于“=”的右结合性,应先执行y=z再执行x=(y=z)运算。(类型说明符)表达式(float) a转换为实 x+y的结果转换为整1运算符记为“--1。 i自减1后再参与其它运算。 i参与运算后,i的值再自减1main(){inti=8;printf("%d\n",--printf("%d\n",i--printf("%d\n",-printf("%d\n",-i--}i的初值为82i1后输出故931后输出故为84行输i为8之后再加1(9)5行输i9之后再减1(8)6行输出-8之后再加1(9),第7行输出-9之后再减1(为8)。inti=5,j=5,p,q;}这个程序中P=(i++)+(i++)+(i++)应理解为三个i相加,故P15。然后i再自13i8q的值则不然,q=(++j)+(++j)+(++j)q先自1,再参与运算q1三次8,三8相加的和为24,j的最后值仍8。赋值运算符和赋值表达赋值运算=

C中,把“=类型转实型赋予整型,舍去小数部分。前面的例子已经说明了这种情0)。inta,b=322;charc1='k',c2;}bc2后取其低八位成为字符型(b的低八位为66ASCII码对应于字符B)。在赋值符“”之前加上其它二目运算符可构成复合赋值符。如+=,-=,*=,%=,<<=,>>=,&=,^=,|=变量双目运算符=表达式 等价于a=a+5 等价于r=r%p逗号运算符和逗号表达起来组成一个表达式,称为逗号表达式。}12也可以又是逗号表达式。表达式1,表达式2,…表达式n小C的数据类基本类型的分类及特1C2-short2-long4 2unsigned448常量后L或l U或u F或f 常量类数据类型转运算符优先级和结合表达最简单的C程序设计—顺序程序设 C语句概 赋值语 数据输入输出的概念及在C语言中的实 字符数据的输入输 putchar函数(字符输出函数 格式输入与输 scanf函数(格式输入函数 顺序结构程序设计举 最简单C程序设计—顺序程序设认识,为后面各章的学习打下基础。C语句概源源程序文件源程序文件源程序文件C程x=y+z;赋值语句; 1,i1被调函数体中的语句,求取函数值(在后面函数中再详细介绍)。printf("CProgram");的语句定义符组成。C语言有九种控制语句。可分成以下三类:{x=y+z;}复合语句内的各条语句都必须以分号“;”结尾,在括号“}”外不能加分号;赋值语变量=变量=…=表达式intintintif((x=y+5)>0)下述语句是的:if((x=y+5;)>0)数据输入输出的概念及在C所谓输入输出是以计算机为主体而言#include<stdio.h或#include#include<stdio.h或#include字符数据的输入输putchar函数(字符输出函数 (输出大写字母A) putchar(‘\101’);(也是输出字符A) 或#includechara='B',b='o',c='k';} 函数(键盘输入函数charc;main(){charprintf("inputacharacter\n");}使用本函数前必须包含文件“stdio.h”完毕再返回TC屏幕。格式输入与输 函数(格式输出函数printf函数称为格式输出函数,其关键字最末一个字母f即为“格式”(format)之意。其要求在使用printf函数之前必须包含stdio.h文件。printf(“格式控制字符串”,输出表列{inta=88,b=89;printf("%d}本例中四次输出了a,b值,但由于格式控制串不同,输出的结果也不相同。第四行的输出语句格式控制串中,两格式串%da,b间有一个空格。第五行的printf语句格式控制串中加入的是非格式字符逗号,因此输出的在TurboC doufcs -+#则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。{intfloatb=123. doublec= chard='p';}a“%5d”5,a值为15只有两位故补三个空格。第八行中以四种格式输出实型量b的值。其中“%f”和“%lf”格式的输出相同,说明“l”符对“f”类型无影响。“%5.4lf”5,精度输出双精度实数,“%8.4lf”由于指定精度为4位故截去了超过4位的部分。第十行输出字符d,其中“%8c”8p74.5】inti=8;}4.6】inti=8;}printfprintf7。最后才求输出表列中的第一项“++i”i18。 函数(格式输入函数scanf同,C语言也允许在使用scanf函数之前不必包含stdio.h文件。scanf(“格式控制字符串”,地址表列&a,ab变量的地址是C编译系统分配的,用户不必关心具体的地址是多少。inta,b,c;}在本例中,由于scanf函数本身不能显示提示串,故先用printf语句在屏幕上输出提示,请用户输入a、b、c的值。执行scanf语句,则退出TC屏幕进入用户屏幕等待用户输78或789格式字符doxufcsscanf("%d%*d当输入为 3时,把1赋予a,2被跳过,3赋予b句输入小数为2位的实数。scanfscanf("%d",a);是的,应改为scnaf("%d",&a);才是合法的。用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或数据(如对“%d”输入“12A”时,A即为数据)时即认为该数据结束。 则把'd'赋予a,b,'ec。时,才能把'd'赋于a,'eb,'f'c。scanf("%c%ccharprintf("inputcharactera,b\n");}可输出MN两字符。charprintf("inputcharactera,b\n");scanf("%c%c",&a,&b);} intprintf("inputanumber\n");}longprintf("inputalonginteger\n");}inputalongcharprintf("inputcharactera,b,c\n");scanf("%c%c%c",&a,&b,&c);}main(){inta;longb;floatf;doubled;charc;}顺序结构程序设计举s(ss(sa)(sb)(s{floata,b,c,s,area;}

b b2b b2 2b2qb2 2a {float}分支结构程 关系运算符和表达 关系运算符及其优先次 关系表达 逻辑运算符和表达 逻辑运算符极其优先次 逻辑运算的 逻辑表达 条件运算符和条件表达 switch语 程序举 分支结构程关系运算符和表达关系运算符及其优先次 <=小于或等于 >=大于或等于5)==等于6)!=符,高于赋值运算符。在六个关系运算符中,<,<=,>,>=的优先级相同,高于==和!=,==关系表达5>0的值为“真”,即1charinti=1,j=2,k=3;}在本例中求出了各种关系运算符的值。字符变量是以它对应的ASCII码参与运算的。对于含多个关系运算符的表达式,如k==j==i+5,根据运算符的左结合性,先计算k==j,该式不成立,其值为0,再计算0==i+5,也不成立,故表达式值为0。逻辑运算符和表达逻辑运算符极其优先次&&与运算||或运算 ((&&“&&”和“||”低于关系运算符,“!”高于算术运算a>b&&逻辑运算的5>0&&或运算||虽然C编译在给出逻辑运算值时,以“1”代表“真”,“0”代表“假”5||0的值为“真”,即1逻辑表达表达式逻辑运算符表达式逻辑表达式的值是式中各种逻辑运算的最后值,以“1”和“0”分别代表“真”和“假”charinti=1,j=2,k=3;}本例中!xy分别0,!x*!y0,故其输出0x0,故!!!x的逻x||i&&j-3逻辑值为1i<j&&x<yi<j的值1x<y0故表达式的值为1,0相与,最后为0i==5&&c&&(j=8)式,由i==5为假,即值0,该表达式由两个与运算组成,所以整个表达式的值为0。对于式x+y||i+j+k由于x+y的值为非0,故整个或表达式的值为1。ifC语言的if语句有三种基本形式。if语句的三种形if(intprintf("\ninputtwonumbers: if(max<b)max=b;}maxb,bmaxmaxmaxinta,printf("inputtwonumbers: }ifelseif(语句elseif(语句…elseif(表达式语句后续程序。if-else-if语句的执行过程如图3—3所示。【例5.5】charprintf("inputacharacter: printf("Thisisacontrolcharacter\n");elseif(c>='0'&&c<='9')printf("Thisisadigit\n");elseif(c>='A'&&c<='Z')printf("Thisisacapitalletter\n");elseif(c>='a'&&c<='z')printf("Thisisasmallletter\n");printf("Thisisanother}本例要求判别键盘输入字符的类可以根据输入字符的ASCII码来判别类ASCII码表可知ASCII值小32的为控制字符。在“0”和“9”之间的为数字,在“A”和“Z”之间为大写字母,在“a”和“z”之间为小写字母,其余则为其它字符。这是一个多分支选择的问题,用if-else-if语句编程,判断输入字符ASCII码所在的范围,分别给出不在三种形式的if语句中,在if关键字之后均为表达式。该表达式通常是逻辑表达式或关系表达式,但也可以是其它表达式,如赋值表达式等,甚至也可以是一个变量。if(a=5)if(b)在if语句的三种形式中,所有的语句应为单个语句,如果要想在满足条件时执行一组if语句的if语句;况,这时要特别注意ifelse的配对问题。intprintf("pleaseinputA,B: if(a>b)printf("A>B\n"); }三种选择即A>B、A<BA=B。这种问if-else-if语句也可以完成。而且程序更加清晰。intprintf("pleaseinputA,B: if(a==b)printf("A=B\n");elseif(a>b)printf("A>B\n");elseprintf("A<B\n");}条件运算符和条件表达 表达式1?表达式2:表达式 12if(a>b)max=a;elsemax=b;intprintf("\ninputtwonumbers: }语句语句}:语句语句case后的语句。如表达式的值与所有case后的常量表达式均不相同时,则执行defaultintprintf("inputintegernumber: switchcase1:printf("Monday\n");case2:printf("Tuesday\n");case4:printf("Thursday\n");case5:printf("Friday\n");case6:printf("Saturday\n");case7:printf("Sunday\n");}}本程序是要求输入一个数字,输出一个英文单词。但是当输入3之后,却执行了case3以及以后的所有语句,输出了Wednesday及以后的所有单词。这当然是不希望的。为什么会达式”只相当于一个语句标号,表达式的值和某标号相等则转向该标号执行,但不能在执switchcase还提供了一种break语句,于跳出switch语句,break语句只有关键字break,没有参数。在后面还将详细介绍。修改例题的程序,在每一case语句之后增break语句,使每一次执行之后均可跳出switch语句,从而避免输出不应有的结果。intprintf("inputintegernumber: switchcase1:printf("Monday\n");break;case2:printf("Tuesday\n");break;case4:printf("Thursday\n");break;case5:printf("Friday\n");break;case6:printf("Saturday\n");break;case7:printf("Sunday\n");break;}}程序举intprintf("inputthreenumbers: }本程序中,首先比较输入的a,b的大小,并把大数max,小数装min中,然后再与c比较,若maxc,则cmaxcmin,则把cminmax内总是最大数,而minmax和min的值即可。【例4.12】计算器程序。用户输入运算数和四则运算符,输出计算结果。charc;printf("inputexpression:a+(-,*,/)b\n");case'+':case'-':printf("%f\n",a-case'*':case'/':printf("%f\n",a/b);break;default:printf("inputerror\n");}}循环控 概 do-while语 循环的嵌 几种循环的比 continue语 程序举 循环控概gotogoto语句构成循goto语句标号;其中标号是一个有效的标识符,这个标识符加上一个“:”一起出现在函数内某处,执行个函数中,但可以不在一个循环层中。通常goto语句与if条件语句连用,当满足某一条件时,程序跳到标号处运行。goton { gotoloop;}}while语n {{}}#include<stdio.h>intprintf("inputastring:\n");while(getchar()!='\n')n++;}intprintf("\ninputn: while(n--printf("%d}do-whilewhilen {{}}{intsum=0,i;}}{intsum=0,i;}}forfor(表达式1;表达式2;表达式3)语句3)步;若其值为假(0),则结束循环,转到第5)步。for关系表达式,它决定什么时候退出循环;循环变量增量,定义循环控制变量每循环一次后按什么方式变化。这三个部分之间用;分开。for(i=1;i<=100;}1;1;}for循环中的“表达式1(循环变量赋初值)”、“表达式2(循环条件)”和“表达式3(循环的嵌{inti,j,k;printf("ijk\n");for(i=0;i<2;for(j=0;j<2;j++)for(k=0;k<2;k++)printf(“%d%d%d\n",i,j,}几种循环的比goto型循whiledo-whilewhiledo-while语句之前完成,而for语句可以在表达式1中实现循环变量的初始化。break语break语句通常用在循环语句和开关语句中。当break用于开关语句switch中时,可使程序跳switch而执switch以后的语句;如果没有break语句,则将成为一个死循环而无法退出。break在switch中的用法已面介绍开关语句时的例子中碰到,这里不再举例。breakif{charc; { {} printf("TheNo.is%d\n",}printf("The}breakcontinue{}{} {char {printf("%c\n",c);}}程序举1111 公式求π

{intfloatn,t,pi;}}N-S流程图:{intm,i,k;printf(“%disaprimenumber\n”,m);printf(“%disnotaprime}{intm,i,k,n=0;{}}数 一维数组的定义和...........................................................................................一维数组的定义方 一维数组元素的.......................................................................................一维数组的初始 一维数组程序举 二维数组的定义和...........................................................................................二维数组的定 二维数组元素的.......................................................................................二维数组的初始 二维数组程序举 字符数 字符数组的定 字符数组的初始 字符数组的.............................................................................................字符串和字符串结束标 字符数组的输入输 字符串处理函 程序举 本章小 数一维数组的定义和一维数组的定义方int float charch[20]; ch,20{inta;}05a[0],a[1],a[2],a[3],a[4]。#defineFD5{int}{intn=5;int}int一维数组元素的能逐个地使用下标变量,而不能一次整个数组。for(i=0;i<10;i++){inti,a[10];printf("%d}{inti,a[10];}{inti,a[10];printf("%dprintf("\n%d}量。当然第二个for语句也可以这样作,C语言允许用表达式表示下标。程序中最后一个printfa[5]的值,可以看出当下标不为整数时将自动取整。一维数组的初始inta[10]={0,1,2,3,4,5,6,7,8,9intintintintint一维数组程序举{inti,max,a[10];printf("input10numbers:\n");}本例程序中第一个for语句逐个输10个数到数组aa[0]max中。在第二个for语句中,从a[1]到a[9]逐个max中的内容比较,若比max的值大,则把该maxmaxmax的值。{intprintf("\ninput10numbers:\n");if(q<a[j]){p=j;q=a[j];}a[p]=s;}}}forfor句。第一个for语句用于输入10个元素的初值。第二个for语句用于排序。本程序的排序采用逐个比较的方法进行。在i次循环时,把第一个元素的下标i赋于p,而把该下标变量值a[i]赋于q。然后进入小循环,从a[i+1]起到最后一个元素止逐个与a[i]作比较,有比a[i]大者则将其下标送p,元素值送q。一次循环结束后,p即为最大元素的下标,q则为该元素值。若此时i≠p,说明p,q值均已不是进入小循环之前所赋之值,则交换a[i]和a[p]之值。a[i]i+1二维数组的定义和二维数组的定或造。下,组int量共有3×4个,即:二维数组元素的【例7.6】一个学组有5个人,每个人有三门课的考试成绩。求全组分科的平均成绩和张王李赵周C得各分科平均成绩,设变量average为全组各科总平均成绩。编程如下:{printf("inputscore\n");{}averageprintf("total:%d\n",average);}5v[i]之中,这就是该门课v[0],v[1],v[2]3二维数组的初始inta[5][3]={{80,75,92},{61,65,71},{59,63,70},{85,87,90},{76,77,85}inta[5][3]={{inti,j,s=0,int}printf("total:%d\n",average);}int102030a0100030intint如二维数组a[3][4],可分解为三个一维数组,其数组名分别为:一维数组a[0]的元素为a[0][0],a[0][1],a[0][2],a[0][3]。二维数组程序举字符数字符数组的定charchar字符数组的初始charc[10]={‘c’, ’,‘p’,‘r’,‘o’,‘g’,‘r’,数组 c[1]的值为charc[]={`c`,`C9字符数组的{intchar{}}字符串和字符串结束标charc[]={'c','charc[]={"Ccharc[]="C上面的数组c在内存中的实际存放情况为:Cprogram般无须指定数组的长度,而由系统自行处理。字符数组的输入输{}{charst[15];}inputthisisa{charst1[6],st2[6],st3[6],st4[6];printf("inputstring:\n");printf("%s%s%s%s\n",st1,st2,st3,st4);}设数c首地址为2000,也就是说c[0]单元地址为2000。则数组c代表这个首地址。因此在c前面不能再加地址运算符&。如写作scanf("%s",&c);则是错误的。在执行函数printf("%s",c)时,按数组名c找到首地址,然后逐个输出数组中各个字符直到遇到字符字符串处理函比较、转换、、搜索几类。使用这些函数可大大减轻编程的负担。用于输入输出的字符串函数,在使用前应包含头文件"stdio.h",使用其它字符串函数则应包含头文件字符串输出函数格式:puts【例7.12】{}printfprintf格式: 【例7.13】{char}scanf格式:strcat11后的串标志“\0”。本函数返回值是字符数组1的首地【例7.14】{staticcharst1[30]="Mynameis";intst2[10];printf("inputyourname:\n");}格式:strcpy1字符数名【例7.15】{charst1[15],st2[]="CLanguage";}格式:strcmp(1,字符串1=字符串2,返回值=0;【例7.16】{intstaticcharst1[15],st2[]="CLanguage";printf("inputastring:\n");if(k>0)printf("st1>st2\n");if(k<0)printf("st1<st2\n");}本程序中把输入的字符串和数组st2的串比较,比较结果返回到k根k值再输dbaseASCII“dBASE”大于“CLanguage”k〉0,格式:strlen(【例7.17】{intstaticcharst[]="Clanguage";printf("Thelenthofthestringis}程序举【例个比插入数小的元素i时,该元前即为插入位置。然后从数组最后一个元素开始到该元素{int{p=i;q=a[i];{}printf("%d}}本程序首先对数组a10个数从大到小排序并输出排序结果。然后输入要插入的整数n。再for语句n和数组元素逐个比较,如果发n>a[i]时,则由一个内循环把i以下各元素值顺次后移一个单元。后移应从后向前进行(从a[9]开始到a[i]为止)。后移结束跳出外循环。插入点为i,把n赋予a[i]即可。如所有的元素均大于入数,则并未进行过后移工作。此时i=10,结果是把n赋于a[10]。最后一个循环输出插入数后的数组各元素a=(3102512b=(87108{intintb[3],i,j,l;{printf("\narraya:\n");{for(j=0;j<=3;j++)}baforab。【例{inti,j,p;printf("inputcountry'sname:\n");{}}cs[5][20]为二维字符数组,可分为五cs[i]sti赋本章小称为下标变量。数组的类型是指下标变量取值的类型。函 概 函数定义的一般形 函数的参数和函数的 形式参数和实际参 函数的返回 函数的调 函数调用的一般形 函数调用的方 被调用函数的和函数原 函数的嵌套调 函数的递归调 数组作为函数参 局部变量和全局变 局部变 全局变 变量的类 动态方式与静态动态方 用static局部变 register变 概main(),但实用程序往往由多个函数组成。函数是C源程序的基本模块,通过对函提供了极为丰富的库函数TurboC,MSC都提供了三百多个库函数),还允许用户建立自己printf、scanf、getchar、putchar、gets、puts、strcat等函数均属此类。“void”。 执行总是从main函数开始,完成对其它函数的调用后再返回到main函数,最后由main函数结束整个程序。一个C源程序必须有,也只能有一个主函数main。函数定义的一般形 }void{printf("o,world}被其它函数调用时,输出oworld字符串。形式参数表列 形式参数表列 }intmax(inta,int{if(a>b)returna;elsereturnb;}值作为函数的值返回给主调函数。有返回值函数中至少应有一个return在C程序中,一个函数的定义可以放在任意位置,既可放在主函数main之前,也可放mainintmax(inta,int{elsereturnb;}{intmax(inta,intb);intx,y,z;printf("inputtwonumbers:\n");}程序15max函数定义。进入主函数后,因为准备max函数,故先对max函数进行说明(程序第8行)。函数定义和函数说明并不是一回事,在后面还要专门讨max函数,并把x,y中的值传送给maxa,b。max函数执行的结果(ab)将返回给变量z。最后由主函数输出z的值。函数的参数和函数的形式参数和实际参{int}ints(int{int}为实参,在调用时传送给s函数的形参量n(注意,本例的形参变量和实参变量的标识符都的初值也为100,在执行函数过程中,形参n的值变为5050。返回主函数之后,输出实参n的值仍为100。可见实参的值不随形参的变化而变化。函数的返回如调用正弦函数取得正弦值,调用例8.1的max函数取得的最大数等。对函数的值(或称函函数的值只能通过returnreturnreturn表达式 return(表达式); 该语句的功能是计算表达式的值并返回给主调函数在函数中允许有多个return不返回函数值的函数,可以明确定义为“空类型”,类型说明符为“void”。如voids(int{}例如,在定义s为空类型后,在主函数中写下述语句函数的调函数调用的一般形 函数调用的方算。这种方式要求函数是有返回值的。例如:z=max(x,y)是一个赋值表达式,把max的返回值赋予变量z。函数语句:函数调用的一般形式加上分号即构成函数语句。例如:printf("%d",a);scanf("%d",&b);都是以函数语句的方式调用函数。为实参进行传送,因此要求该函数必须是有返回值的。例如: 介绍printf函数时已提到过,这里从函数调用的角度再强调一下。{int}877898898,7,7,8。上述问题如还不理解,上机一试就明白了。被调用函数的和函数原在主调函数中调用某函数之前应对该被调函数进行说明(,这与使用变量之前要 类型说明符被调函数名(类型形参,类型形参…); 类型说明符被调函数名(类型,类型…); intmax(inta,int mainmaxintmax(inta,intb)。charstr(inta);floatf(floatb);{}charstr(int{}floatf(float{}strf函数的嵌套调图表示了两层嵌套的情形。其执行过程是:执行main函数中调用a函数的语句时,即转去执行a函数,在a函数中调用b函数时,又转去执行b函数,b函数执行完毕返回a函数的断点继续执行,a函数执行完毕返回main函数的断点继续执行。 f1,另一个是用来计算阶乘值的然后返回f1,再返回主函数,在循环程序中计算累加和。longf1(int{intk;longreturnr;}longf2(int{inti;return}{inti;}f2i值作为实参调用函数f1i值。在f1中又发生对函数f2i的值作为实参去调f2,在f2中完成求i的计算。22 22 函数的递归调intf(int{inty;}用递归法计算n!可用下述公式表示:n!=1(n=0,1)n×(n-1)!longff(int{longif(n<0)printf("n<0,inputerror");elseif(n==0||n==1)f=1;}{intn;longprintf("\ninputainteagernumber:\n");}程序中给出的函数ff是一个递归函数。主函数调用ff后即进入函数ff执行,如果n<0,n==0n=1ff函数自身。由于每次递归调用语句即为y=ff(5)ff函数n=5,不等于01f=ff(n-1)*n,即f=ff(5-1)*5。该语句对ff作递归调用即ff(4)。回主调函数。ff(1)的函数返回值为1,ff(2)的返回值为1*2=2,ff(3)的返回值为2*3=6,ff(4)的返回值为6*4=24,最后返回值ff(5)为24*5=120

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论