《第二章基本数据类型及数据的输入输出.ppt》由会员分享,可在线阅读,更多相关《第二章基本数据类型及数据的输入输出.ppt(48页珍藏版)》请在三一办公上搜索。
1、第二章 基本数据类型及 数据的输入输出,2.0预备知识2.1常量与变量2.2数据类型2.3常用输出与输入函数 练习与实践,2.0 预备知识计算机中数的表示及进制转换数码、基与权数码:表示数的符号基:数码的个数权:每一位所具有的值数制,十进制:4956=410+910+510+610,二进制:1011=12+02+12+12,十六进制:81AE=816+116+1016+1416,八进制:4275=48+28+78+58,各种进制之间的转换二进制、八进制、十六进制转换成十进制方法:按权相加,各种进制之间的转换(整数)二进制、八进制、十六进制转换成十进制方法:按权相加,十进制转换成二进制、八进制、
2、十六进制原理:,方法:连续除以基,从低到高记录余数,直至商为0,二进制与八进制之间的转换二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制八进制转换成二进制:用3位二进制数代替每一位八进制数,例(1101001)2=(001,101,001)2=(151)8,例(246)8=(010,100,110)2=(10100110)2,000 0001 1010 2011 3100 4101 5110 6111 7,二进制与十六进制之间的转换二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制十六进制转换成二进制:用4位二进制数代替每一位十六进制数,例(1
3、1010101111101)2=(0011,0101,0111,1101)2=(357D)16,例(4B9E)16=(0100,1011,1001,1110)2=(100101110011110)2,0000 00001 10010 20011 30100 40101 50110 60111 71000 81001 91010 A1011 B1100 C1101 D1110 E1111 F,字节和位内存以字节为单元组成每个字节有一个地址一个字节一般由8个二进制位组成每个二进位的值是0或1,数值的表示方法原码、反码和补码原码:最高位为符号位,其余各位为数值本身的绝对值反码:正数:反码与原码相同负
4、数:符号位为1,其余位对原码取反补码:正数:原码、反码、补码相同负数:最高位为1,其余位为原码取反,再对整个数加1,9-5=49+7=16=(14)12,为什么用补码表示?,25-19=25+(-19)(25)10=(00011001)2(-19)10=(11101101)2 00011001+11101101-100000110,为什么用补码表示?,19-25=19+(-25)(19)10=(00010011)2(-25)10=(11100111)2 00010011+11100111-11111010-(-6)?引入补码之后符号位也进入了运算,不用再单独处理符号位,负数补码转换成十进制数:
5、最高位不动,其余位取反加1,例 补码:11111001 取反:10000110 加1:10000111=-7,2.1 常量与变量标识符定义:用来标识变量、常量、函数等的字符序列组成:只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线大小写敏感不能使用关键字长度:最长32个字符命名原则:见名知意不宜混淆 如l与I,o与0,例:判断下列标识符号合法性sum Sum M.D.John day Date 3days student_name#33 lotus_1_2_3 char ab _above$123,M.D.John,3days,#33,char,$123,ab,一般用大写字母是宏定
6、义预处理命令,不是C语句直接常量:整型常量 实型常量 字符常量 字符串常量,如#define PRICE 30,常量定义:程序运行时其值不能改变的量(即常数)分类:符号常量:用标识符代表常量定义格式:#define 符号常量 常量,例 符号常量举例#define PRICE 30main()int num,total;num=10;total=num*PRICE;printf(total=%d,total);,运行结果:total=300,变量-其值可以改变的量 概念:每个变量有一个名字:用标识符表示。每个变量有一个存储空间(存储单元),该单元中的状态所表示的数为此时变量的值。,变量初始化:定
7、义时可以赋初值,合法标识符,变量的使用:先定义,后使用,变量定义的一般格式:数据类型 变量1,变量2,变量n;,如:int a,b,c;float x,y;,例:int a=2,b,c=4;float data=3.67;char ch=A;int x=1,y=1,z=1;int x=y=z=1;,例2 float a,b,c;c=a%b;/Illegal use of floating point in function main,变量定义位置:一般放在函数开头,例1 int student;stadent=19;/Undefined symbol statent in function m
8、ain,每一个变量都有一个类型,表明了为它的存储属性:分配空间的大小;表示的数的范围;所能进行的运算。,例2.1main()float length,area,radius;/*length为周长,area为面积,radius半径*/printf(nEnter a radius:);scanf(%f,程序的运行情况为:Enter a radius:2.8 length is:17.584000 area is:24.617599,2.2 数据类型数据类型总表,数据类型决定:1.数据占内存字节数2.数据取值范围3.其上可进行的操作,2.2.1整数类型 整数类型的标识符是int。整型数据根据其占用
9、的内存字节数不同,可加限定词:short(短整型),int,long(长整型),shortintlong可用sizeof(类型标识符)测量 unsigned short(无符号短整型),unsigned int(无符号整型),unsigned long(无符号长整型),其中short和long的引入是为满足实际要求的不同长度的整数,而经unsigned限定词限定的整数总是正的。,整型常量(整常数)三种形式:十进制整数:由数字09和正负号表示.如 123,-456,0八进制整数:由数字0开头,后跟数字07表示.如0123,011十六进制整数:由0 x开头,后跟09,af,AF表示.如0 x123
10、,0Xff,例 12 与 12L,例 30000 为int型 65536 为long int 型,问题:0123=()100 x123=()100Xff=()10,整型常量的类型根据其值所在范围确定其数据类型:一个整数若值在-3276832767内,则默认为它是int型;一个整数若值在-21474836482147483647之间,可使用长整型常量表示。在整常量后加字母l或L,认为它是long int 型常量无符号数也可用后缀表示,整型常数的无符号数的后缀为“U”或“u”。例如:358u,0 x38Au,235Lu 均为无符号数;0XA5Lu表示十六进制无符号长整数A5,其十进制为165。一个
11、非负的整数,只要它的值不超过相应变量的取值范围,就可以赋给unsigned型变量。例如,可以将6000赋给一个 unsigned int型变量,但却不可以将66000赋给一个unsigned int型变量(将会出现溢出错误),整型变量 定义方法:int a1,a2;unsigned int b1,b2;一个整型常量只可以赋给能容纳下其值的整型变量。如a1,a2的取值范围为-32768-32767 b1,b2的取值范围为 0-65535如果:a1=65535;或者:b1=-1;在内存中数值将不是所赋的数值。,2.2.2 实数类型 实数类型分为单精度(float)和双精度(double)类型,二者
12、的区别在于所占存储位的多少,从而决定了其取值范围。通常以32位(bits)来存储单精度实数型数据,以64位来存储双精度实型数据。,实型常量(实数或浮点数)表示形式:十进制数形式:由数字和小数点组成,小数点的左右至少一边要有数字。(必须有小数点)如0.123,.123,123.0,0.0,123.指数形式:由尾数、e或E和指数部分组成,E的两边都至少要有一位数且E的右边只允许是整数形式(e或E之前必须有数字;指数必须为整数)如12.3e3,123E2,1.23e4,e-5,1.2E-3.5,实型常量的类型默认double型在实型常量后加字母f或F,认为它是float 型,实型变量 实型变量的说明
13、形式如下:float 变量名1,变量名2,变量名n;double 变量名1,变量名2,变量名n;float:占4字节,提供7位有效数字double:占8字节,提供1516位有效数字,例 float a;a=111111.111;/*a=111111.1*/double b;b=111111.111;/*b=111111.111*/,float a,b,c;double x,y;,【例2.2】实型变量的有效数字。main()double a;a=6.152367864359046178294901;printf(n%25.20f,a);输出结果为:6.15236786435904648000 在
14、这个例子中,a被赋值了一个有效位数为25位的数字。但由于a是double类型的,所以a只能接收1516位有效数字。在printf语句中,我们使用了%20.18f这样的格式符号,这指示printf语句在输出a时总长度应为25位,小数点位数占20位。输出的结果显然显示了25位数,但只有6.152367864359046共16位有效数字被正确显示出来,后面的数字是一些无效的数值。这就表明double型的数据只接收1516位有效数字。,2.2.3 字符类型 整型、实型都是数值型,是大家比较熟悉的。除数值型外,还有一类数据是计算机经常处理的数据,这就是字符型。字符型数据包含的是一个字符集。一般用的是AS
15、CII码字符集见附录A(p249)。字符集中的每一个字符都有一个序号,称为ASCII码。ASCII码大的字符比ASCII码小的字符值大。字符类型的标识符是char。,字符常量定义:用单引号括起来的单个普通字符或转义字符.,字符常量的值:该字符的ASCII码值,如 101-A 012-n 376-x61-a 60-0 483-(),例:A-101-x41-65,如 A65,a97,048,n10,如 a A?n 101,转义字符:反斜线后面跟一个字符或一个代码值表示,例 转义字符举例(ch2_001.c,ch2_004.c)main()printf(101 x42 Cn);printf(I sa
16、y:How are you?n);printf(C Programn);printf(Turbo C);,运行结果:(屏幕显示)A B CIsay:”How are you?”C ProgramTurbo C,例 main()printf(“Yb=n”);,运行结果:屏幕显示:=打印机输出:,字符型变量char 变量名1,变量名2,变量名n;如:char c1,c2;一个字符型变量的值只能是一个单个字符;在内存中占一个字节;字符变量存放的是字符的ASCII码;char与int数据间可进行算术运算;由于字符型变量在内存中是以字符的ASCII码一个无符号整数的形式来存放的,所以在一定范围内,字符型
17、数据和整型数据是可以互相通用的,二者的区别仅在于:字符型常量占一个字节,而整型常量占两个字节。,例 a=D;/*a=68;*/x=A+5;/*x=65+5;*/s=!+G/*s=33+71;*/,【例2.3】将小写字母转化为大写字母。main()char c1,c2;c1=x;c2=y;c1=c132;c2=c232;printf(n%c,%c,x1,x2);程序的输出结果是:X,Y 这个例子是将小写字母转化为大写字母的程序。我们在对ASCII码字符表进行观察后会发现,大小写对应的字母,它们之间的ASCII码正好相差32。利用这个特性和上一个特性,我们可以编写出非常简单的大小写字母转换程序。,
18、字符常量与字符串常量不同,字符串常量定义:用双引号(“”)括起来的字符序列存储:每个字符串尾自动加一个 0 作为字符串结束标志,例:char ch;ch=“A”;,没有字符串变量,用字符数组存放,基本数据类型,整型,字符型,实型,有,无,说明:数据类型所占字节数随机器硬件不同而不同,上表以IBM PC机为例:,例/*ch2_003.c*/#define PRICE 12.5 main()int num=3;float total;char ch1,ch2=D;total=num*PRICE;ch1=ch2-A+a;printf(“total=%f,ch1=%cn”,total,ch1);,运行
19、结果:total=37.500000,ch1=d,2.3 常用输入与输出函数,C语言无I/O语句,I/O操作由函数实现#include,格式:printf(“格式控制串”,输出表列);功能:按指定格式向显示器输出数据返值:正常,返回输出字节数;出错,返回EOF(-1),2.3.1格式输出函数,输出表列:要输出的数据,通常是表达式,可以没有,多个时以“,”分隔)格式控制串:包含两种信息:格式说明:%修饰符格式字符-用于指定所输出的表达事的格式;普通字符或转义序列:原样输出;格式字符,int a=567;printf(“%d”,a);,int a=255;printf(“%x”,a);,int a
20、=65;printf(“%o”,a);,int a=567;printf(“%u”,a);,char a=65;printf(“%c”,a);,printf(“%s”,“ABC”);,float a=567.789;printf(“%e”,a);,float a=567.789;printf(“%f”,a);,float a=567.789;printf(“%g”,a);,printf(“%”);,567,ff,101,567,A,ABC,5.677890e+02,567.789000,567.789,%,说明格式字符要用小写格式字符与输出项个数应相同,按先后顺序一一对应输出转换:格式字符与输
21、出项类型不一致,自动按指定格式输出,例 main()unsigned int u=65535;printf(”u=%dn,u);输出结果:u=-1,例 int a=3,b=4;printf(“%d%dn”,a,b);printf(“a=%d,b=%dn”,a,b);,例 int a=3,b=4;printf(“%d%dn”,a,b);printf(“a=%d,b=%dn”,a,b);输出结果:3 4 a=3,b=4,附加格式说明符(修饰符),例2.4 main()int n1,n2;float f1,f2,sum;char ch;n1=65;n2=3;f1=234.5;f2=18.75;sum
22、=f1+f2;ch=A;printf(%d,%c,%d,%o,%f,%c,%d,n1,n1,n2,n2,sum,ch,ch);printf(%s,Very good!);,运行结果:65,A,3,177775,253.250000,A,65,Very good!,例 static char a=“Hello,world!”printf(“%sn%15sn%10.5sn%2.5sn%.3sn”,a,a,a,a,a);,运行结果:Hello,world!Hello,world!Hello Hello Hel,例 int a=1234;float f=123.456;static char c=“H
23、ello,world!”;printf(“%8d,%-8dn”,a,a);printf(“%10.2f,%-10.1fn”,f,f);printf(“%10.5s,%-10.3sn”,c,c);,运行结果:1234,1234 123.46,123.5 Hello,Hel,例-,例 int a=1234;float f=123.456;printf(“%08dn”,a);printf(“%010.2fn”,f);printf(“%0+8dn”,a);printf(“0+10.2fn”,f);,例 0、+,例 int a=123;printf(“%o,%#o,%X,%#Xn”,a,a,a,a);,
24、例#,例 long a=65536;printf(“%d,%8ldn”,a,a);,例 l,/00001234,/0000123.46,/000+1234,/000+123.56,/173,0173,7B,0X7B,/0,65536,2.3.2 格式输入函数,格式:scanf(“格式控制串”,地址表)功能:按指定格式从键盘读入数据,存入地址表指定的 存储单元中,并按回车键结束返值:正常,返回输入数据个数,地址表:变量的地址,常用取地址运算符&格式字符:d,i,o,x,u,c,s,f,e,例 scanf(“%d”,输入:10 则 a=10,例 scanf(“%x”,输入:11 则 a=17,附加
25、格式说明符(修饰符),例 scanf(“%4d%2d%2d”,输入 19991015 则1999yy,10 mm,15 dd,例 scanf(“%3d%*4d%f”,输入 12345678765.43 则123k,8765.43f,例 scanf(“%2d%*3d%2d”,输入 1234567 则12a,67b,例 scanf(“%3c%2c”,输入 abcde 则ac1,d c2,输入分隔符的指定一般以空格、TAB或回车键作为分隔符其它字符做分隔符:格式串中两个格式符间字符,例 scanf(“%d%o%x”,输入 123 123 123 输出 a=123,b=83,c=291,例 scanf
26、(“%d:%d:%d”,输入 12:30:45 则12 h,30 m,45 s,例 scanf(“%d,%d”,&a,&b)输入 3,4 则3a,4 b,例 scanf(“a=%d,b=%d,c=%d”,输入 a=12,b=24,c=36,说明:用“%c”格式符时,空格和转义字符作为有效字符输入,如 scanf(“%c%c%c”,若输入abc 则ac1,c2,b c3,输入数据时,遇以下情况认为该数据结束:遇空格、TAB、或回车遇宽度结束遇非法输入,如 scanf(“%d%c%f”,若输入1234a123o.26 则 1234 a,a b,123 c,输入函数留下的“垃圾”:,例 int x;
27、char ch;scanf(“%d”,执行:123输出:x=123,ch=10,例 int x;char ch;scanf(“%d”,执行:123输出:x=123,ch=10,解决方法:(1)用getchar()清除(2)用函数fflush(stdin)清除全部剩余内容(3)用格式串中空格或“%*c”来“吃掉”,例 int x;char ch;scanf(“%d”,#include main()int c;char a;c=65;a=B;putchar(c);putchar(n);putchar(a);,运行结果:A B,2.3.3 字符输出函数-putchar(),格式:putchar(c)参数:c为字符常量、变量或表达式功能:把字符c输出到显示器上返值:正常,为显示的代码值;出错,为EOF(-1),格式:getchar()功能:从键盘读一字符返值:正常,返回读取的代码值;出错,返回EOF(-1),2.3.4 字符输入函数-getchar(),例,#include main()int c;printf(Enter a character:);c=getchar();printf(%c-hex%xn,c,c);,运行结果:Enter a character:AA-hex41,