第四章最简单的c程序设计
主要内容
4.1 C语句概述
1.一个c程序可以有若干个源程序文件组成
2.一个源文件可以有若干个函数和预处理命令以及全局变量声明部分组成
3.一个函数有函数首部和函数体组成
4.函数体由数据声明和执行语句组成
5.C语句分为
控制语句
函数调用语句
表达式语句
空语句
复合语句
4.2赋值语句
赋值语句是由赋值表达式加上一个分号构成
例:a=100赋值表达式
a=100;赋值语句
条件中不能含有赋值符号,但是赋值表达式可以包含于条件表达式中
例:if(a=b)
t=a;错误
if((a=b)>0)
t=a;正确
4.3数据输入输出的概念及在C语言中的实现
(一)所谓输入输出是以计算机主机为主体而言的
输出:从计算机向外部输出设备(显示器,打印机)输出数据。
输入:从输入设备(键盘,鼠标,扫描仪)向计算机输入数据。
(二)C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的。
例如:
字符输入函数: getchar字符输出函数:putchar
格式输入函数: scanf格式输出函数: printf
字符串输入函数:gets字数穿输出函数:puts
(三)在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中。
例如:在调用标准输入输出库函数时,文件开头应该有:
#include“stdio.h”或:#include
4.4字符数据的输入输出
(一)字符输出函数
一般形式:putchar(c)函数作用:向终端输出一个字符
例4.1输出单个字符。#include
void main()
{
char
a,b,c;
a=‘B’;b=‘O’;c=‘Y’;
putchar(a);putchar(b);putchar(c);putchar(‘\n’);
}
例4.2输入单个字符。#include
void main()
{
char c;
printf("请输入一个字母:");
c=getchar();
putchar(c);
putchar('\n');
}
4.5格式输入与输出
(一)格式输出函数
函数作用:向终端(或系统隐含指定的输出设备)输出若干个任意类型的数据。
一般格式:printf(格式控制,输出表列)
1.%d:以带符号的十进制形式输出整数
2.%o:以八进制无符号形式输出整数
3.%x:以十六进制无符号形式输出整数
4.To be continued……
5.%u:以无符号十进制形式输出整数
6.%c:以字符形式输出,只输出一个字符
7.%s:输出字符串
8.%f:以小数形式输出单,双精度数,隐含输出六位小数
9.%e:以指数形式输出实数
10.%g:选用%f或%e格式中输出宽度较短的一种格式,不输出无意义的0
几种常见的格式符的修饰符:
1 . L:用于长整型整数,可加在格式符d,o,x,u前面
2 . M(代表一个正整数):数据最小宽度
3 . N(代表一个正整数):对实数,表示输出n位小数;
对字符串,表示截取的字符个数
(二):输出的数字或字符在域内向左靠
(1)d格式符。用来输出十进制整数。几种用法:
①
%d:按十进制整型数据的实际长度输出。
②
%md:m为指定的输出字段的宽度。如果数据的位数小于m,
则左端补以空格,若大于m,则按实际位数输出。
例:printf(″%4d,%4d″,a,b);
若a=123,d=12345,则输出结果为
123,12345
③
%ld:输出长整型数据。
例: long a=135790;/*定义a为长整型变量*/
Printf(“%ld”,a);
(2)o格式符。以八进制整数形式输出。输出的数值不带符号,符号位也一起作为八进制数的一部分输出。
例:int
a=-1;
printf("%d,%o",a,a);
-1在内存单元中的存放形式(以补码形式存放)如下:
1111111111111111
输出为:
-1,1777777
不会输出带负号的八进制整数。对长整数(long型)可以用“%lo”格式输出。还可以指定字段宽度。
例:printf("%8o",a);
输出为: 177777。(数字前有2个空格)
(3)x格式符。以十六进制数形式输出整数。同样不会出现负的十六进制数。
例:
int a=-1;
Printf(“%x,%o,%d”,a,a,a);
输出结果为:
ffff,177777,-1
可以用“%lx”输出长整型数,也可以指定输出字段的宽度。
例:“%12x”
(4)u格式符,用来输出unsiged型数据。
一个有符号整数(int型)也可以用%u格式输出;
一个unsiged型数据也可以用%d格式输出;
unsiged型数据也可用%o或%x格式输出。
(5)c格式符,用来输出一个字符。
如:char d=’a’;
Printf(“%c”,d);
输出字符’a’.
一个整数,只要它的值在0~255范围内,可以用“%c”使之按字符形式输出,在输出前,系统会将该整数作为ASCII码转换成相应的字符;一个字符数据也可以用整数形式输出。
例4.3无符号数据的输出。#include
void main()
{
unsigned
int a=65535;int b=-2;
printf(“a=%d,%o,%x,%u\n”,a,a,a,a);
printf(“b=%d,%o,%x,%u\n”,b,b,b,b);
}
例4.4字符数据的输出。#include
void main()
{
char
c=‘a’;
int
i=97;
printf(“%c,%d\n”,c,c);
printf(“%c,%d\n”,i,i);
}
(6)s格式符(输出字符串.)
①
%s。例如:
printf(″%s″,″CHINA″)
输出字符串“CHINA”(不包括双引号)。
②
%ms,输出的字符串占m列,若串长大于m,则全部输出,若串长小于m,则左补空格。
③%-ms,若串长小于m,字符串向左靠,右补空格。
④%m. ns,输出占m列,只取字符串中左端n个字符,输出在m列的右侧,左补空格。
⑤%-m.ns,n个字符输出在m列的左侧,右补空格,若n〉m,m自动取n值。
例4.5字符串的输出。#include
void main()
{
printf(“%3s,%7.2s,%.4s,%-5.3s\n”,“CHINA”,“CHINA”,“CHINA”,“CHINA”);
}
(7)f格式符。用来以小数形式输出实数(包括单双精度)有以下几种用法:
①
%f。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出6位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为7位。
②%m.nf。指定输出的数据共占m列,其中有n位小数。如果数值长度小于m,则左端补空格。
③%-m.nf与%m.nf基本相同,只是使输出的数值向左端靠,右端补空格。
例4.6输出实数时的有效位数。#include
voidmain(){
float x,y;x=111111.111;y=222222.222;printf(″%f″,x+y);}
例4.7输出双精度数时的有效位数。#include
voidmain(){
double x,y;x=1111111111111.111111111;
y=2222222222222.222222222;
printf(“%f”,x+y);}
例4.8输出实数时指定小数位数。#include
void main(){
float
f=123.456;
printf(“%f%10f%10.2f%.2f%-10.2f\n”,f,f,f,f,f);}
(8)e格式符,以指数形式输出实数。
可用以下形式:
①
%e。不指定输出数据所占的宽度和数字部分的小数位数.
例:
printf(″%e″,123.456);
输出:
1.234560 e+002
6列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+002
1.234560e+002 1.23e+002 1.23e+002 1.23e+002
13列13列10列9列10列
说明:
1.未指定n,自动使n=6.
2.超过给定的10列,乃突破10列的限制,按实际长度输出。
3.第3个数据共占10列,小数部分占2列。
4.只指定n=2,未指定m,自动使m等于数据应占的长度。
5.第5个数据应占10列,数值只有9列,由于是“%-10.2e”,
6.数值向左靠,右补一个空格。
(注:有的C系统的输出格式与此略有不同)
(9)g格式符,用来输出实数.
它根据数值的大小,自动选f格式或e格式(选择输出时占宽度较小的一种),且不输出无意义的零。
例:若f=123.468,则printf(″%f%e%g″,f,f,f);
输出如下:
123.468000
1.234680e+002 123.468
10列13列10列
说明:
用%f格式输出占10列,用%e格式输出占13列,用%g格式时,自动从上面两种格式中选择短者(今以%f格式为短)故占10列,并按%f格式用小数形式输出,最后3个小数位为无意义的0,不输出,因此输出123.468,然后右补3个空格。%g格式用得较少。
4.5格式输入与输出
(一).格式输入函数
函数作用:按照变量在内存的地址将变量值存进去。
一般格式:scanf(格式控制,地址表列)
格式控制:同printf函数
地址表列:是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址
例4.9用scanf函数输入数据。#include
void main()
{
int
a,b,c;
scanf(“%d%d%d”,&a,&b,&c);//a在内存中的地址&是地址运算符printf(“%d,%d,%d\n”,a,b,c);
}
使用scanf函数时应注意的问题:
(1)scanf函数中的“格式控制”后面应当是变量地址,而不应是变量名。
(2)如果在“格式控制”字符串中除了格式说明以外还有其他字符,则在输入数据时在对应位置应输入与这些字符相同的字符。
(3)在用“%c”格式输入字符时,空格字符和“转义字符”都作为有效字符输入 。
(4)在输入数据时,遇以下情况时认为该数据结束。
① 遇空格,或按“回车”或“跳格”(Tab)键;
② 按指定的宽度结束,如“%3d”,只取3列;
③ 遇非法输入。
例4.10输入三角形的三边长,求三角形面积。
假设:三个边长a,b,c能构成三角形。
已知面积公式:area=
s=(a+b+c)*0.5
#include
#include//数学函数库因为要用到其中的sqrt函数void main()
{
float a,b,c,s,area;
scanf(″%f,%f,%f″,&a,&b,&c);
s=1.0/2*(a+b+c);
area=sqrt(s*(s-a)*(s-b)*(s-c));
printf(″a=%7.2f, b=%7.2f,
c=%7.2f, s=%7.2f\n″,a,b,c,s);
printf(″area=%7.2f\n″,area);
}
例4.11从键盘输入一个大写字母,要求改用小写字母输出。
#include
voidmain(){char cl,c2;cl=getchar();printf(″%c,%d\n″,cl,cl);c2=cl+32;printf(″%c,%d\n″,c2,c2);}