您好,欢迎访问三七文档
当前位置:首页 > 商业/管理/HR > 质量控制/管理 > 第3章基本输入输出和顺序结构程序设计
第三章3.1数据输入输出的概念所谓输入输出是以计算机主机为主体而言的输出:从计算机向外部输出设备(显示器,打印机)输出数据。输入:从输入设备(键盘,鼠标,扫描仪)向计算机输入数据。C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的。例如:字符输入函数:getchar字符输出函数:putchar格式输入函数:scanf格式输出函数:printf字符串输入函数:gets字符串输出函数:puts在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。例如:在调用标准输入输出库函数时,文件开头应该有:#include“stdio.h”或:#includestdio.h3.2字符数据的输入输出3.2.1字符输出函数(putchar()函数)一般形式:putchar(c)函数作用:向终端输出一个字符等价与printf(“%c”,c);字符型变量整型变量例3.1输出单个字符。#includestdio.hvoidmain(){chara,b,c;a=‘B’;b=‘O’;c=‘Y’;putchar(a);putchar(b);putchar(c);putchar(‘\n’);}运行结果:BOYputchar(a);putchar(‘\n’);putchar(b);putchar(‘\n’);putchar(c);putchar(‘\n’);运行结果:BOY3.2.2字符输入函数(getchar()函数)一般形式:getchar()函数作用:从终端输入一个字符。函数值:从输入设备得到的字符。等价于scanf(“%c”,&c);括号内什么也没有例3.2输入单个字符。#includestdio.hvoidmain(){charc;c=getchar();putchar(c);putchar(‘\n’);}运行程序:从键盘输入字符‘a’按Enter键屏幕上将显示输出的字符‘a’aa用getchar()得到的字符可以赋给字符型变量、整型变量,或作为表达式的一部分,如c=getchar()+32;putchar(c);又如:3.3.1格式输出函数函数作用:向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据。一般格式:printf(“格式控制”,输出表列)3.3格式输入与输出printf(sum=%d\n%c,x,ch);普通字符格式说明转义字符输出列表例例3.1#includestdio.hvoidmain(){inta,b;a=3;b=4;printf(输出结果为:);printf(%d%d\n,a,b);printf(a=%d,b=%d\n,a,b);printf(a+b=%d,a+b);}输出结果为:34a=3,b=4a+b=7_输出%d:以带符号的十进制形式输出整数%o:以八进制无符号形式输出整数%x:以十六进制无符号形式输出整数%u:以无符号十进制形式输出整数%c:以字符形式输出,只输出一个字符%s:输出字符串%f:以小数形式输出单,双精度数,隐含输出六位小数%e:以指数形式输出实数%g:选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的0几种常见的格式符的修饰符:l:用于长整型整数,可加在格式符d,o,x,u前面m(代表一个正整数):数据最小宽度n(代表一个正整数):对实数,表示输出n位小数;对字符串,表示截取的字符个数-:输出的数字或字符在域内向左靠格式说明必须以%开始,以格式字符结束。一般形式如下:格式说明的一般形式(1)d格式符。用来输出十进制整数。几种用法:①%d:按十进制整型数据的实际长度输出。②%md:m为指定的输出字段的宽度。如果数据的位数小于m,则左端补以空格,若大于m,则按实际位数输出。例:printf(″%4d,%4d″,a,b);若a=123,d=12345,则输出结果为_123,12345③%ld:输出长整型数据。例:longa=135790;/*定义a为长整型变量*/printf(″%ld″,a);(2)o格式符。以八进制整数形式输出。输出的数值不带符号,符号位也一起作为八进制数的一部分输出。例:inta=-1;printf(%d,%o,a,a);-1在内存单元中的存放形式(以补码形式存放)如下:1111111111111111输出为:-1,177777不会输出带负号的八进制整数。对长整数(long型)可以用“%lo”格式输出。还可以指定字段宽度。例:printf(%8o,a);输出为:__177777。(数字前有2个空格)(3)x格式符。以十六进制数形式输出整数。同样不会出现负的十六进制数。例:inta=-1;printf(″%x,%o,%d″,a,a,a);输出结果为:ffff,177777,-1可以用“%lx”输出长整型数,也可以指定输出字段的宽度。例:“%12x”(4)u格式符,用来输出unsigned型数据。一个有符号整数(int型)也可以用%u格式输出;一个unsigned型数据也可以用%d格式输出;unsigned型数据也可用%o或%x格式输出。(5)c格式符,用来输出一个字符。如:chard=‘a’;printf(“%c”,d);输出字符a。一个整数,只要它的值在0~255范围内,可以用“%c”使之按字符形式输出,在输出前,系统会将该整数作为ASCII码转换成相应的字符;一个字符数据也可以用整数形式输出。(6)s格式符输出字符串.①%s。例如:printf(“%s”,“CHINA”)输出字符串CHINA②%ms,输出的字符串占m列,若串长大于m,则全部输出,若串长小于m,则左补空格。③%-ms,若串长小于m,字符串向左靠,右补空格。④%m.ns,输出占m列,只取字符串中左端n个字符,输出在m列的右侧,左补空格。⑤%-m.ns,n个字符输出在m列的左侧,右补空格,若nm,m自动取n值,以保证n个字符正常输出。例3.4字符串的输出。#includestdio.hvoidmain(){printf(“%3s,%7.2s,%.4s,%-5.3s\n”,“CHINA”,“CHINA”,“CHINA”,“CHINA”);}运行结果:CHINA,CH,CHIN,CHI(7)f格式符。用来以小数形式输出实数(包括单双精度)有以下几种用法:①%f。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出6位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为7位。②%m.nf。指定输出的数据共占m列,其中有n位小数。如果数值长度小于m,则左端补空格。③%-m.nf与%m.nf基本相同,只是使输出的数值向左端靠,右端补空格。例3.5输出实数时的有效位数。#includestdio.hvoidmain(){floatx,y;doublea,b;x=111111.111;y=222222.222;a=1111111111111.111111111;b=2222222222222.222222222;printf(“%f,%f”,x+y,a+b);}运行结果:333333.328125,3333333333333.333010例3.6输出实数时指定小数位数。#includestdio.hvoidmain(){floatf=123.456;printf(“%f%10f%10.2f%.2f%-10.2f\n”,f,f,f,f,f);}运行结果:123.455994123.455994123.46123.46123.46(8)e格式符,以指数形式输出实数。可用以下形式:①%e。不指定输出数据所占的宽度和数字部分的小数位数,有的系统自动指定给出数字部分的小数位数为6位,指数部分占5位。例:printf(“%e”,123.456);输出:1.234560e+0026列5列所输出的实数共占13列宽度。(注:不同系统的规定略有不同)②%m.ne和%-m.ne。m、n和“-”字符的含义与前相同。此处n指拟输出的数据的小数部分(又称尾数)的小数位数。若f=123.456,则:printf(%e%10e%10.2e%.2e%-10.2e,f,f,f,f,f);输出如下:1.234560e+0021.234560e+0021.23e+0021.23e+0021.23e+00213列13列10列9列10列说明:未指定n,自动使n=6.超过给定的10列,乃突破10列的限制,按实际长度输出。第3个数据共占10列,小数部分占2列,左补空格。只指定n=2,未指定m,自动使m等于数据应占的长度。第5个数据应占10列,数值只有9列,由于是“%-10.2e”,数值向左靠,右补一个空格。(注:有的C系统的输出格式与此略有不同)(9)g格式符,用来输出实数.它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的零。例:若f=123.468,则printf(″%f%e%g″,f,f,f);输出如下:123.4680001.234680e+002123.46810列13列10列说明:用%f格式输出占10列,用%e格式输出占13列,用%g格式时,自动从上面两种格式中选择短者(今以%f格式为短)故占10列,并按%f格式用小数形式输出,最后3个小数位为无意义的0,不输出,因此输出123.468,然后右补3个空格。%g格式用得较少。3.2.2.格式输入函数函数作用:按照变量在内存的地址将变量值存进去。一般格式:scanf(“格式控制”,地址表列)如果在%后有一个“*”附加说明符,表示跳过它指定的列数。例如:scanf(“%2d%*3d%2d”,&a,&b);如果输入12_345_67%*3d表示读入3位整数但不赋给任何变量。例3.7用scanf函数输入数据。#includestdio.hvoidmain(){inta,b,c;scanf(“%d%d%d”,&a,&b,&c);printf(“%d,%d,%d\n”,a,b,c);}运行情况:345(输入a,b,c的值)3,4,5(输出a,b,c的值)a在内存中的地址&是地址运算符“%d%d%d”表示要按十进制整数形式输入3个数据。输入数据时,在两个数据之间以一个或多个空格间隔,也可以用Enter键、Tab键。下面输入均合法:(1)3__4____5(2)34_5(3)3(按Tab键)45输入数据的分隔:inputa,b,c:1234A=12,b=3.000000,c=4.000000输入1234567系统自动把12赋给a,把345赋给b,67赋给c输出结果为:a=12,b=345.000000,c=67.000000使用scanf函数时应注意的问题:1、scanf函数中的“格式控制”后面应当是变量地址,而不应是变量名。2、输入数据时不能规定精度,例如scanf(“%7.2f”,&a);×3、如果在“格式控制”字符串中除了格式说明以外还有其他字符,则在输入数据时在对应位置应输入与这些字符相同的字符。4、在用“%c”格式输入字符时,空格字符和“转义字符”都作为有效字符输入。3.4常用数学函数的使用1、sin函数—正弦函数原型:doublesin(doublex);2、sqrt函数—平方根函数原型:doublesqrt(doublex);3、log10函数—求常用对数函数原型:doublelog10(doublex);4、log函数—求自然对数函数原型:doublelog(doublex);5、exp函数—求e的x次方函数原型:doubleexp(doublex);6、pow函数—求x的y次方函数原型:doublepow(doublex,doubley);7、abs函数—求整数的绝对值函数原型:Intabs(inti);8、fabs函数—求实数绝对值函数原型:doublefabs(doublex);说明:(1)在使用这些数学函数时,在程序开头必须加上#includemath.h(2)函数的调用格式为:函数名(参数
本文标题:第3章基本输入输出和顺序结构程序设计
链接地址:https://www.777doc.com/doc-3374771 .html