C程序设计(第三版)
第 4章 顺序结构 程序设计
C 语言程序设计
主要内容
4.1 C语句概述
4.2 赋值语句
4.3 数据输入输出的概念及在 c语言中的实现
4.4 字符数据的输入输出
4.5 格式输入与输出
4.6 顺序结构程序设计举例
C程序设计(第三版) 2009-7-31
4.1 C语句概述
C程序源程序文件 1 源程序文件 2 源程序文件 n
预处理命令 函数 n函数 1数据声明函数首部 函数体数据声明 执行语句
C程序设计(第三版) 2009-7-31
4.1 C语句概述
一个 c程序可以有若干个源程序文件组成
一个源文件可以有若干个函数和预处理命令以及全局变量声明部分组成
一个函数有函数首部和函数体组成
函数体由数据声明和执行 语句 组成
C语句分为
5类 控制语句函数调用语句表达式语句空语句复合语句
C程序设计(第三版) 2009-7-31
4.1 C语句概述
(一 )控制语句 完成一定的控制功能
1 if() ~else 条件 语句 6 break 间断语句
2 for()~ 循环 语句 7 switch() 开关语句
3 while()~循环 语句 8 goto 转向语句
4 do ~while();循环 语句 9 return 返回语句
5 continue 继续 语句
C程序设计(第三版) 2009-7-31
4.1 C语句概述
(二 )函数调用语句有一个函数调用加一个分号构成一个语句
Printf(“This is a C statement.”);
C程序设计(第三版) 2009-7-31
4.1 C语句概述
(三 )表达式语句有一个表达式加一个分号构成一个语句
a = 3 ; 分号赋值表达式 表达式语句
C程序设计(第三版) 2009-7-31
4.1 C语句概述
(四 )空语句 只有一个分号的语句
(什么也不做)
用来做流程的转向点
用来作为循环语句中的循环体
C程序设计(第三版) 2009-7-31
4.1 C语句概述
(五)复合语句 用一对 {}括起来的语句
{ z=x+y;
t=z/100;
printf(“%f”,t);
}
C程序设计(第三版) 2009-7-31
4.2 赋值语句
赋值语句是由赋值表达式加上一个分号构成例,a=100 赋值表达式
a=100; 赋值语句
条件中不能含有赋值符号,但是赋值表达式可以包含于条件表达式中例,if(a=b) t=a; 错误
if((a=b)>0) t=a; 正确
C程序设计(第三版) 2009-7-31
4.2 赋值语句
1,C语言中的赋值号,=” 是一个运算符,在其他大多数语言中赋值号不是运算符,
2,其他大多数高级语言没有“赋值表达式”这一概念,
问题,c语言中的赋值语句于其他高级语言的赋值语句有什么不同点?
C程序设计(第三版) 2009-7-31
4.3 数据输入输出的概念及在 C
语言中的实现
(一 ).所谓输入输出是以计算机主机为主体而言的输出,从计算机向外部输出设备 (显示器,打印机 )
输出数据输入,从输入设备 (键盘,鼠标,扫描仪 )向计算机输入数据,
C程序设计(第三版) 2009-7-31
(二 ).C语言本身不提供输入输出语句,输入和输出操作是由 C函数库中的函数来实现的例如,
字符输入函数,getchar 字符输出函数,putchar
格式输入函数,scanf 格式输出函数,printf
字符串输入函数,gets 字数串输出函数,puts
4.3 数据输入输出的概念及在 C
语言中的实现
C程序设计(第三版) 2009-7-31
(三 ).在使用系统库函数时,要用预编译命令,#include”
将有关的,头文件,包括到用户源文件中,
例如,在调用标准输入输出库函数时,文件开头应该有:
#include,stdio.h”
或:
#include <stdio.h> 头文件
4.3 数据输入输出的概念及在 C 语言中的实现
C程序设计(第三版) 2009-7-31
4.4 字符数据的输入输出
(一),字符输出函数
一般形式,putchar( c)
函数作用:向终端输出一个字符字符型变量整型变量
C程序设计(第三版) 2009-7-31
4.4 字符数据的输入输出例 4.1 输出单个字符。
#include<stdio.h>
void main()
{
char a,b,c;
a=?B?;b=?O?;c=?Y?;
putchar(a);putchar(b);putchar(c);putchar(?\n?);
}
运行结果,BOY
putchar(a);putchar(?\n?);putchar(b);putchar(?\n?);putchar(c);putchar(?\n?);
运行结果,B
O
Y
C程序设计(第三版) 2009-7-31
4.4 字符数据的输入输出
(二),字符输入函数
一般形式,getchar()
函数作用:从终端(或系统隐含指定的输入设备)输入一个字符。
函数值,从输入设备得到的字符。
C程序设计(第三版) 2009-7-31
4.4 字符数据的输入输出例 4.2 输入单个字符。
#include<stdio.h>
void main()
{
char c;
c=getchar();
putchar(c);
putchar(?\n?);
}
运行程序:
从键盘输入字符 ‘ a’
按 Enter键屏幕上将显示输出的字符 ‘ a’
a
a
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(一),格式输出函数
函数作用:向终端(或系统隐含指定的输出设备)输出 若干个任意类型 的数据。
一般格式,printf(格式控制,输出表列)
%d:以带符号的十进制形式输出整数
%o:以八进制无符号形式输出整数
%x:以十六进制无符号形式输出整数
To be continued……
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
%u:以无符号十进制形式输出整数
%c:以字符形式输出,只输出一个字符
%s:输出字符串
%f:以小数形式输出单,双精度数,隐含输出六位小数
%e:以指数形式输出实数
%g:选用 %f或 %e格式中输出宽度较短的一种格式,不输出无意义的 0
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出几种常见的格式符的修饰符:
L:用于长整型整数,可加在格式符 d,o,x,u前面
M(代表一个正整数):数据最小宽度
N(代表一个正整数):对实数,表示输出 n位小数;
对字符串,表示截取的字符个数
—:输出的数字或字符在域内向左靠
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(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);
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(2) o格式符 。以八进制整数形式输出。
输出的数值不带符号,符号位也一起作为八进制数的一部分输出。
例,int a=-1;
printf("%d,%o",a,a);
-1在内存单元中的存放形式(以补码形式存放)如下:
1111111111111111
输出为,
-1,177777
不会输出带负号的八进制整数。对长整数(long型)可以用,%lo,格式输出。还可以 指定字段宽度,
例,printf( "%8o ",a) ;
输出为,177777。 (数字前有 2个空格 )
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(3)x格式符 。以十六进制数形式输出整数。同样不会出现负的十六进制数。
例,int a=-1;
printf( ″ %x,%o,%d ″,a,a,a);
输出结果为,
ffff,177777,-1
可以用,%lx,输出长整型数,也可以 指定输出字段的宽度例,,%12x,
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(4)u格式符,用来输出unsigned型数据,
一个有符号整数(int型)也可以用%u格式输出;
一个unsigned型数据也可以用%d格式输出。
unsigned型数据也可用%o或%x格式输出。
(5)c格式符,用来输出一个字符。
如,char d= ′ a ′ ;
printf( ″ %c ″,d);
输出字符 ′ a ′.
一个整数,只要它的值在0~255范围内,可以用
,%c,使之按字符形式输出,在输出前,系统会将该整数作为 ASCII码转换成相应的字符;一个字符数据也可以用整数形式输出。
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.3 无符号数据的输出。
#include<stdio.h>
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);
}
运行结果:
a=-1,177777,ffff,65535
b=-2,177776,fffe,65534
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.4 字符数据的输出。
#include<stdio.h>
void main()
{
char c=?a?;
int i=97;
printf(“%c,%d\n”,c,c);
printf(“%c,%d\n”,i,i);
}
运行结果:
a,97
a,97指定输出字数的宽度,printf(“%3c”,c);
则输出:
a
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(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值。
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.5字符串的输出。
#include<stdio.h>
void main()
{
printf(“%3s,%7.2s,%.4s,%-5.3s\n”,“CHINA”,“CHINA”,“CHINA”,
“CHINA”);
}
运行结果:
CHINA,CH,CHIN,CHI
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(7)f格式符。 用来以小数形式输出实数(包括单双精度)
有以下几种用法:
① %f。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出6位小数。应当注意,在输出的数字中并非全部数字都是有效数字。单精度实数的有效位数一般为7位。
②%m,nf。指定输出的数据共占m列,其中有n位小数。如果数值长度小于m,则左端补空格。
③%-m,nf与%m,nf基本相同,只是使输出的数值向左端靠,右端补空格。
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.6 输出实数时的有效位数。
#include <stdio.h>
void main()
{
float x,y;
x=111111.111;
y=222222.222;
printf(“%f”,x+y);

运行结果:
333333,328125
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.7输出双精度数时的有效位数。
#include <stdio.h>
void main()
{
double x,y;
x=1111111111111.111111111;
y=2222222222222.222222222;
printf(“%f”,x+y);

运行结果:
3333333333333.333010
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.8 输出实数时指定小数位数。
#include <stdio.h>
void main()
{
float f=123.456;
printf(“%f%10f%10.2f%.2f%-10.2f\ n”,f,f,f,f,f);
}
运行结果:
123.455994 123.455994 123.46 123.46 123.46
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(8)e格式符,以指数形式输出实数。
可用以下形式:
① %e。不指定输出数据所占的宽度和数字部分的小数位数,
例,
printf( ″ %e ″,123.456);
输出:
1.234560 e+002
6列 5列所输出的实数共占13列宽度。 (注:不同系统的规定略有不同 )
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
② % 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
13列 13列 10列 9列
1.23e+002
10列说明,
未指定n,自动使n=6,
超过给定的10列,乃突破10列的限制,按实际长度输出。
第 3个数据共占10列,小数部分占2列。
只指定n=2,未指定m,自动使m等于数据应占的长度。
第 5个数据应占10列,数值只有9列,由于是,%-10.2e,
数值向左靠,右补一个空格。
(注:有的 C系统的输出格式与此略有不同 )
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(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格式用得较少。
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出说明:
除了 X,E,G外,其他各式字符必须用小写。
可以在 printf函数中的“格式控制”字符串中包含转义字符。
一个格式说明必须以,%”开头,以 9个格式字符之一为结束,中间可以插入附加格式字符。
想输出 %,则应该在格式控制字符串中用连续两个 %表示
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出
(一),格式输入函数
函数作用:按照变量在内存的地址将变量值存进去。
一般格式,scanf(格式控制,地址表列)
同 printf函数是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出例 4.9 用 scanf函数输入数据。
#include<stdio.h>
void main()
{
int a,b,c;
scanf(“%d%d%d”,&a,&b,&c);
printf(“%d,%d,%d\n”,a,b,c);
}
运行情况:
3 4 5 (输入 a,b,c的值 )
3,4,5 (输出 a,b,c的值)
a在内存中的地址
&是地址运算符
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出说明:
对 unsigned型变量所需要的数据,可以用 %u,%d或 %o,
%x格式输入。
可以指定输入数据所占的列数,系统自动按它截取所需数据。
如果在 %后有一个,*”附加说明符,表示跳过它指定的列数。
输入数据时不能规定精度。
C程序设计(第三版) 2009-7-31
4.5 格式输入与输出使用scanf函数时应注意的问题,
(1)scanf函数中的,格式控制,后面应当是变量地址,而不应是变量名。
(2) 如果在,格式控制,字符串中除了格式说明以外还有其他字符,
则在输入数据时在对应位置应输入与这些字符相同的字符。
(3) 在用,%c,格式输入字符时,空格字符和,转义字符,都作为有效字符输入
(4) 在输入数据时,遇以下情况时认为该数据结束。
① 遇空格,或按,回车,或,跳格,( Tab)键;
② 按指定的宽度结束,如,%3d,,只取3列;
③ 遇非法输入。
C程序设计(第三版) 2009-7-31
补充:程序设计的一般方法程序就是按照某种算法,在有限的步骤内对一些经过整理的、按照一定形式组织起来的有关联的数据(即数据结构)进行分析研究,得到期望的结果的计算机可以执行的指令序列。所以,数据结构和算法是程序设计的主要因素。
程序设计的一般方法可以概括为以下四个步骤:
明确处理对象、选择算法
画流程图
编写程序
调试程序
C程序设计(第三版) 2009-7-31
C语言的顺序结构
顺序结构是结构化程序设计的三种基本结构中最简单的。
它可以独立存在,也可以出现在选择结构或循环结构中,
函数、一段程序或者语句是按照出现的先后顺序执行的。
C程序设计(第三版) 2009-7-31
4.6 顺序结构程序设计举例例 4.10 输入三角形的三边长,求三角形面积。
首先需要明确处理对象,选择适合的算法根据数据特点和取值范围,浮点型的数据可以很好的表示三角形的边长和面积。
假设:三个边长 a,b,c能构成三角形。
已知面积公式:
area=
s=(a+b+c)*0.5
c)b ) ( sa ) ( ss ( s
开始输入三边长计算 s
计算面积结束第二步画流程图
C程序设计(第三版) 2009-7-31
4.6 顺序结构程序设计举例
#include<stdio.h>
#include<math.h>
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);}
数学函数库因为要用到其中的 sqrt
函数运行情况:
3,4,6
a= 3.00,b= 4.00,c= 6.00,s= 6.50
area= 5.33
C程序设计(第三版) 2009-7-31
4.6 顺序结构程序设计举例例 4.11 从键盘输入一个大写字母,要求改用小写字母输出。
#include <stdio.h>
void main()

char c1,c2;
c1=getchar();
printf(“%c,%d\n”,c1,c1);
c2=c1+32;
printf(“%c,%d\n”,c2,c2);

运行情况:
A ↙
A,65
a,97
C程序设计(第三版) 2009-7-31
4.6 顺序结构程序设计举例例 4.12 求a x2+bx+c=0方程的根。
a,b,c由键盘输入,设 >0。
众所周知,一元二次方程式的根为
x1= x2=
可以将上面的分式分为两项:
p=,q= x1=p+q,x2=p-q
acb 42?
a
acbb
2
42 a acbb 2 4
2
a
b
2
a
acb
2
42?
C程序设计(第三版) 2009-7-31
4.6 顺序结构程序设计举例
#include <stdio.h>
#include <math.h>
void main ( )
{
float a,b,c,disc,x1,x2,p,q;
scanf("a=%f,b=%f,c=%f",&a,&b,&c);
disc=b*b-4*a*c;
p=-b/(2*a);
q=sqrt(disc)/(2*a);
x1=p+q;x2=p-q;
printf("\n\nx1=%5.2f\nx2=%5.2f\n",x1,x2);
}
运行情况:
a=1,b=3,c=2 ↙
x1=-1.00
x2=-2.00