配色: 字号:
C程序课件第4章顺序
2012-04-24 | 阅:  转:  |  分享 
  
第四章顺序程序设计一、C语句概述二、赋值语句三、数据输出语句四、数据输入语句五、顺序结构程序设计六、本章要点例E
X4_3输出字符型数据的值。voidmain(){ chara=''B'',b=''o'',c=''k''; putchar(a)
;putchar(b); putchar(b);putchar(c);putchar(''\t''); putchar(a)
;putchar(b);putchar(''\n''); putchar(b);putchar(c);}C语言的数据输
入也是由函数语句完成的。本节介绍从标准输入设备-键盘上输入数据的函数scanf和getchar。scanf函数称为格式输入函
数,即按用户指定的格式从键盘上把数据输入到指定的变量之中。scanf函数的一般形式为:scanf(“格式控制字符串
”,地址表列);1、scanf函数的一般形式scanf函数是一个标准库函数,它的函数原型在头文件“stdio.h
”中,与printf函数相同,在使用scanf函数之前必须包含“stdio.h”文件。其中,格式控制字符串的作用与printf
函数相同,但不能显示非格式字符串,也就是不能显示提示字符串。地址表列中给出各变量的地址。地址是由地址运算符“&”后跟变量名组成的。
例如,&a,&b分别表示变量a和变量b的地址。这个地址就是编译系统在内存中给a,b变量分配的地址。在C语言中,使用了地址这个概念
,这是与其它语言不同的。应该把变量的值和变量的地址这两个不同的概念区别开来。变量的地址是C编译系统分配的,用户不必关心具体的地址
是多少。变量的地址和变量值的关系如下:&a=>a<=567,a为变量名,567是变量的值,&a是变量a的地址。在赋值表达式中给变量
赋值,如:a=567在赋值号左边是变量名,不能写地址,而scanf函数在本质上也是给变量赋值,但要求写变量的地址,如&a。这两者在
形式上是不同的。&是一个取地址运算符,&a是一个表达式,其功能是求变量的地址。例4_4scanf函数的使用方法voidma
in(){ inta,b,c; printf("inputa,b,c\n"); scanf("%d%d%d",&a,&b
,&c); printf("a=%d,b=%d,c=%d",a,b,c);}注意&的用法!在本例中,由于scanf函
数本身不能显示提示串,故先用printf语句在屏幕上输出提示,请用户输入a、b、c的值。执行scanf语句,则退出TC屏幕进入用户
屏幕等待用户输入。用户输入7、8、9后按下回车键,此时,系统又将返回TC屏幕。在scanf语句的格式串中由于没有非格式字符在“%d
%d%d”之间作输入时的间隔,因此在输入时要用一个以上的空格或回车键作为每两个输入数之间的间隔。如:789或7>89其中表示回车。最好的方法是在格式符之间用逗号分隔,即“%d,%d,%d”,在输入数据时也以逗
号间隔,如:7,8,9。其中有方括号[]的项为任选项。各项的意义如下:1)、类型表示输入数据的类型,其格式符和意
义下表所示。格式 字符意义d 输入十进制整数o 输入八进制整数x 输入十六进制整数u 输
入无符号十进制整数f或e 输入实型数(用小数形式或指数形式)c 输入单个字符s 输入字符串2、格式字符串
格式字符串的一般形式为:%[][输入数据宽度][长度]类型3)、宽度用十进制整数指定输入的宽度(即字符数)。例如:
scanf("%5d",&a);输入:12345678只把12345赋予变量a,其余部分被截去。又如:scanf("%4d%
4d",&a,&b);输入:12345678将把1234赋予a,而把5678赋予b。2)、“”符用以表示该输入项读入后不赋
予相应的变量,即跳过该输入值。如scanf("%d%d%d",&a,&b);当输入为:123时,把1赋予a,2被跳过,
3赋予b。A、scanf函数中没有精度控制,如:scanf("%5.2f",&a);是非法的。不能企图用此语句输入小数为2位的
实数。4)、长度长度格式符为l和h,l表示输入长整型数据(如%ld)和双精度浮点数(如%lf)。h表示输入短整型数据。使用
scanf函数还必须注意以下几点:B、scanf中要求给出变量地址,如给出变量名则会出错。如scanf("%d",a);是非法
的,应改为scnaf("%d",&a);才是合法的。D、在输入字符数据时,若格式控制串中无非格式字符,则认为所有输入的字符均为有
效字符。例如:scanf("%c%c%c",&a,&b,&c);输入为:def则把''d''赋予a,''''赋予b,''e''赋予
c。只有当输入为:def时,才能把''d''赋于a,''e''赋予b,''f''赋予c。如果在格式控制中加入空格作为间隔,如scanf
("%c%c%c",&a,&b,&c);则输入时各数据之间可加空格。C、在输入多个数值数据时,若格式控制串中没有非格式字符作
输入数据之间的间隔则可用空格,TAB或回车作间隔。C编译在碰到空格,TAB,回车或非法数据(如对“%d”输入“12A”时,A即为非
法数据)时即认为该数据结束。例4_4_2scanf函数的使用方法voidmain(){ chara,b; prin
tf("inputcharactera,b\n"); scanf("%c%c",&a,&b); printf("%c%c\
n",a,b);}printf("%c%c\n",a,b);由于scanf函数"%c%c"中没有空格,输入MN,结果输出
只有M。而输入改为MN时则可输出MN两字符,见下面的输入运行情况。例4_4_3scanf函数的使用方法voidmain(
){ chara,b; printf("inputcharactera,b\n"); scanf("%c%c",&a
,&b); printf("\n%c%c\n",a,b);}本例表示scanf格式控制串"%c%c"之间有空格时,
输入的数据之间可以有空格间隔。F、如输入的数据与输出的类型不一致时,虽然编译能够通过,但结果将不正确。E、如果格式控制串中有非
格式字符则输入时也要输入该非格式字符。例如:scanf("%d,%d,%d",&a,&b,&c);其中用非格式符“,”作间
隔符,故输入时应为:5,6,7又如:scanf("a=%d,b=%d,c=%d",&a,&b,&c);则输入应为a=
5,b=6,c=7例4_4_4scanf函数的使用方法voidmain(){ inta; printf("
inputanumber\n"); scanf("%d",&a); printf("%ld\n",a);}由于
输入数据类型为整型,而输出语句的格式串中说明为长整型,因此输出结果和输入数据不符。如改动程序如下:例4_4_5scanf函数
的使用方法voidmain(){ longa; printf("inputalonginteger:\n");
scanf("%ld",&a); printf("%ld\n",a);}运行结果为:inputalonginteger
:12345678901234567890当输入数据改为长整型后,输入输出数据相等。getchar函数的功能是从键盘上输入一
个字符。其一般形式为: getchar();3、键盘输入函数通常把输入的字符赋予一个字符变量,构成赋值语句,如:
charc;c=getchar();例EX4_5putchar函数的使用方法#includev
oidmain(){ charc; printf("inputacharacter\n"); c=getchar()
; putchar(c);}使用getchar函数还应注意几个问题:1、getchar函数只能接受单个字符,输入数
字也按字符处理。输入多于一个字符时,只接收第一个字符。2、使用本函数前必须包含文件“stdio.h”。3、
在TC屏幕下运行含本函数程序时,将退出TC屏幕进入用户屏幕等待用户输入。输入完毕再返回TC屏幕。例EX4_6输入输出函数的使
用。voidmain(){ chara,b,c; printf("inputcharactera,b,c\n");
scanf("%c%c%c",&a,&b,&c); printf("%d,%d,%d\n%c,%c,%c\n",
a,b,c,a-32,b-32,c-32);}例EX4_7输出各种数据类型的字节长度。voidmain(){ in
ta;longb;floatf; doubled;charc; printf("%d,%d,%d,%d,%
d", sizeof(a),sizeof(b),sizeof(f), sizeof(d),sizeof(c));
}C程序设计数学系计算机系列课程课件之一本章要点4.1C语句概述4.2赋值语句4.3数据输出语
句4.4数据输入语句4.5顺序结构程序设计本章介绍C语言程序设计的基本方法和基本的程序语句。
和其他高级语言一样,C语言的语句用来向计算机系统发出操作指令。一个语句经编译后产生若干条机器指令。一个实际程序应当包含若干语句。
应当指出,C语句都是用来完成一定任务定的。声明部分的内容不应称为语句。一个函数包含声明部分和执行部分,执行部分即由语句组成。
程序应该包括数据描述(由声明部分实现)和数据操作(由语句实现)。数据描述主要定义数据结构(用数据类型表示)和数据初值,数据操作
的任务是对已提供的数据进行加工。从程序流程的角度来看,程序可以分为三种基本结构,即顺序结构、分支结构、循环结构。这三种基
本结构可以组成所有的各种复杂程序。C语言提供了多种语句来实现这些程序结构。本章介绍这些基本语句及其应用,使读者对C程序有一个初
步的认识,为后面各章的学习打下基础。C语句可分为以下五类:C程序的执行部分是由语句组成的。程序的功能也是由
执行语句实现的。5)、空语句1)、表达式语句2)、函数调用语句3)、控制语句4)、复合语句1、表达式语
句表达式语句由表达式加上分号“;”组成。其一般形式为:表达式;执行表达式语句就是计算表达式的值。例如:x=y+z;赋
值语句,计算结果赋予变量x;y+z;加法运算语句,计算结果不能保留,无实际意义;i++;自增1语句,i值增1,值保留在i中。
由函数名、实际参数加上分号“;”组成。其一般形式为:函数名(实际参数表);执行函数语句就是调用函数体并把实
际参数赋予函数定义中的形式参数,然后执行被调函数体中的语句,求取函数值。(在第八章函数中再详细介绍)例如printf("
CProgram");调用库函数,输出字符串。2、函数调用语句控制语句用于控制程序的流程,以实现程序的各种结构方式。它
们由特定的语句定义符组成。C语言有九种控制语句。可分成以下三类:(1)条件判断语句:if语句,switch语句。
(2)循环执行语句:while语句,dowhile语句,for语句。(3)转向语句:break语句,goto
语句,continue语句,return语句。3、控制语句把多个语句用括号{}括起来组成的一个语句称复合语句。
在程序中应把复合语句看成是单条语句,而不是多条语句,例如: { x=y+z;a=b+c; printf(“%d,
%d”,x,a); }是一条复合语句。复合语句内的各条语句都必须以分号“;”结尾,在括号“}”外不能加分号。4
、复合语句只有分号“;”组成的语句称为空语句。空语句是什么也不执行的语句。在程序中空语句可用来作空循环体。
例如while(getchar()!=''\n'');本语句的功能是,只要从键盘输入的字符不是回车则重新输入。这里的循环体为空语句
。5、空语句C语言允许一行写几个语句,也允许一个语句拆开写在几行上,书写格式无固定要求,但初学时应注意书写格式。
赋值语句的功能是将右边表达式的值赋予左边的变量(即将表达式的值存储到变量所指的存储单元中)。这里表达式的含义是广义的,它可以是
一个数值,变量或表达式。也就是说,赋值语句的右边可以是数值或变量或表达式,而它的左边只能是一个(仅此一个)变量,它是程序中使用最多
的语句之一。赋值语句是由赋值表达式再加上分号构成的表达式语句。其一般形式为:变量=表达式;2、由于在赋值符
“=”右边的表达式也可以又是一个赋值表达式,因此,下述形式: 变量=(变量=表达式);是成立的,从而形成嵌套
的情形。将其展开之后的一般形式为:变量=变量=…=表达式;在赋值语句的使用中需要注意以下几点:1
、C语言中的赋值号“=”是一个运算符,在其他大多数语言中赋值号不作为运算符;例如:a=b=c=d=e=
5;按照赋值运算符的右结合性,因此实际上等效于: e=5;d=e;c=d;b=c;a=b;
4、在变量说明中,不允许连续给多个变量赋初值。如下述说明是错误的:inta=b=c=5;必须写为inta=5,b
=5,c=5;而赋值语句允许连续赋值。3、注意在变量说明中给变量赋初值和赋值语句的区别。给变量赋初值是变
量说明的一部分,赋初值后的变量与其后的其它同类变量之间仍必须用逗号间隔,而赋值语句则必须用分号结尾。下述语句是合法的:if((
x=y+5)>0)z=x;语句的功能是,若表达式x=y+5大于0则z=x。下述语句是非法的:if((x=y+5;)>0)
z=x;因为x=y+5;是语句,不能出现在表达式中。5、注意赋值表达式和赋值语句的区别。赋值表达式是一种表达式,它可以
出现在任何允许表达式出现的地方,而赋值语句则不能。数据的输入和输出是计算机完成数据操作的关键,在C语言中完成数据的输入和
输出是通过以下手段来实现的:(1)、所谓输入输出是以计算机主机为主体而言的。从计算机向外部输出设备(如显示器、打印机、磁
盘等)输出数据称为“输出”,从外部向输入设备(如键盘、鼠标、磁盘等)输入数据称为“输入”,通常把这些设备称为标准设备。(
2)、C语言本身不提供输入输出语句,输入和输出操作是由函数来实现的。在C标准函数库中提供了一些输入输出函数,以方便用户使用。
在C语言函数库中有一批“标准输入输出函数”,它是以标准的输入输出设备为输入输出对象的。其中有printf(格式输出),put
char(输出字符),puts(输出字符串),scanf(格式输入),getchar(输入字符),gets(输入字符串)。
(3)、在使用C语言库函数时,要用预编译命令“#include”将有关“头文件”包含到用户编写的源程序文件中。在头文件中包含了与
用到的函数有关的信息。如在使用标准输入输出库函数时要用到“stdio.h”文件,则在文件开头应有预编译命令:#inclu
de或#include“stdio.h”。stdio.h是standardinput&outpu
t的缩写,h是head的缩写。本小节先介绍printf函数和putchar函数。printf函数称为格式输出函数,其关键字最末
一个字母f即为“格式”(format)之意。其功能是按用户指定的格式,把指定的数据显示到显示器屏幕上。在前面的例题中我们已多次使用
过这个函数。1、printf函数的一般形式printf函数是一个标准库函数,它的函数原型在头文件“stdio.h”中。
因此在使用printf函数之前必须包含“stdio.h”文件,即在每一个程序开头有#include语句。
printf函数调用的一般形式为: printf(“格式控制字符”,输出表列);其中格式控制字符用于指定
输出格式。格式控制字符可由格式字符串和非格式字符串两种组成。格式字符串是以%开头的字符串,在%后面跟有各种格式字符,以说明输出数据
的类型、形式、长度、小数位数等。如“%d”表示按十进制整型输出,“%ld”表示按十进制长整型输出,“%c”表示按字符型输出等。后面
将专门给予讨论。非格式字符串在输出时原样照印,在显示中起提示作用。输出表列中给出了各个输出项,要求格式字符串和各输出项在数量
和类型上应该一一对应。例EX4_1输出两个数的值。voidmain(){ inta=88,b=89; printf(
“%d%d\n”,a,b); printf("%d,%d\n",a,b); printf(“%c,%c\n”,a,b); pr
intf("a=%d,b=%d\n",a,b);}由于printf是函数,因此“格式控制”字符串和“输出表列”实际上都
是函数的参数。printf函数的一般形式可以表示为:printf(参数1,参数2,参数3,…参数n
);在TurboC中格式字符串的一般形式为:[标志][输出最小宽度][.精度][长度]类型其
中方括号[]中的项为可选项。各项的意义介绍如下:2、格式字符1)、类型字符用以表示输出数据的类型,其格式符和意义下表所示:
表示输出类型的格式字符 格式字符意义d 以十进制形式输出带符号整数(正数不输出符号)o 以八进制形式输出无符号整数(不输出前
缀0)x 以十六进制形式输出无符号整数(不输出前缀0X)u 以十进制形式输出无符号整数f 以小数形式输出单、双精度实数e
以指数形式输出单、双精度实数g 以%f%e中较短的输出宽度输出单、双精度实数c 输出单个字符s 输出字符串2)、标志标志
字符为-、+、#、空格四种,其意义下表所示:标志格式字符标志意义- 结果左对齐,右边填空格+ 输出符
号(正号或负号)空格输出值为正 时冠以空格,为负时冠以负号# 对c,s,d,u类无影响;对o类,在输 出时加前缀o
对x类,在输出时加前缀0x;对e,g,f类 当结果有小数时才给出小数点3)、输出最小宽度用十进制整数来表示输
出的最少位数。若实际位数多于定义的宽度,则按实际位数输出,若实际位数少于定义的宽度则补以空格或0。4)、精度精度格
式符以“.”开头,后跟十进制整数。本项的意义是:如果输出数字,则表示小数的位数;如果输出的是字符,则表示输出字符的个数;若实际位数
大于所定义的精度数,则截去超过的部分。5)、长度长度格式符为h,l两种,h表示按短整型量输出,l表示按长整型量输出。
例EX4_2_1输出各种类型数据的值。voidmain(){ inta=15;floatb=138.3576278;
doublec=35648256.3645687; chard=''p''; printf("a=%d,%5d,%o,%
x\n",a,a,a,a); printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b); printf("
c=%lf,%f,%8.4lf\n",c,c,c); printf("d=%c,%8c\n",d,d);}例EX4_2_2输
出各种类型数据的值。main(){ inta=29;floatb=1243.2341; doublec=24212345.24232; chard=''h''; printf("a=%d,%5d,%o,%x\n",a,a,a,a); printf("b=%f,%lf,%5.4lf,%e\n",b,b,b,b); printf("c=%lf,%f,%8.4lf\n",c,c,c); printf("d=%c,%8c\n",d,d);}使用printf函数时还要注意一个问题,那就是输出表列中的求值顺序。不同的编译系统不一定相同,可以从左到右,也可从右到左。TurboC是按从右到左进行的。如把例3_11_3改写如下述形式:voidmain(){ inti=8; printf("%d\n%d\n%d\n%d\n%d\n%d\n", ++i,--i,i++,i--,-i++,-i--);}例如:putchar(''A''); 输出大写字母A putchar(x); 输出字符变量x的值 putchar(‘\n’); 换行对控制字符则执行 控制功能,不在屏幕上显示使用本函数前必须要用文件包含命令: #include3、字符输出函数putchar函数是字符输出函数,其功能是在显示器上输出单个字符。其一般形式为:putchar(字符变量);
献花(0)
+1
(本文系紫霄书屋首藏)