收藏 分享(赏)

C语言程序设计(第三版)第三章.ppt

上传人:hwpkd79526 文档编号:10024018 上传时间:2019-09-29 格式:PPT 页数:113 大小:1.15MB
下载 相关 举报
C语言程序设计(第三版)第三章.ppt_第1页
第1页 / 共113页
C语言程序设计(第三版)第三章.ppt_第2页
第2页 / 共113页
C语言程序设计(第三版)第三章.ppt_第3页
第3页 / 共113页
C语言程序设计(第三版)第三章.ppt_第4页
第4页 / 共113页
C语言程序设计(第三版)第三章.ppt_第5页
第5页 / 共113页
点击查看更多>>
资源描述

1、第3章 最简单的C程序设计,3.1 顺序程序设计举例 3.2 数据的表现形式及其运算 3.3 C语句 3.4 数据的输入输出,3.1顺序程序设计举例,例3.1 有人用温度计测量出用华氏法表示的温度(如 F),今要求把它转换为以摄氏法表示的温度(如 C) 。,解题思路:找到二者间的转换公式,f代表华氏温度,c代表摄氏温度,3.1顺序程序设计举例,#include int main ( ) float f,c; f=64.0; c=(5.0/9)*(f-32); printf(“f=%fnc=%fn“,f,c); return 0;,定义f和c为单精度浮点型变量,指定f的值,计算c的值,输出f和c

2、的值,3.1顺序程序设计举例,例3.2 计算存款利息。有1000元,想存一年。有三种方法可选:(1)活期,年利率为r1(2)一年期定期,年利率为r2(3)存两次半年定期,年利率为r3请分别计算出一年后按三种方法所得到的本息和。,3.1顺序程序设计举例,解题思路:确定计算本息和的公式。 从数学知识可知:若存款额为p0,则: 活期存款一年后本息和为: p1=p0(1+r1) 一年期定期存款,一年后本息和为: p2=p0(1+r2) 两次半年定期存款,一年后本息和为:,3.1顺序程序设计举例,#include int main ( )float p0=1000, r1=0.0036,r2=0.022

3、5,r3=0.0198, p1, p2, p3; p1 = p0 * (1 + r1); p2 = p0 * (1 + r2); p3 = p0 * (1 + r3/2) * (1 + r3/2); printf(”%fn%fn%fn”,p1, p2, p3); return 0;,定义变量同时赋予初值,3.2 数据的表现形式及其运算,3.2.1 常量和变量 3.2.2 数据类型 3.2.3 整型数据 3.2.4 字符型数据 3.2.5 浮点型数据 3.2.6 怎样确定常量的类型 3.2.7 运算符和表达式,3.2.1 常量和变量,1.常量:在程序运行过程中,其值不能被改变的量 整型常量:如1

4、000,12345,0,-345,整型常量的三种表示形式,十进制整数。如:123, -456。 八进制整数。以0开头的数是八进制数。如:0123表示八进制数123,等于十进制数83; -011表示八进制数-11,即十进制数-9。 十六进制整数。以0x开头的数是16进制数。如:0x123,代表16进制数123,等于十进制数 291。 -0x12等于十进制数10。,3.2.1 常量和变量,1.常量:在程序运行过程中,其值不能被改变的量 实型常量 十进制小数形式:如0.34 -56.79 0.0 指数形式:如12.34e3 (代表12.34103),实型常量的表示方法,两种表 示形式,小数 指数,0

5、.123 3e-3,1e3、1.8e-3、-123e-6、-.1e-3 e3、2.1e3.5、.e3、e,注意:字母e(或E)之前必须有数字,且e (或E)后面的指数必须为整数。,字符常量,1.常量:在程序运行过程中,其值不能被改变的量 (1)用单撇号括起来的一个字符,不包括单撇号。a A ?注意:字符常量在计算机存储单元中,并不是存储字符本身,而是以其代码存储的。 (2)转义字符:以“”开头的特殊字符。n 换行 t 水平制表r 回车 反斜杠ddd ddd 1到3位八进制数字(ASCII码值)xhh hh表示1到2位十六进制数字(ASCII码值)见P40 表3.1,P377 附录B。,3.2.

6、1 常量和变量,1.常量:在程序运行过程中,其值不能被改变的量 字符串常量: 用双撇号把若干个字符括起来,字符串常量是双撇号中的全部字符(但不包括双撇号)如”boy” 符号常量:用#define指令,指定用一个符号名称代表一个常量。#define PI 3.1416,例 常量与符号常量的使用 #include #define PRICE 30 int main ( ) int num, total;num=10;total=num * PRICE;printf(“total=%dn“,total);return 0; ,3.2.1 常量和变量,2. 变量:在程序运行期间,变量的值是可以改变的

7、变量必须先定义,后使用 定义变量时指定该变量的名字和类型 变量名和变量值是两个不同的概念 变量名实际上是以一个名字代表的一个存储地址 从变量中取值,实际上是通过变量名找到相应的内存地址,从该存储单元中读取数据,3.2.1 常量和变量,3.常变量:const int a=3; 4.标识符:一个对象的名字(变量,符号常量,函数等) 语言规定标识符只能由字母、数字和下划线3种字符组成,且第一个字符必须为字母或下划线 合法的标识符:如sum,average, _total, Class, day, BASIC, li_ling 不合法的标识符:M.D.John,¥123,33,3D64,ab,注意:

8、1.区别大小写。 如sum与SUM为不同的变量名,但一般变量名用小写字母,符号常量采用大写字母。 2.标识符必须先定义后使用。 分配单元、 确定类型、语法检查 3.在一个程序单元中(分程序或函数中)不能重复定义。 4.关键字(P378 附录C)不能作为标识符。,3.2.2 数据类型,所谓类型,就是对数据分配存储单元的安排,包括存储单元的长度(占多少字节)以及数据的存储形式不同的类型分配不同的长度和存储形式,3.2.2 数据类型,C语言允许使用的数据类型: 基本类型 整型类型 基本整型 短整型 长整型 双长整型 字符型 布尔型,浮点类型 单精度浮点型 双精度浮点型 复数浮点型,3.2.2 数据类

9、型,C语言允许使用的数据类型: 基本类型 枚举类型 空类型 派生类型 指针类型 数组类型 结构体类型 共用体类型 函数类型,算术类型(存放的数值),纯量类型(存放的数字),3.2.3 整型数据,1. 整型数据的分类 最基本的整型类型 基本整型(int型):占2个或4个字节在存储单元中,用整数的补码形式存放。 短整型(short int):VC+6.0中占2个字节 长整型(long int):VC+6.0中占4个字节 双长整型(long long int):C99新增的,整数类型的有关数据:,类型 类型说明符 长度 数的范围 基本型 int 2字节 -3276832767 短整型 short 2

10、字节 -215215-1 长整型 long 4字节 -231231-1 无符号整型 unsigned 2字节 065535 无符号短整型 unsigned short 2字节 065535 无符号长整型 unsigned long 4字节 0(232-1)注:对应不同的机器和编译系统,各类数据所占内存字节数不尽相同,因此数值范围也不同。,例 整型变量的定义与使用,#include int main ( ) int a,b,c,d;unsigned u; a=12;b=-24;u=10;c=a+u;d=b+u;printf(“a+u=%d,b+u=%dn“,c,d); return 0;,运行结

11、果: a+u=22 b+u=-14,整型变量的定义 C 语言必须给在程序中用到的所有的变量指定其类型 变量定义必须放在函数的开头部分,例 整型数据的溢出,#include int main() int a,b; a=32767;b=a+1;printf(“%d,%dn“,a,b);return 0; /假设int占两个字节,运行结果: 32767,-32768,运行结果分析: 有符号整型变量的范围为-3276832767,运算结果超出此范围,发生“溢出”。 发生“溢出”时,编写的程序如果没有对此情况进行处理,则程序将根据错误的结果继续运行。,3.2.4 字符型数据,字符是按其代码(整数)形式存

12、储的 C99把字符型数据作为整数类型的一种 字符型数据在使用上有自己的特点,3.2.4 字符型数据,1.字符与字符代码(共127个字符) 大多数系统采用ASCII字符集 字母:A Z,a z 数字:09 专门符号:29个:! ” # & ( ) *等 空格符:空格、水平制表符、换行等 不能显示的字符:空(null)字符(以0表示)、警告(以a表示)、退格(以b表示)、回车(以r表示)等,3.2.4 字符型数据,字符1和整数1是不同的概念: 字符1只是代表一个形状为1的符号,在需要时按原样输出,在内存中以ASCII码形式存储,占1个字节整数1是以整数存储方式(二进制补码方式)存储的,占2个或4个

13、字节,3.2.4 字符型数据,2.字符变量 用类型符char定义字符变量char c = ?;系统把?的ASCII代码63赋给变量c printf(”%d %cn”,c,c); 输出结果是:63 ?,例 向字符变量赋以整数,#include int main() char c1,c2;c1=97;c2=98;printf(“%c %cn“,c1,c2);printf(“%d %dn“,c1,c2);return 0; ,运行结果: 97 98,3.2.5 浮点型数据,浮点型数据是用来表示具有小数点的实数 float型(单精度浮点型) 编译系统为float型变量分配4个字节 数值以规范化的二进制

14、数指数形式存放参见主教材图3.11 double型(双精度浮点型) 编译系统为double型变量分配8个字节 15位有效数字 long double(长双精度)型,3.2.6 怎样确定常量的类型,字符常量:由单撇号括起来的单个字符或转义字符。 整型常量:不带小数点的数值,数字跟l或L表示长整型;跟u或U表示无符号整型。 系统根据数值的大小确定int型还是long型等 浮点型常量:凡以小数形式或指数形式出现的实数 C编译系统把浮点型常量都按双精度处理(数字跟f或F表示单精度浮点型),类型与变量的区分:每个变量都属于一个确定的数据类型 类型是变量的一个重要属性,变量是占用存储单元,是具体存在的实体

15、,在其占用的存储单元中可以存放数据 类型是变量的共性,是抽象的,不占用存储单元,不能用来存放数据,3.2.7 运算符和表达式,1.基本的算术运算符: + :正号运算符(单目运算符)- :负号运算符(单目运算符) * :乘法运算符 / :除法运算符 % :求余运算符 + :加法运算符- :减法运算符,3.2.7 运算符和表达式,说明 两个整数相除的结果为整数 如5/3的结果值为,舍去小数部分 如果除数或被除数中有一个为负值,舍入方向不固定。例如,-5/3,有的系统中得到的结果为-1,在有的系统中则得到结果为-2 VC+采取“向零取整”的方法如5/3=1,-5/3=-1,取整后向零靠拢% 运算符要

16、求参加运算的运算对象(即操作数)为整数,结果也是整数。如8%3,结果为2,请回答:例题3.1中摄氏温度的计算公式: C=5.0/9*(f-32),3.2.7 运算符和表达式,2. 自增(+)、自减(-)运算符: 作用是使变量的值加或减 +i,-i:在使用i之前,先使i的值加(减)1 i+,i-:在使用i之后,使i的值加(减)1 例如(i=3) j=+i 如果运算之前i的值为3,则运算后i的值为4,j的值也为4。 j=i+ 如果运算之前i的值为3,则运算后i的值为4,j的值却为3,3.2.7 运算符和表达式,2. 自增、自减运算符: 注意: 1.自增、自减运算不能用于常量和表达式如:3+,(a+

17、b)+。 2.为避免二义性,可以加一些“不必要”的括号。,3.2.7 运算符和表达式,3. 算术表达式和运算符的优先级与结合性: C 算术表达式: 用算术运算符和圆括号将运算对象(也称操作数)连接起来的、符合C语法规则的式子。 运算对象: 常量、变量、函数 等。 优先级: 对于算术运算, 必须掌握其优先级具体见P378(附录D) 结合性: 一个运算对象两边有两个优先级相同的运算符时,该运算对象先和左边的运算符结合称左结合性,如先和右边的运算符结合称右结合性。,3.2.7 运算符和表达式,4.不同类型数据间的混合运算: +、-、*、/ 运算的两个数中有一个数为float或double型,结果是d

18、ouble型。系统将float型数据都先转换为double型,然后进行运算 (2) 如果int型与float或double型数据进行运算,先把int型和float型数据转换为double型,然后进行运算,结果是double型 (3)字符型数据与整型数据进行运算,就是把字符的ASCII代码与整型数据进行运算 以上的转换是编译系统自动完成的。,各类数值型数据间的混合运算,混合运算:字符型、整型和浮点型。在进行运算时,不同类型的数据要先转换成同一类型,然后进行运算(这种类型转换由系统自动进行的)。,3.2.7 运算符和表达式,例3.3 给定一个大写字母,要求用小写字母输出,解题思路: 关键是找到大、

19、小写字母间的内在联系 同一个字母,用小写表示的字符的ASCII代码比用大写表示的字符的ASCII代码大32,3.2.7 运算符和表达式,#include int main ( ) char c1,c2;c1=A; c2=c1+32; printf(“%cn“,c2); printf(”%dn”,c2); return 0; ,3.2.7 运算符和表达式,#include int main ( ) char c1,c2;c1=A; c2=c1+32; printf(“%cn“,c2); printf(”%dn”,c2); return 0; ,将字符A的ASCII代码65放到c1中,将65+32

20、的结果放到c2中,用字符形式输出,用十进制形式输出,3.2.7 运算符和表达式,5. 强制类型转换运算符 强制类型转换运算符的一般形式为(类型名)(表达式) (double)a (将转换成double类型) (int) (x+y) (将x+y的值转换成int型) (float)(5%3)(将5%3的值转换成float型) 有两种类型转换 系统自动进行的类型转换 强制类型转换 注意:在强制类型转换时,得到一个所需类型的中间数据,而原来变量的类型未发生变化,3.2.7 运算符和表达式,6.运算符 (1) 算术运算符 (+ - * / % + -) (2) 关系运算符 ( !) (3) 逻辑运算符

21、(! | ) (4) 位运算符 ( | ) (5) 赋值运算符 (及其扩展赋值运算符) (6) 条件运算符 (?:),3.2.7 运算符和表达式,6.运算符 (7) 逗号运算符 (,) (8) 指针运算符 (*和) (9) 求字节数运算符 (sizeof) (10) 强制类型转换运算符 ( (类型) ) (11) 成员运算符 (.-) (12) 下标运算符 ( ) (13) 其他 (如函数调用运算符(),3.3 C语句,3.3.1 C语句的作用和分类 3.3.2 最基本的语句-赋值语句,3.3.1 C语句的作用和分类,语句分为以下5类: (1) 控制语句: if、switch、for、whil

22、e、dowhile、continue、break、return、goto等 (2) 函数调用语句:由一个函数调用加一个分号构成。如printf()函数调用。,3.3.1 C语句的作用和分类,语句分为以下5类: (3) 表达式语句:由一个表达式加一个分号构成,如赋值语句。 举例:a=3是赋值表达式,a=3;是赋值语句。 (4) 空语句:只有一个分号的语句。 (5) 复合语句:用把一些语句和声明括起来成为复合语句。,3.3.2 最基本的语句-赋值语句,在C程序中,最常用的语句是: 赋值语句 输入输出语句 其中最基本的是赋值语句,3.3.2 最基本的语句-赋值语句,例3.4 给出三角形的三边长,求三

23、角形面积。,解题思路:假设给定的三个边符合构成三角形的条件 关键是找到求三角形面积的公式 公式为:其中s=(a+b+c)/2,#include #include int main ( ) double a,b,c,s,area; a=3.67; b=5.43; c=6.21; s=(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(“a=%ftb=%ftc=%fn“,a,b,c); printf(“area=%fn“,area); return 0;,对边长a、b、c赋值,计算s,计算area,#include #include int main

24、( ) double a,b,c,s,area; a=3.67; b=5.43; c=6.21; s=(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(“a=%ftb=%ft%fn“,a,b,c); printf(“area=%fn“,area); return 0;,数学函数,计算平方根,调用数学函数加此行,#include #include int main ( ) double a,b,c,s,area; a=3.67; b=5.43; c=6.21; s=(a+b+c)/2; area=sqrt(s*(s-a)*(s-b)*(s-c);

25、printf(“a=%ftb=%ft%fn“,a,b,c); printf(“area=%fn“,area); return 0;,转义字符,使输出位置跳到下一个tab位置,归纳总结: 1.赋值运算符 “”是赋值运算符 作用是将一个数据赋给一个变量 也可以将一个表达式的值赋给一个变量,归纳总结: 2.复合的赋值运算符 在赋值符“”之前加上其他运算符,可以构成复合的运算符 算术运算的复合赋值运算符有+=,-=,*=,/=,%= = 等价于 x *= y+8 等价于 x=x*(y+8)x%=3 等价于 x=x%3,归纳总结: 3.赋值表达式 一般形式为:变量 赋值运算符 表达式 对赋值表达式求解的

26、过程: 求赋值运算符右侧的“表达式”的值 赋给赋值运算符左侧的变量,归纳总结: 3.赋值表达式 赋值表达式“a=3*5”的值为15,对表达式求解后,变量a的值和表达式的值都是15 “a=b”和“b=a”含义不同,归纳总结: 3.赋值表达式 左值的含义:可以出现在赋值运算符的左侧,值是可以改变的。变量可以作为左值,算术表达式(如a+b)和常量不能作为左值。 左值可以作为右值。 a=(a=b)=3*4,错误,归纳总结: 3.赋值表达式 赋值运算符按照“自右而左”的结合顺序。 “a=(b=5)”和“a=b=5”等价 赋值表达式可以包含复合的赋值运算符。 a+=a-=a*a;(a初值为12),归纳总结

27、: 3.赋值表达式 赋值表达式可以以表达式的形式出现在其他语句中。 printf(“%d”,a=b); 完成了赋值和输出的双重功能,归纳总结: 4.赋值过程中的类型转换 两侧类型一致时,直接赋值 两侧类型不一致,但都是算术类型时,自动将右侧的类型转换为左侧类型后赋值 将浮点型数据(单、双精度)赋给整型变量时,先对浮点取整,舍弃小数部分,然后赋予整型变量。,将整型数据赋给单双精度变量时,数值不变,但以浮点形式存储到变量中。 将一个double型数据赋给float变量时,先将双精度数转换为单精度,只取6-7位有效数字,存储到float变量的4个字节中。 将一个float型数据赋给double变量时

28、,数值不变,在内存中以8个字节存储,有效位数扩展到15位。,字符型赋给整型变量时,将字符的ASCII代码赋给整型变量。 将一个占字节多的整型数据赋给一个占字节少的整型变量或字符变量时,只将其低字节原封不动地送到被赋值的变量。例如:int i=289;char c=a;c=i; 定义变量时要防止数据溢出,归纳总结: 5.赋值表达式和赋值语句 赋值表达式的末尾没有分号,而赋值语句有分号 一个表达式可以包含赋值表达式,但决不能包含赋值语句如:int a ,b ,c,d;a=1;b=2;c=3; a = c % b +( d = b;) - c;/语句1a = c % b +( d = b) - c

29、;/语句2,错误,正确,归纳总结: 6.变量赋初值:可以用赋值语句对变量赋值,也可以在定义变量时对变量赋以初值,也可以对定义的变量的一部分赋以初值。如: int a=3,b=3,c; int a=3; 相当于 int a; a=3; int a=b=c=3; 错,3.4 数据的输入输出,3.4.1 输入输出举例 3.4.2 有关数据输入输出的概念 3.4.3 用printf函数输出数据 3.4.4 用scanf函数输入数据 3.4.5 字符数据的输入输出,3.4.1 输入输出举例,例3.5 求 方程的根。a、b、c由键盘输入设 ,3.4.1 输入输出举例,解题思路:首先要知道求方程式的根的方法

30、。 由数学知识已知:如果 0,则一元二次方程有两个实根:,若记,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q;scanf(“%lf%lf%lf“, ,程序中调用数学函数sqrt,输入a,b,c的值,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q;scanf(“%lf%lf%lf“, ,输入的是双精度型实数,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q;scanf(“%lf%lf%lf

31、“, ,要求输入3个实数,自动转成实数后赋给a,b,c,#include #include int main ( ) double a,b,c,disc,x1,x2,p,q;scanf(“%lf%lf%lf“, ,输出数据占7列,其中小数占2列,3.4.2 有关数据输入输出的概念,几乎每一个C程序都包含输入输出 输入输出是程序中最基本的操作之一,3.4.2 有关数据输入输出的概念,语言本身不提供输入输出语句 输入和输出操作是由C标准函数库中的函数来实现的 printf和scanf不是语言的关键字,而只是库函数的名字 putchar、getchar、puts、gets,3.4.2 有关数据输入输

32、出的概念,在使用输入输出函数时,要在程序文件的开头用预编译指令 #include (按标准方式查找) 或 #include stdio.h(用户先从当前目录中寻找要包含的文件,如果找不到,再按标准方式查找。),3.4.3 用printf函数输出数据,1.printf函数的一般格式 printf(格式控制,输出表列) 格式控制是用双撇号括起来的一个字符串 例如: printf(”i=%d,c=%cn”,i,c);,格式声明,格式声明由%和格式字符组成。,3.4.3 用printf函数输出数据,1.printf函数的一般格式 printf(格式控制,输出表列) 例如: printf(”i=%d,c

33、=%cn”,i,c);,普通字符,普通字符即需要在输出时原样输出的字符,3.4.3 用printf函数输出数据,1.printf函数的一般格式 printf(格式控制,输出表列) 输出表列:在程序中需要输出的一些数据 例如: printf(”i=%d,c=%cn”,i,c);,可以是常量、变量或表达式,3.4.3 用printf函数输出数据,2. 常用格式字符 格式符。用来输出一个有符号的十进制整数 可以在格式声明中指定输出数据的域宽printf(”%5d%5dn”,12,-345);输出数据显示在五列区域的右侧。 %d输出int型数据 %ld输出long型数据,3.4.3 用printf函数

34、输出数据,2. 常用格式字符 格式符。用来输出一个字符char ch=a;printf(”%c”,ch); 或printf(”%5c”,ch); /指定域宽,输出字符: a,3.4.3 用printf函数输出数据,2. 常用格式字符 格式符。 一个整数如果在0-127范围中,可以用%c格式输出。如:short a=121;printf(“%c”,a);,如果整数比较大,则把它的最后一个字节的信息以字符形式输出。如:int a=377;printf(“%c”,a);,3.4.3 用printf函数输出数据,2. 常用格式字符 格式符。用来输出一个字符串printf(”%s”,”CHINA”);,

35、输出字符串:CHINA,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数(包括单、双精度、长双精度),以小数形式输出。 不指定数据宽度和小数位数,用%f。 系统处理的方法一般是:实数中的整数部分全部输出,小数部分输出6位。例3.6 double a=1.0;printf(”%fn”,a/3);,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。 指定数据宽度和小数位数。用%m.nf。printf(“%20.15fn“,1/3);printf(“%.0fn”,10000/3.0);,3.4.3 用printf函数输出数据,2. 常用格式字符

36、f格式符。用来输出实数,以小数形式输出 输出的数据向左对齐,用%-m.nf,3.4.3 用printf函数输出数据,2. 常用格式字符 f格式符。用来输出实数,以小数形式输出 float型数据只能保证6位有效数字 double型数据能保证15位有效数字 计算机输出的数字不都是绝对精确有效的,3.4.3 用printf函数输出数据,2. 常用格式字符 e格式符。指定以指数形式输出实数 %e,VC+给出小数位数为位,指数部分占5列,小数点前必须有而且只有1位非零数字。 例: printf(”%e”,123.456);输出:1.234560 e+002,3.4.3 用printf函数输出数据,2.

37、常用格式字符 e格式符。指定以指数形式输出实数 %m.neprintf(”%13.2e”,123.456);输出: 1.23e+002 (前面有4个空格),3.4.3 用printf函数输出数据,3. 另外格式字符 i格式符。作用与d格式符相同,按十进制整型数据的实际长度输出。 o格式符。以八进制整数形式输出。输出的数值不带符号,即符号位也作为八进制数的一部分输出。如:int a=-1; printf(“%dt%on”,a,a);,3.4.3 用printf函数输出数据,3. 另外格式字符 x格式符。以十六进制无符号形式输出整数。 u格式符。以十进制无符号形式输出整数。 g格式符。用来输出浮点

38、数,系统自动选f格式或e格式输出,选择其中长度较短的格式,不输出无意义的0。 例:double a=12345678954321;printf(“%ft%et%gn”,a,a,a);,printf的格式控制的完整格式:% - 0 m.n l或h 格式字符下面对组成格式说明的各项加以说明: %:表示格式说明的起始符号,不可缺少。 -:有-表示左对齐输出,如省略表示右对齐输出。 0:有0表示指定空位填0,如省略表示指定空位不填。 m.n:m指域宽,即对应的输出项在输出设备上所占的字符数。n指精度。用于说明输出的实型数的小数位数。未指定n时,隐含的精度为n=6位。 l或h:l对整型指long型,对实

39、型指double型。h用于将整型的格式字符修正为short型。,说明,除了X,E,G外,其他各式字符必须用小写。 可以在printf函数中的“格式控制”字符串中包含转义字符。 一个格式说明必须以“%”开头,以12个格式字符之一为结束,中间可以插入附加格式字符。 如果需要输出%,则应该在格式控制字符串中用连续两个%表示。如:printf(“%f%n”,1.0/3);,3.4.4 用scanf函数输入数据,1. scanf 函数的一般形式:scanf(格式控制,地址表列),含义同printf函数,3.4.4 用scanf函数输入数据,1. scanf 函数的一般形式:scanf(格式控制,地址表列

40、),可以是变量的地址,或字符串的首地址,3.4.4 用scanf函数输入数据,2. scanf函数中的格式声明 与printf函数中的格式声明相似 以开始,以一个格式字符结束,中间可以插入附加的字符 如:scanf(“a=%f,b=%f,c=%f“,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 (1)scanf函数中的“格式控制”后面应当是变量地址,而不是变量名。 如:scanf(”%f%f%f”,a,b,c); scanf(”%f%f%f”,错,对,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 (2)如果在“格式控制字符串”中除了格

41、式声明以外还有其他字符,则在输入数据时在对应的位置上应输入与这些字符相同的字符。 如:scanf(“a=%f,b=%f,c=%f“,1 3 2 a=1,b=3,c=2 a=1 b=3 c=2,错,对,错,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 (3)在用“%c”格式声明输入字符时,空格字符和“转义字符”中的字符都作为有效字符输入。 如:scanf(”%c%c%c”,abc a b c 在输入数值时,在两个数值之间需要插入空格(或其他分隔符)以区分;在输入字符时,在两个字符之间不要插入空格或其他分隔符。,对,错,3.4.4 用scanf函数输入数据,3.使用s

42、canf函数时应注意的问题 (4)在输入数值数据时,如输入空格、回车、Tab键或遇非法字符(不属于数值的字符),认为该数据结束。 如:scanf(”%d%c%f”, 若输入1234a123o.26,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 (4)在输入数值数据时,如输入空格、回车、Tab键或遇非法字符(不属于数值的字符),认为该数据结束 如:scanf(”%d%c%f”, 若输入1234a123o.26,3.4.4 用scanf函数输入数据,3.使用scanf函数时应注意的问题 (4)在输入数值数据时,如输入空格、回车、Tab键或遇非法字符(不属于数值的字符)

43、,认为该数据结束。 如:scanf(”%d%c%f”, 若输入1234a123o.26,3.4.5 字符数据的输入输出,1.用putchar函数输出一个字符 从计算机向显示器输出一个字符 putchar函数的一般形式为:putchar(c),3.4.5 字符数据的输入输出,例3.8 先后输出BOY三个字符。 解题思路: 定义3个字符变量,分别赋以初值B、O、Y 用putchar函数输出这3个字符变量的值,3.4.5 字符数据的输入输出,#include int main ( ) char a=B,b=O,c=Y; putchar(a); putchar(b); putchar(c); putc

44、har (n); return 0; ,向显示器输出字符B,向显示器输出换行符,3.4.5 字符数据的输入输出,#include int main ( ) char a=B,b=O,c=Y; putchar(a); putchar(b); putchar(c); putchar (n); return 0; ,改为int a=66,b=79,c=89;,3.4.5 字符数据的输入输出,可以用putchar函数输出转义字符 如:putchar(101) putchar() 说明:putchar(c)中的参数c可以是字符常量、整型常量、字符变量或整型变量(其值在字符的ASCII代码范围内)。,(输

45、出字符),(输出单撇号字符),3.4.5 字符数据的输入输出,2. 用getchar函数输入一个字符 向计算机输入一个字符 getchar函数的一般形式为:getchar( ),3.4.5 字符数据的输入输出,例3.9 从键盘输入BOY三个字符,然后把它们输出到屏幕。 解题思路: 用3个getchar函数先后从键盘向计算机输入BOY三个字符 用putchar函数输出,3.4.5 字符数据的输入输出,#include int main ( ) char a,b,c; a=getchar(); b=getchar(); c=getchar(); putchar(a); putchar(b); pu

46、tchar(c); putchar(n); return 0; ,输入一个字符,送给变量a,3.4.5 字符数据的输入输出,#include int main ( ) char a,b,c; a=getchar(); b=getchar(); c=getchar(); putchar(a); putchar(b); putchar(c); putchar(n); return 0;,putchar(getchar();,3.4.5 字符数据的输入输出,#include int main ( ) char a,b,c; a=getchar(); b=getchar(); c=getchar(); putchar(a); putchar(b); putchar(c); putchar(n); return 0;,

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 企业管理 > 管理学资料

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报