计算机软件技术基础C语言-第1-3章复习.ppt
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_1.gif)
![资源得分’ title=](/images/score_05.gif)
《计算机软件技术基础C语言-第1-3章复习.ppt》由会员分享,可在线阅读,更多相关《计算机软件技术基础C语言-第1-3章复习.ppt(90页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、C语言程序设计语言程序设计 第第 一一 至至 三章三章 小小 结结C语言概述数据类型、运算符与表达式最简单的程序设计顺序程序设计选择结构程序设计循环控制数组结构化程序设计三种基本结构1q计算机中数的表示q数据类型q关于输入输出q程序的流程设计程序设计的基本知识程序设计的基本知识q计算机中数的表示及进制转换计算机中数的表示及进制转换v数码、基与权l数码:表示数的符号l基:数码的个数l权:每一位所具有的值v数制l二进制l八进制l十进制l十六进制v各种进制之间的转换l二进制、八进制、十六进制转换成十进制u方法:按权相加v各种进制之间的转换(整数)l二进制、八进制、十六进制转换成十进制u方法:按权相加
2、l十进制转换成二进制、八进制、十六进制u原理:u方法:连续除以基,从低到高记录余数,直至商为0例 把十进制数59转换成二进制数5922921427232120(59)10=(111011)21101111 1 1 0 1 1余余余余余余例 把十进制数159转换成八进制数1598198280(159)10=(237)82 3 7 余 7余 3余 2例 把十进制数459转换成十六进制数4591628161160(459)10=(1CB)161 C B 余11余12余 1l二进制与八进制之间的转换u二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制u八进制转换成二进制:用3位二
3、进制数代替每一位八进制数例 (1101001)2=(001,101,001)2=(151)8例(246)8=(010,100,110)2=(10100110)2000 0001 1010 2011 3100 4101 5110 6111 7l二进制与十六进制之间的转换u二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制u十六进制转换成二进制:用4位二进制数代替每一位十六进制数例 (11010101111101)2=(0011,0101,0111,1101)2=(357D)16例(4B9E)16=(0100,1011,1001,1110)2=(1001011100111
4、10)20000 00001 10010 20011 30100 40101 50110 60111 71000 81001 91010 A1011 B1100 C1101 D1110 E1111 F字节和位v内存以字节为单元组成v每个字节有一个地址v一个字节一般由8个二进制位组成v每个二进位的值是0或101234567012345678910.7643251数值的表示方法原码、反码和补码v原码:最高位为符号位,其余各位为数值本身的绝对值v反码:l正数:反码与原码相同l负数:符号位为1,其余位对原码取反v补码:l正数:原码、反码、补码相同l负数:最高位为1,其余位为原码取反,再对整个数加131
5、26912457810119-5=49+7=16=(4)12原码反码补码+7000001110000011100000111-7100001111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围0111111111111111(-127+127)0111111110000000(-127+127)0111111110000000(-128+127)(用一字节表示数)v负数补码转换成十进制数:最高位不动,其余位取反加1例 补码:11111001 取反:10000110 加1:10000111=-7q数据
6、类型数据类型数据类型基本类型构造类型指针类型空类型void定义类型typedef数值类型字符类型char枚举类型enum整 型浮点型单精度型float双精度型double短整型short长整型long整型int数组结构体struct共用体union数据类型决定:1.数据占内存字节数2.数据取值范围3.其上可进行的操作数据类型数据类型类型符号关键字数的表示范围所占位数整型字符型实型有无(signed)int16-3276832767(signed)short16-3276832767(signed)long32-2147483648214748364716unsigned int06553532
7、04294967295unsigned longunsigned short16065535有float323.4e-383.4e38有double641.7e-3081.7e308有char8-128127无unsigned char80255格式:putchar(c)参数:c为字符常量、变量或表达式功能:把字符c输出到显示器上返值:正常,为显示的代码值;出错,为EOF(-1)q关于输入输出关于输入输出5C语言无I/O语句,I/O操作由函数实现5#include 1、数据输出字符输出函数#include main()int c;char a;c=65;a=B;putchar(c);putch
8、ar(n);putchar(a);运行结果:A B例格式:printf(“格式控制串”,输出表)功能:按指定格式向显示器输出数据返值:正常,返回输出字节数;出错,返回EOF(-1)格式输出函数v输出表:要输出的数据(可以没有,多个时以“,”分隔)v格式控制串:包含两种信息l格式说明:%修饰符格式字符 ,用于指定输出格式l普通字符或转义序列:原样输出v格式字符d,ix,Xoucse,Efg%格式字符:十六进制无符号整数不带符号十进制整数十进制整数指数形式浮点小数单一字符字符串八进制无符号整数小数形式浮点小数e和f中较短一种百分号本身int a=567;printf(“%d”,a);int a=2
9、55;printf(“%x”,a);int a=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(“%”);567ff101567AABC5.677890e+02567.789000567.789%l说明u格式字符要用小写u格式字符与输出项个数应相同,按先后顺序一一对应u输出
10、转换:格式字符与输出项类型不一致,自动按指定格式输出例 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=411 11 11 11 11 11 11 1165535v附加格式说明符(修饰符).n对实数,指定小数点后位数(四舍五入)对字符串,指定实际输出位数修饰符功 能m输出数据
11、域宽,数据长度m,左补空格;否则按实际输出输出数据在域内左对齐(缺省右对齐)-指定在有符号数的正数前显示正号(+)+输出数值时指定左面不使用的空位置自动填00在八进制和十六进制数前显示前导0,0 x#在d,o,x,u前,指定输出精度为long型在e,f,g前,指定输出精度为double型l例 int a=1234;float f=123.456;char ch=a;printf(“%8d,%2dn”,a,a);printf(“%f,%8f,%8.1f,%.2f,%.2en”,f,f,f,f,f);printf(“%3cn”,ch);运行 1234,1234结果:123.456000,123.4
12、56000,123.5,123.46,1.23e+02 a例 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 例 m.n例 int a=1234;float f=123.456;static char c=“Hello,world!”;printf(“%8d,%-8dn”,a,a);printf(“%10.2f,%-10.1fn”,f,f);printf(“%10.5s,%-10.3sn”,c,c);运行
13、结果: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);例#例 long a=65536;printf(“%d,%8ldn”,a,a);例 l00 00 00 00 00 00 00 01 00 00 00 00 00 00 00 00/00001234/0000
14、123.46/000+1234/000+123.56/173,0173,7B,0X7B/0,65536格式:getchar()功能:从键盘读一字符返值:正常,返回读取的代码值;出错,返回EOF(-1)2、数据输入字符输入函数 例#include main()int c;printf(Enter a character:);c=getchar();printf(%c-hex%xn,c,c);运行结果:Enter a character:AA-hex41格式输入函数格式:scanf(“格式控制串”,地址表)功能:按指定格式从键盘读入数据,存入地址表指定的 存储单元中,并按回车键结束返值:正常,返回
15、输入数据个数v地址表:变量的地址,常用取地址运算符&v格式字符:d,i,o,x,u,c,s,f,e例 scanf(“%d”,&a);输入:10 则 a=10例 scanf(“%x”,&a);输入:11 则 a=17v附加格式说明符(修饰符)l修饰符功 能hm*用于d,o,x前,指定输入为short型整数用于d,o,x前,指定输入为long型整数用于e,f前,指定输入为double型实数指定输入数据宽度,遇空格或不可转换字符则结束抑制符,指定输入项读入后不赋给变量例 scanf(“%4d%2d%2d”,&yy,&mm,&dd);输入 19991015 则1999yy,10 mm,15 dd例 s
16、canf(“%3d%*4d%f”,&k,&f);输入 12345678765.43 则123k,8765.43f例 scanf(“%2d%*3d%2d”,&a,&b);输入 1234567 则12a,67b例 scanf(“%3c%2c”,&c1,&c2);输入 abcde 则ac1,d c2v输入分隔符的指定l一般以空格、TAB或回车键作为分隔符l其它字符做分隔符:格式串中两个格式符间字符例 scanf(“%d%o%x”,&a,&b,&c);printf(“a=%d,b=%d,c=%dn”,a,b,c);输入 123 123 123 输出 a=123,b=83,c=291例 scanf(“%
17、d:%d:%d”,&h,&m,&s);输入 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,&b,&c);输入 a=12,b=24,c=36 v说明:l用“%c”格式符时,空格和转义字符作为有效字符输入如 scanf(“%c%c%c”,&c1,&c2,&c3);若输入abc 则ac1,c2,b c3l输入数据时,遇以下情况认为该数据结束:u遇空格、TAB、或回车u遇宽度结束u遇非法输入如 scanf(“%d%c%f”,&a,&b,&c);若输入1234a123o.26
18、 则 1234 a,a b,123 cl输入函数留下的“垃圾”:例 int x;char ch;scanf(“%d”,&x);ch=getchar();printf(“x=%d,ch=%dn”,x,ch);执行:123输出:x=123,ch=10例 int x;char ch;scanf(“%d”,&x);scanf(“%c”,&ch);printf(“x=%d,ch=%dn”,x,ch);执行:123输出:x=123,ch=10解决方法:(1)用getchar()清除(2)用函数fflush(stdin)清除全部剩余内容(3)用格式串中空格或“%*c”来“吃掉”例 int x;char ch
19、;scanf(“%d”,&x);scanf(“%c”,&ch);或 scanf(“%*c%c”,&ch);格式说明符简介格式说明符简介e%d以带符号的十进制形式输出整数以带符号的十进制形式输出整数e%o以无符号的八进制形式输出整数以无符号的八进制形式输出整数e%x以无符号的十六进制形式输出整数以无符号的十六进制形式输出整数e%u以无符号的十进制形式输出整数以无符号的十进制形式输出整数e%c以字符形式输出单个字符以字符形式输出单个字符e%s输出字符串输出字符串e%f以小数点形式输出单、双精度实数以小数点形式输出单、双精度实数e%e以标准指数形式输出单、双精度实数以标准指数形式输出单、双精度实数e
20、%g选用输出宽度较小的格式输出实数选用输出宽度较小的格式输出实数d d 格式符格式符功能功能以带符号的十进制形式输出整数。以带符号的十进制形式输出整数。具体用法具体用法d d:按照整型数据的实际长度输出。:按照整型数据的实际长度输出。mdmd:以:以m m指定的字段宽度输出,右对齐。指定的字段宽度输出,右对齐。ldld:输出长整型数据。:输出长整型数据。mldmld:输出指定宽度的长整型数据。:输出指定宽度的长整型数据。程序范例程序范例例例执行下面程序,注意输出格式:执行下面程序,注意输出格式:main()int a=12,b=-3456;long int c=123456;printf(%5
21、dn,a);printf(%dn,b);printf(%ldn,c);printf(%dn,c);运行结果:运行结果:12-3456123456-7616 o o 格式符格式符 和和 x x 格式符格式符功能:将内存单元中的二进制数将内存单元中的二进制数补码补码补码补码直接转换成八直接转换成八进制数或十六进制数输出,不带符号位。进制数或十六进制数输出,不带符号位。说明:同“d”类似,可以用“mo”或“mx”指定字段输出宽度。对长整型数可以用“lo”或“lx”格式输出。机器数(带符号)的表示机器数(带符号)的表示正数:正数:原码、反码及补码一样,即:符号位绝对值原码、反码及补码一样,即:符号位绝
22、对值负数:负数:原码:符号位绝对值原码:符号位绝对值反码:符号位对原码取反反码:符号位对原码取反补码:符号位:对原码取反补码:符号位:对原码取反1 1举例:设有举例:设有 int a=1,b=-1;int a=1,b=-1;a a的表示:的表示:0000 0000 0000 00010000 0000 0000 0001(原、反、补)(原、反、补)b b的表示:的表示:1000 0000 0000 00011000 0000 0000 0001(原码)(原码)1111 1111 1111 11101111 1111 1111 1110(反码)(反码)1111 1111 1111 1111111
23、1 1111 1111 1111(补码)(补码)例例main()int a=1,b=-1;printf(a:%8d,%8o,%8xn,a,a,a);printf(”b:%8d,%8o,%8xn,b,b,b);运行结果:a:1,1,1b:-1,177777,ffffu u 格式符格式符功能:以无符号的十进制形式输出整数。功能:以无符号的十进制形式输出整数。说明:说明:有符号数可用有符号数可用“u”u”格式输出;格式输出;无符号数可用无符号数可用“d”d”、“o”o”、“x”x”格式输格式输出。出。举例:举例:int i=-1;int i=-1;printf(“%d,%u”,i,i);printf
24、(“%d,%u”,i,i);输出结果:输出结果:-1,65535-1,65535c 格式符功能:输出单个ASCII码字符。说明:c格式也可用于输出一个范围在0255之间的整数,其值必然对应某个ASCII字符。例例例例4.54.5 main()char c=M;int i;i=c+32;printf(%c,%dn,c,c);printf(%c,%dn,i,i);M,77m,109s s 格式符格式符分类:分类:Fs s:直接输出指定字符串。:直接输出指定字符串。Fmsms:输出字符串占:输出字符串占m m列,右对齐。列,右对齐。F-ms-ms:输出字符串占:输出字符串占m m列,左对齐。列,左对
25、齐。Fm.nsm.ns:输出字符串前:输出字符串前n n个字符,占个字符,占m m列,右列,右对齐。对齐。F-m.ns-m.ns:输出字符串前:输出字符串前n n个字符,占个字符,占m m列,左列,左对齐。对齐。例例例例s s格式符使用。格式符使用。格式符使用。格式符使用。main()printf(%3s,%7.2s,%.4s,%-5.3sn,China,China,China,China);运行结果运行结果China,Ch,Chin,Chi f 格式符功能:以小数点形式输出单、双精度实数。功能:以小数点形式输出单、双精度实数。分类:分类:f f:数据的整数部分全部输出,小数部分输出:数据的整
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机软件 技术 基础 语言 复习
![提示](https://www.taowenge.com/images/bang_tan.gif)
限制150内