c语言C语言的数据.pptx

上传人:莉*** 文档编号:73648876 上传时间:2023-02-21 格式:PPTX 页数:60 大小:206.28KB
返回 下载 相关 举报
c语言C语言的数据.pptx_第1页
第1页 / 共60页
c语言C语言的数据.pptx_第2页
第2页 / 共60页
点击查看更多>>
资源描述

《c语言C语言的数据.pptx》由会员分享,可在线阅读,更多相关《c语言C语言的数据.pptx(60页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、3.1 程序设计概述一个程序应包括对数据的描述和对数据处理的描述。1对数据的描述,即数据结构。数据结构是计算机学科的核心课程之一,有许多专门著作论述,本课程就不再赘述。在C语言中,系统提供的数据结构,是以数据类型的形式出现的。2对数据处理的描述,即计算机算法。算法是为解决一个问题而采取的方法和步骤,是程序的灵魂。为此,著名计算机科学家沃思(Nikiklaus Wirth)提出一个公式:数据结构+算法=程序 实际上,一个程序除了数据结构和算法外,还必须使用一种计算机语言,并采用结构化方法来表示。第1页/共60页3.2 C语言的数据类型C语言提供的数据结构,是以数据类型形式出现的。具体分类如下:1

2、.基本类型分为整型、实型(又称浮点型)、字符型和枚举型四种。2.构造类型分为数组类型、结构类型和共用类型三种。3.指针类型。4.空类型C语言中的数据,有常量和变量之分,它们分别属于上述这些类型。本章将介绍基本类型中的整型、实型和字符型三种数据。第2页/共60页3.3 常量和变量3.3.1 常量 1.常量的概念 在程序运行过程中,其值不能被改变的量称为常量。2.常量的分类 (1)整型常量(2)实型常量(3)字符常量。(4)符号常量。常量的类型,可通过书写形式来判别。3.3.2 变量1.变量的概念在程序运行过程中,其值可以被改变的量称为变量。2.变量的两个要素第3页/共60页(1)变量名。每个变量

3、都必须有一个名字变量名,变量命名遵循标识符命名规则。(2)变量值。在程序运行过程中,变量值存储在内存中。在程序中,通过变量名来引用变量的值。.标识符命名规则(1)有效字符:只能由字母、数字和下划线组成,且以字母或下划线开头。(2)有效长度:随系统而异,但至少前个字符有效。如果超长,则超长部分被舍弃。例如,由于student_name和student_number的前个字符相同,有的系统认为这两个变量,是一回事而不加区别。在TC V2.0中,变量名(标识符)的有效长度为个字符,缺省值为。第4页/共60页(3)C语言的关键字不能用作变量名。注意:C语言对英文字母的大小敏感,即同一字母的大小写,被认

4、为是两个不同的字符。习惯上,变量名和函数名中的英文字母用小写,以增加可读性。思考题:在C语言中,变量名total与变量名TOTAL、ToTaL、tOtAl等是同一个变量吗?标识符命名的良好习惯见名知意:所谓“见名知意”是指,通过变量名就知道变量值的含义。通常应选择能表示数据含义的英文单词(或缩写)作变量名,或汉语拼音字头作变量名。例如,name/xm(姓名)、sex/xb(性别)、age/nl(年龄)、salary/gz(工资)。第5页/共60页4.变量的定义与初始化在语言中,要求对所有用到的变量,必须先定义、后使用;且称在定义变量的同时进行赋初值的操作为变量初始化。(1)变量定义的一般格式

5、存储类型 数据类型 变量名,变量名2;例如,float radius,length,area;(2)变量初始化的一般格式存储类型 数据类型 变量名=初值,变量名2=初值2;例如,float radius=2.5,length,area;第6页/共60页3.4 整型数据3.4.1 整型变量 1.分类 根据占用内存字节数的不同,整型变量又分为类:(1)基本整型(类型关键字为int)。(2)短整型(类型关键字为short int)。(3)长整型(类型关键字为long int)。(4)无符号整型。无符号型又分为无符号基本整型(unsigned int)、无符号短整型(unsigned short)和无

6、符号长整型(unsigned long)三种,只能用来存储无符号整数。2.占用内存字节数与值域 上述各类型整型变量占用的内存字节数,随系统而异。在16位操作系统中,一般用字节表示一个int型变量,且long型(字节)int型(字节)short型(字节)。第7页/共60页显然,不同类型的整型变量,其值域不同。占用内存字节数为n的(有符号)整型变量,其值域为:-2n*8-1(2n*8-1-1);无符号整型变量的值域为:0(2n*8-1)。例如,PC机中的一个int型变量,其值域为-22*8-1(22*8-1-1),即-3276832767;一个unsigned型变量的值域为:0(22*8-1),即

7、065535。3.4.2 整型常量.三种表示形式整型常量即整常数,在语言中可用三种形式表示:(1)十进制。例如10、36。(2)八进制(以数字开头)。例如012。(3)十六进制(以数字+小写字母x开头)。例如0 x36。第8页/共60页.分类(1)基本整型。在16位机中,用2字节存储,其数据范围与int型变量一样。(2)长整型(在数值后面加“L(l)”)。对超出基本整型值域的整型常量,可使用长整型常量表示,其取值范围可达-(-)。例如,123l、315等。.类型匹配规则类型匹配规则为:一个整型常量,可以赋给能容纳下其值的整型变量。例如,其值在-(-)的整型常量,可以赋给int型变量和long

8、int型变量;其值在-(-)的整型常量,就只能赋给long int型变量。注意:常量无unsigned型。但一个非负整型常量,只要它的值不超过相应变量的值域(即取值范围),也可以赋给unsigned型变量。第9页/共60页3.5 实型数据3.5.1 实型变量 语言的实型变量,分为两种:(1)单精度型。类型关键字为float,一般占字节(位)、提供位有效数字。(2)双精度型。类型关键字为double,一般占个字节、提供1516位有效数字。3.5.2 实型常量 .表示形式实型常量即实数,在语言中又称浮点数,其值有两种表达形式:(1)十进制形式。例如3.14、9.8。(2)指数形式:E(e)。例如3

9、.0+5等。.关于类型 实型常量不分float型和double型。一个实型常量,可以赋给一个实型变量(float型或double型)。第10页/共60页3.6 字符型数据3.6.1 字符常量1.字符常量的定义用一对单引号括起来的单个字符,称为字符常量。例如,A、等。2.转义字符语言还允许使用一种特殊形式的字符常量,就是以反斜杠“”开头的转义字符。注意:如果反斜杠或单引号本身作为字符常量,必须使用转义字符:、。案例3.1 用转义字符输出可打印字符和不可打印字符。/*程序功能:用转义字符输出可打印字符和不可打印字符*/第11页/共60页main()printf(“x4Fx4Bx21n”);/*等价

10、于printf(“OK!n”);*/printf(“x15 xABn”);程序运行结果如下:!3.6.2 字符变量字符变量的类型关键字为char,一般占用1字节内存单元。1.变量值的存储 字符变量用来存储字符常量。将一个字符常量存储到一个字符变量中,实际上是将该字符的ASCII码值(无符号整数)存储到内存单元中。例如,char ch1,ch2;/*定义两个字符变量:ch1,ch2*/ch1=a;ch2=b;/*给字符变量赋值*/第12页/共60页2.特性字符数据在内存中存储的是字符的ASCII码 一个无符号整数,其形式与整数的存储形式一样,所以语言允许字符型数据与整型数据之间通用。(1)一个字

11、符型数据,既可以字符形式输出,也可以整数形式输出。案例3.2 字符变量的字符形式输出和整数形式输出。/*程序功能:用字符形式和整数形式输出字符变量*/main()char ch1,ch2;ch1=a;ch2=b;printf(“ch1=%c,ch2=%cn”,ch1,ch2);printf(“ch1=%d,ch2=%dn”,ch1,ch2);程序运行结果:ch1=a,ch2=b ch1=97,ch2=98 第13页/共60页 案例3.3 字符数据的算术运算。/*程序功能:字符数据的算术运算*/main()char ch1,ch2;ch1=a;ch2=B;/*字母的大小写转换*/printf(“

12、ch1=%c,ch2=%cn”,ch1-32,ch2+32);/*用字符形式输出一个大于256的数值*/printf(ch1+200=%dn,ch1+200);printf(ch1+200=%cn,ch1+200);printf(ch1+256=%dn,ch1+256);printf(ch1+256=%cn,ch1+256);(2)允许对字符数据进行算术运算,此时就是对它们的ASCII码值进行算术运算。第14页/共60页程序运行结果:ch1=A,ch2=bch1+200=297ch1+200=)ch1+256=353ch1+256=a 思考题:用字符形式输出一个大于256的数值,会得到什么结果

13、?第15页/共60页1.字符串常量的概念和字符串长度字符串常量是用一对双引号括起来的若干字符序列。字符串中字符的个数称为字符串长度。长度为0的字符串(即一个字符都没有的字符串)称为空串,表示为“”(一对紧连的双引号)。例如,“How do you do.”、“Good morning.”等,都是字符串常量,其长度分别为14和13(空格也是一个字符)。如果反斜杠和双引号作为字符串中的有效字符,则必须使用转义字符。例如:(1)C:msdosv6.22 C:msdosv6.22 (2)I say:Goodbye!I say:Goodbye!“3.6.3 字符串常量第16页/共60页2.字符串的存储C

14、语言规定:在存储字符串常量时,由系统在字符串的末尾自动加一个0作为字符串的结束标志。注意:在源程序中书写字符串常量时,不必加结束字符0,否则画蛇添足。如果有一个字符串为“CHINA”,则它在内存中的实际存储如下所示:最后一个字符0是系统自动加上的,它占用字节而非字节内存空间。0ANIHC第17页/共60页综上所述,字符常量A与字符串常量A是两回事:(1)定界符不同:字符常量使用单引号,而字符串常量使用双引号;(2)长度不同:字符常量的长度固定为1,而字符串常量的长度,可以是0,也可以是某个整数;(3)存储要求不同:字符常量存储的是字符的ASCII码值,而字符串常量,除了要存储有效的字符外,还要

15、存储一个结束标志0。第18页/共60页3.7 算术运算与算术表达式在语言中,除控制语句和输入输出函数外,其它所有基本操作都作为运算符处理。1.五种基本算术运算符 +、-(减法/取负)、*、/、%(求余数)(1)关于除法运算/C语言规定:两个整数相除,其商为整数,小数部分被舍弃。例如,5/2=2。(2)关于求余数运算要求两侧的操作数均为整型数据,否则出错。2.表达式和算术表达式(1)表达式的概念 用运算符和括号将运算对象(常量、变量和函数等)连接起来的、符合语言语法规则的式子,称为表达式。第19页/共60页 单个常量、变量或函数,可以看作是表达式的一种特例。将单个常量、变量或函数构成的表达式称为

16、简单表达式,其它表达式称之为复杂表达式。(2)算术表达式的概念表达式中的运算符都是算术运算符。例如,3+6*9、(x+y)/2-1等,都是算术表达式。良好的源程序书写习惯:在表达式中,在双目运算符的左右两侧各加一个空格,可增强程序的可读性。请比较表达式“(x+y)/2 1”与“(x+y)/21”,您认为哪个的可读性更好一些?第20页/共60页(1)语言规定了运算符的优先级和结合性。所谓结合性是指,当一个操作数两侧的运算符具有相同的优先级时,该操作数是先与左边的运算符结合,还是先与右边的运算符结合。自左至右的结合方向,称为左结合性。反之,称为右结合性。结合性是语言的独有概念。除单目运算符、赋值运

17、算符和条件运算符是右结合性外,其它运算符都是左结合性。(2)表达式求值1)按运算符的优先级高低次序执行。例如,先乘除后加减。2)如果在一个运算对象(或称操作数)两侧的运算符的优先级相同,则按语言规定的结合方向(结合性)进行。例如,算术运算符的结合方向是“自左至右”,即:在执行“a b+c”时,变量b先与减号结合,执行“a-b”;然后再执行加c的运算。3.运算符的优先级与结合性第21页/共60页(1)在语言中,整型、实型和字符型数据间可以混合运算(因为字符数据与整型数据可以通用)。如果一个运算符两侧的操作数的数据类型不同,则系统按“先转换、后运算”的原则,首先将数据自动转换成同一类型,然后在同一

18、类型数据间进行运算。转换规则如图2-5所示。1)横向向左的箭头,表示必须的转换。char和short 型必须转换成 int 型,float型必须转换成double型。2)纵向向上的箭头,表示不同类型的转换方向。例如,int型与double型数据进行混合运算,则先将int型数据转换成double型,然后在两个同类型的数据间进行运算,结果为double型。注意:箭头方向只表示数据类型由低向高转换,不要理解为int型 先 转 换 成 unsigned型,再 转 换 成 long型,最 后 转 换 成double型。4.数据类型转换第22页/共60页(2)除自动转换外,语言也允许强制转换。数据类型强制

19、转换的一般格式为:(要转换成的数据类型)(被转换的表达式)当被转换的表达式是一个简单表达式时,外面的一对圆括号可以缺省。例如,(double)a(等价于(double)(a)/*将变量a的值转换成double型*/(int)(x+y)/*将x+y的结果转换成int型*/(float)5/2(等价于(float)(5)/2)/*将5转换成实型,再除以2(=2.5)*/(float)(5/2)/*将5整除2的结果(2)转换成实型(2.0)*/注意:强制转换类型得到的是一个所需类型的中间量,原表达式类型并不发生变化。例如,(double)a 只是将变量a的值转换成一个double型的中间量,其数据类

20、型并未转换成double型。第23页/共60页3.8 赋值运算与赋值表达式 1.赋值运算 赋值符号“=”就是赋值运算符,它的作用是将一个表达式的值赋给一个变量。赋值运算符的一般形式为:变量 =赋值表达式 例如,x=5 y=(float)5/2 如果表达式值的类型,与被赋值变量的类型不一致,但都是数值型或字符型时,系统自动地将表达式的值转换成被赋值变量的数据类型,然后再赋值给变量。思考题:假设变量num的数据类型为float,其值为2.5,则执行“num=(int)num”后,num的值等于多少?第24页/共60页复合赋值运算符是由赋值运算符之前再加一个双目运算符构成的。复合赋值运算的一般格式为

21、:变量 双目运算符=表达式 复合赋值运算符它等价于:变量=变量 双目运算符(表达式)。当表达式为简单表达式时,表达式外的一对圆括号才可缺省,否则可能出错。例如,x+=3 /*等价于x=x+3*/y*=x+6/*等 价 于 y=y*(x+6),而 不 是y=y*x+6*/C语言规定的10种复合赋值运算符如下:+=,-=,*=,/=,%=;/*复合算术运算符(5个)*/&=,=,|=,=;/*复合位运算符(5个)*/2.复合赋值运算第25页/共60页由赋值运算符或复合赋值运算符,将一个变量和一个表达式连接起来的表达式,称为赋值表达式。(1)一般格式 变量 (复合)赋值运算符 表达式(2)赋值表达式

22、的值任何一个表达式都有一个值,赋值表达式也不例外。被赋值变量的值,就是赋值表达式的值。例如,“a=5”这个赋值表达式,变量a的值“”就是它的值。3.赋值表达式第26页/共60页3.9 C语言特有的运算和运算符3.9.1 自增(+)、自减(-)运算 1.作用 自增运算使单个变量的值增,自减运算使单个变量的值减。2.用法与运算规则 自增、自减运算符都有两种用法:(1)前置运算运算符放在变量之前:变量、变量 先使变量的值增(或减),然后再以变化后的值参与其它运算,即先增减、后运算。(2)后置运算运算符放在变量之后:变量、变量 变量先参与其它运算,然后再使变量的值增(或减),即先运算、后增减。第27页

23、/共60页main()int x=6,y;printf(x=%dn,x);/*输出x的初值*/y=+x;/*前置运算*/printf(y=+x:x=%d,y=%dn,x,y);y=x-;/*后置运算*/printf(y=x-:x=%d,y=%dn,x,y);程序运行结果:x=6y=+x:x=7,y=7y=x-:x=6,y=7 案例3.4 自增、自减运算符的用法与运算规则示例。/*程序功能:自增、自减运算符的用法与运算规则示例*/第28页/共60页思考题:如果将案例“y=+x;”语句中的前置运算改为后置(y=x+;),“y=x-;”语句中的后置运算改为前置(y=-x;),程序运行结果会如何?3.

24、说明(1)自增、自减运算,常用于循环语句中,使循环控制变量加(或减),以及指针变量中,使指针指向下(或上)一个地址。(2)自增、自减运算符,不能用于常量和表达式。例如,5+、-(a+b)等都是非法的。(3)在表达式中,连续使同一变量进行自增或自减运算时,很容易出错,所以最好避免这种用法。第29页/共60页语言提供一种用逗号运算符“,”连接起来的式子,称为逗号表达式。逗号运算符又称顺序求值运算符。1.一般形式 表达式,表达式,表达式n2.求解过程自左至右,依次计算各表达式的值,“表达式n”的值即为整个逗号表达式的值。例如,逗号表达式“a=3*5,a*4”的值=60:先求解a=3*5,得a=15;

25、再求a*4=60,所以逗号表达式的值=60。又例如,逗号表达式“(a=3*5,a*4),a+5”的值=20:先求解a=3*5,得a=15;再求a*4=60;最后求解a+5=20,所以逗号表达式的值=20。注意:并不是任何地方出现的逗号,都是逗号运算符。很多情况下,逗号仅用作分隔符。3.9.2 逗号运算(,)及其表达式第30页/共60页3.10 顺序结构程序设计顺序结构程序设计为了让计算机处理各种数据,首先就应该把源数据输入到计算机中;计算机处理结束后,再将目标数据信息以人能够识别的方式输出。C语言中的输入输出操作,是由C语言编译系统提供的库函数来实现。主要输入输出函数有:l格式化输出:prin

26、tf()函数l格式化输入:scanf()函数l单个字符输入输出:getchar()和putchar()函数第31页/共60页3.10.1 格式化输出printf()函数 printf()函数的作用:向计算机系统默认的输出设备(一般指终端或显示器)输出一个或多个任意类型的数据。一.printf()函数的一般格式函数的一般格式案例3.5 已知圆半径radius=1.5,求圆周长和圆面积。main()float radius,length,area,pi=3.1415926;radius=1.5;length=2*pi*radius;/*求圆周长*/area=pi*radius*radius;/*求

27、圆面积*/printf(“radius=%fn”,radius);/*输出圆半径*/printf(“length=%7.2f,area=%7.2fn”,length,area);/*输出圆周长、面积*/第32页/共60页 程序运行结果如下:radius=1.500000 length=9.42,area=7.07 printf()函数的一般格式如下:printf(格式字符串,输出项表);1格式字符串。“格式字符串”也称“转换控制字符串”,可以包含三种字符:(1)格式指示符。格式指示符的一般形式如下:%标志宽度.精度F|N|h|L类型 第33页/共60页 (2)转义字符 例如,案例3.5中pri

28、ntf()函数中的n就是转义字符,输出时产生一个“换行”操作。(3)普通字符除格式指示符和转义字符之外的其它字符。格式字符串中的普通字符,原样输出。例如,案例3.5中“printf(radius=%fn,radius);”语句中的“radius=”,“printf(length=%7.2f,area=%7.2fn,length,area);”语句中的“length=”、“area=”等都是普通字符。2输出项表 输出项表是可选的。如果要输出的数据不止1个,相邻2个之间用逗号分开。下面的printf()函数都是合法的:(1)printf(I am a student.n);(2)printf(%d

29、,3+2);(3)printf(a=%f b=%5dn,a,a+3);必须强调:“格式字符串”中的格式指示符,必须与“输出项表”中、输出项的数据类型一致,否则会引起输出错误。第34页/共60页 二.格式指示符 输出不同类型的数据,要使用不同的类型转换字符。1类型转换字符类型转换字符d以带符号的十进制整数形式输出。以带符号的十进制整数形式输出。案例3.6 类型转换字符d的使用。main()int num1=123;long num2=123456;/*用3种不同格式,输出int型数据num1的值*/printf(num1=%d,num1=%5d,num1=%-5d,num1=%2dn,num1,

30、num1,num1,num1);/*用3种不同格式,输出long型数据num2的值*/printf(num2=%ld,num2=%8ld,num2=%5ldn,num2,num2,num2);printf(num1=%ldn,num1);第35页/共60页程序运行结果如下:num1=123,num1=123,num1=123,num1=123num2=123456,num2=123456,num2=123456num1=16908411对于整数,还可用八进制、无符号形式(%o(小写字母o))和十六进制、无符号形式(%x)输出。对于unsigned型数据,也可用%u格式符,以十进制、无符号形式输

31、出。所谓无符号形式是指,不论正数还是负数,系统一律当作无符号整数来输出。例如,printf(%d,%o,%xn,-1,-1,-1);第36页/共60页 案例3.7 类型转换字符f的使用。main()float f=123.456;double d1,d2;d1=1111111111111.111111111;d2=2222222222222.222222222;printf(%f,%12f,%12.2f,%-12.2f,%.2fn,f,f,f,f,f);printf(d1+d2=%fn,d1+d2);程序运行结果如下:123.456001,123.456001,123.46,123.46,12

32、3.46 d1+d2=3333333333333.3330102 2类型转换字符ff以小数形式、按系统默认的宽度,输出单精度和双精度实数。第37页/共60页 本 案 例 程 序 的 输 出 结 果 中,数 据 123.456001和3333333333333.333010中的001和010都是无意义的,因为它们超出了有效数字的范围。对于实数,也可使用格式符%e,以标准指数形式输出:尾数中的整数部分大于等于1、小于10,小数点占一位,尾数中的小数部分占5位;指数部分占4位(如e-03),其中e占一位,指数符号占一位,指数占2位,共计11位。也可使用格式符%g,让系统根据数值的大小,自动选择%f或

33、%e格式、且不输出无意义的零。第38页/共60页 3类型转换字符类型转换字符c输出一个字符(只占一列宽度)。输出一个字符(只占一列宽度)。案例3.8 类型转换字符c的使用。main()char c=A;int i=65;printf(c=%c,%5c,%dn,c,c,c);printf(i=%d,%c,i,i);程序运行结果如下:c=A,A,65 i=65,A 需要强调的是:在C语言中,整数可以用字符形式输出,字符数据也可以用整数形式输出。将整数用字符形式输出时,系统首先求该数与256的余数,然后将余数作为ASCII码,转换成相应的字符输出。第39页/共60页 4类型转换字符类型转换字符s输出

34、一个字符串。输出一个字符串。案例3.9 类型转换字符s的使用。main()printf(%s,%5s,%-10s,Internet,Internet,Internet);printf(%10.5s,%-10.5s,%4.5sn,Internet,Internet,Internet);程序运行结果如下:Internet,Internet,Internet,Inter,Inter,Inter注意:系统输出字符和字符串时,不输出单引号和双引号。第40页/共60页 三.使用说明 (1)printf()可以输出常量、变量和表达式的值。但格式控制中的格式说明符,必须按从左到右的顺序,与输出项表中的每个数据

35、一一对应,否则出错。例如,printf(str=%s,f=%d,i=%fn,Internet,1.0/2.0,3+5,CHINA);是错误的。(2)格式字符x、e、g可以用小写字母,也可以用大写字母。使用大写字母时,输出数据中包含的字母也大写。除了x、e、g格式字符外,其它格式字符必须用小写字母。例如,%f不能写成%F。(3)格式字符紧跟在“%”后面就作为格式字符,否则将作为普通字符使用(原样输出)。例如,“printf(”c=%c,f=%fn“,c,f);”中的第一个c和f,都是普通字符。第41页/共60页3.10.2 格式化输入scanf()函数scanf()函数是用来从外部输入设备向计算

36、机主机输入数据的。一.scanf()函数的一般格式函数的一般格式 案例3.10 已知圆柱体的底半径radius=1.5,高high=2.0,求其体积。main()float radius=1.5,high=2.0,pi=3.14159,vol;vol=pi*radius*radius*high;/*求体积*/printf(“vol=%7.2fn”,vol);/*输出求出的体积*/案例3.11 已知圆柱体的底半径为radius,高为high,求其体积。/*功能:说明函数scanf()的格式及作用。*/第42页/共60页main()float radius,high,vol,pi=3.141592

37、6;printf(Please input radius&high:);scanf(%f%f,&radius,&high);/*从键盘输入两个实数赋给变量r,h*/vol=pi*radius*radius*high;printf(radius=%7.2f,high=%7.2f,vol=%7.2fn,radius,high,vol);程序运行结果如下:Please input radius&high:1.52.0 radius=1.50,high=2.00,vol=14.14第43页/共60页 在程序中给计算机提供数据,可以用赋值语句,也可以用输入函数。在C语言中,可使用scanf()函数,通过

38、键盘输入,给计算机同时提供多个、任意的数据。1.scanf()函数的一般格式scanf(格式字符串,输入项首地址表);(1)格式字符串。格式字符串可以包含3种类型的字符:格式指示符、空白字符(空格、Tab键和回车键)和非空白字符(又称普通字符)。格式指示符与printf()函数的相似,空白字符作为相邻2个输入数据的缺省分隔符,非空白字符在输入有效数据时,必须原样一起输入。第44页/共60页(2)输入项首地址表由若干个输入项首地址组成,相邻2个输入项首地址之间,用逗号分开。输入项首地址表中的地址,可以是变量的首地址,也可以是字符数组名或指针变量。变量首地址的表示方法:&变量名其 中“&”是 地

39、址 运 算 符。例 如,案 例 2.11中 的“&radius”是指变量radius在内存中的首地址。2scanf()函数的功能:从键盘上接收格式化输入。运行案例3.11的程序时,从键盘上输入2个实数,分别存入&radius、&high起始的存储单元中,即输入两个实数分别赋给radius和high。第45页/共60页 二.格式指示符 格式指示符的一般形式为:%*宽度 F|N h|l 类型字符 1类型字符类型字符 类型字符如表3-6所示。例如,在案例3.11的scanf()函数语句中,格式字符串“%f%f”。2宽度宽度n 指定该项输入数据所占列数为n。换句话说,读取输入数据中相应的n位,但按需要

40、的位数赋给相应的变量,多余部分被舍弃。例如,scanf(%3c%3c,&ch1,&ch2);printf(ch1=%c,ch2=%cn,ch1,ch2);假设输入“abcdefg”,则系统将读取的“abc”中的“a”赋给变量ch1;将读取的“def”中的“d”赋给变量ch2,所以printf()函数的输出结果为:ch1=a,ch2=d。第46页/共60页 3赋值抑制字符赋值抑制字符*表示本输入项对应的数据读入后,不赋给相应的变量(该变量由下一个格式指示符输入)。例如,scanf(%2d%*2d%3d,&num1,&num2);printf(num1=%d,num2=%dn,num1,num2)

41、;假设输入“123456789”,则系统将读取“12”并赋值给num1;读取“34”、但舍弃掉(“*”的作用);读取“567”并 赋 值 给 num2。所 以,printf()函 数 的 输 出 结 果 为:num1=12,num2=567。4类型修饰符类型修饰符F、N、h、l。其含义与printf()中的一样,分别为远指针、近指针、短整型和长整型。第47页/共60页 三.数据输入操作 1如果相邻2个格式指示符之间,不指定数据分隔符(如逗号、冒号等),则相应的2个输入数据之间,至少用一个空格分开,或者用Tab键分开,或者输入1个数据后,按回车,然后再输入下1个数据。例如,scanf(%d%d,

42、&num1,&num2);假设给num1输入12,给num2输入36,则正确的输入操作为:1236 或者:12 36 注:使用“”符号表示按回车键操作,在输入数据操作中的作用是,通知系统输入操作结束。第48页/共60页 2“格式字符串”中出现的普通字符(包括转义字符形式的字符),务必原样输入。例如,scanf(%d,%d,&num1,&num2);假设给num1输入12,给num2输入36,正确的输入操作为:12,36 另外,scanf()函数中、格式字符串内的转义字符(如n),系统并不把它当转义字符来解释,从而产生一个控制操作,而是将其视为普通字符,所以也要原样输入。例如:scanf(num

43、1=%d,num2=%dn,&num1,&num2);假设给num1输入12,给num2输入36,正确的输入操作为:num1=12,num2=36n第49页/共60页 提高人机交互性建议:为改善人机交互性,同时简化输入操作,在设计输入操作时,一般先用printf()函数输出一个提示信息,再用scanf()函数进行数据输入。例如,将scanf(num1=%d,num2=%dn,&num1,&num2);改为:printf(num1=);scanf(%d,&num1);printf(num2=);scanf(%d,&num2);3输入数据时,遇到以下情况,系统认为该数据结束:(1)遇到空格,或者回

44、车键,或者Tab键。(2)遇到输入域宽度结束。例如“%3d”,只取3列。(3)遇到非法输入。例如,在输入数值数据时,遇到字母等非数值符号(数值符号仅由数字字符0-9、小数点和正负号构成)。第50页/共60页 4使用格式说明符“%c”输入单个字符时,空格和转 义字符均作为有效字符被输入。例如,scanf(%c%c%c,&ch1,&ch2,&ch3);printf(ch1=%c,ch2=%c,ch3=%cn,ch1,ch2,ch3);假设输入:ABC,则系统将字母A赋值给ch1,空格赋值给ch2,字母B赋值给ch3。第51页/共60页3.10.3 单个字符输入输出getchar()和 putcha

45、r()函数一.单个字符的输出单个字符的输出putchar()函数函数案例3.12 putchar()函数的格式和使用方法。/*功能:说明putchar()函数的格式和使用方法。*/#include stdio.h/*编译预处理命令:文件包含*/main()char ch1=N,ch2=E,ch3=W;putchar(ch1);putchar(ch2);putchar(ch3);/*输出*/putchar(n);putchar(ch1);putchar(n);/*输出ch1的值,并换行*/putchar(E);putchar(n);/*输 出 字 符 E,并换行*/putchar(ch3);pu

46、tchar(n);第52页/共60页程序运行结果如下:NEWNEW1putchar()函数的格式:putchar(ch);其中ch可以是一个字符变量或常量,也可以是一个转义字符。2putchar()函数的作用:向终端输出一个字符。(1)putchar()函数只能用于单个字符的输出,且一次只能输出一个字符。另外,从功能角度来看,printf()函数可以完全代替putchar()函数。(2)在程序中使用putchar()函数,务必牢记:在程序(或文件)的开头加上编译预处理命令(也称包含命令),即:#include stdio.h 表示要使用的函数,包含在标准输入输出(stdio)头文件(.h)中。

47、第53页/共60页案例3.13 说明getchar()函数的格式和作用。/*功能:说明getchar()函数的格式和作用。*/#include stdio.h/*文件包含*/main()char ch;printf(Please input two character:);ch=getchar();/*输入1个字符并赋给ch*/putchar(ch);putchar(n);putchar(getchar();/*输入一个字符并输出*/putchar(n);二.单个字符的输入单个字符的输入getchar()函数函数第54页/共60页 程序运行情况如下:Please input two chara

48、cters:ab a b 1getchar()函数的格式:getchar();2getchar()函数的作用:从系统隐含的输入设备(如键盘)输入一个字符。另外,从功能角度来看,scanf()函数可以完全代替getchar()函数。(1)getchar()函数只能用于单个字符的输入,一次输入一个字符。(2)程序中要使用getchar()函数,必须在程序(或文件)的开头加上编译预处理命令:#include stdio.h“第55页/共60页3.10.4 顺序结构程序设计 在顺序结构程序中,各语句(或命令)是按照位置的先后次序,顺序执行的,且每个语句都会被执行到。案例3.14 输入任意三个整数,求它

49、们的和及平均值。/*功能:设计一个顺序结构程序,求三个整数的和及平均值。*/main()int num1,num2,num3,sum;float aver;printf(Please input three numbers:);scanf(%d,%d,%d,&num1,&num2,&num3);/*输入三个整数*/sum=num1+num2+num3;/*求累计和*/aver=sum/3.0;/*求平均值*/printf(num1=%d,num2=%d,num3=%dn,num1,num2,num3);printf(sum=%d,aver=%7.2fn,sum,aver);第56页/共60页

50、思考题:能否将“aver=sum/3.0;”中“3.0”改为“3”?案例3.15 求方程ax2+bx+c=0的实数根。a,b,c由键盘输入,a0且b2-4ac0。/*功能:设计一个顺序结构程序,求方程的根。*/#include math.h/*为使用求平方根函数sqrt(),包含math.h头文件*/main()float a,b,c,disc,x1,x2;printf(Input a,b,c:);scanf(%f,%f,%f,&a,&b,&c);/*输入方程的三个系数的值*/disc=b*b-4*a*c;/*求 判 别 式 的 值 赋 给disc*/x1=(-b+sqrt(disc)/(2*

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 应用文书 > PPT文档

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁