1、C C语言程序设计语言程序设计Copyer:Vigiking 第一章第一章 计算机语言与计算机语言与C C语言概述语言概述 1.1 1.1 计算机语言概念计算机语言概念 计算机语言定义计算机语言定义 计算机能够识别和接受的语言。计算机能够识别和接受的语言。要使计算机按自己的意图工作,必要使计算机按自己的意图工作,必须使用计算机所能接受、理解和执须使用计算机所能接受、理解和执行的指令指挥计算机工作。行的指令指挥计算机工作。计算机语言的种类计算机语言的种类机器语言机器语言低级语言低级语言 汇编语言汇编语言(面向计算机面向计算机)BASIC入门语言入门语言F77科学计算科学计算高级语言高级语言Fox
2、pro数据库管数据库管理理 (面向问题面向问题)C多用途多用途计算机语言机器语言机器语言 最早问世,用二进制代码构成指令。最早问世,用二进制代码构成指令。如:如:100000 100000 (+)110000 110000(-)用机器语言编程的缺点:用机器语言编程的缺点:繁琐、不直观、不易调试。繁琐、不直观、不易调试。如计算如计算y=2xy=2x2 2+3x-1+3x-1需要七八条指令。需要七八条指令。移植性差。移植性差。依赖于计算机。依赖于计算机。汇编语言汇编语言 用符号构成指令,如:用符号构成指令,如:MOVMOV、ADDADD 用汇编语言编程:用汇编语言编程:相相对对直直观观,但但仍仍繁
3、繁琐琐,仍仍是是面面向向计计算算机的语言。机的语言。汇编语言是计算机间接接受的语言汇编语言是计算机间接接受的语言高级语言高级语言与低级语言相比,有根本性的区别:是面向问题的语言。高级语言的一条指令(语句):y=2*x*x+3*x-1;对应于:y=2x2+3x-1 y=sin(x);对应于:y=sinx用高级语言编程:用高级语言编程:直观、易懂、移植性好(不依赖于具体计算机)上机运行高级语言程序需经过编译:编译 执行要上机完成一个计算问题,主要的任务就是用高级语言编写出相应的源程序。即至少要学会一种计算机语言。高级语言源程序机器指令目的程序结果编译程序1.2 C1.2 C语言的特点语言的特点集高
4、级语言和低级语言的优点于一身:能实现低级语言的大部分功能(如直接访问内存物理地址、进行位操作等)。图形功能强。运算符和数据结构丰富。语法限制不太严格,程序设计自由度大。生成目标代码质量高,程序执行效率高。1.3 1.3 简单的简单的C C程序介绍程序介绍 例1:main()main()主函数说明 程序框架 printf(printf(“abcdefabcdef”););函数体 语句 程序的功能是输出字符串:abcdef例2:求两数之和。main()inta,b,c;aa=100;b=50;bc=a+b;cprintf(“nc=%d”,c);程序运行结果:c=150例例3 3:求两数中的最大值。
5、:求两数中的最大值。函数类型函数类型 函数名函数名 形参形参main()intmax(intx,inty)inta,b,c;intz;scanf(“%d,%d”,&a,&b);if(xy)z=x;c=max(a,b);elsez=y;printf(“nmaxis:%d”,c);return(z);axbycz(两个函数组成)353555 总结上例可知:总结上例可知:(1 1)C C程序程序由函数构成由函数构成。(2 2)函数由两部分组成:函数由两部分组成:函函数数说说明明部部分分:函函数数名名、函函数数类类型型、形形参名、形参类型。参名、形参类型。函函数数体体:实实现现函函数数的的具具体体操操
6、作作;由由语语句句构成。构成。(3 3)程序总是程序总是从从mainmain函数函数开始执行。开始执行。(4 4)书写格式自由。书写格式自由。(5 5)语句必须有分号。)语句必须有分号。:第二章第二章 算法算法 2 2.1.1 算法的概念算法的概念 要利用计算机处理问题,光学习语言要利用计算机处理问题,光学习语言的语法规则还不够,最重要的是要学会的语法规则还不够,最重要的是要学会针对各类型的问题,拟定出有效的解题针对各类型的问题,拟定出有效的解题方法和步骤。方法和步骤。解题方法和步骤就是算法解题方法和步骤就是算法。算法算法:为了解决一个问题而采取的有限步骤。为了解决一个问题而采取的有限步骤。计
7、算机算法计算机算法:如何使计算机一步一步地工作的具体过程。如何使计算机一步一步地工作的具体过程。利用计算机处理问题的步骤:1)设计好算法算法设计;2)用计算机语言实现算法程序设计。算法必须是“有效”的。算法设计还要充分考虑算法的好坏。衡量算法好坏的主要标准:程序简练。执行速度快。占空间少。例:考虑 的算法。算法:直接表达。直接用语句 s=1+2+3+4+5+6+7+8+9+10当项数较多时该算法不适用s=i110算法:迭代法(累加求和法)s=1+2+3+4+5+6+7+8+9+10 算法步骤:s i 使s=0 +使i=1 累加器 记数器 s+is i+1i 若i10转,否则转 输出s01123
8、364105该算法通用,是好算法2.2 2.2 算法的表示算法的表示 算法需要有统一的表示方法算法需要有统一的表示方法 常用的表示方法有:常用的表示方法有:自然语言自然语言 流程图流程图 结构化流程图结构化流程图 N-SN-S流程图流程图.1、自然语言自然语言对于计算对于计算 s=1+2+3+4+5+6+7+8+9+10s=1+2+3+4+5+6+7+8+9+10 用自然语言表示为:用自然语言表示为:使使s=0s=0 (s s为累加器)为累加器)使使i=1i=1 (i i为计数器)为计数器)s+iss+is (累加求和公式)(累加求和公式)i+1ii+1i (计数器加(计数器加1 1)若若i1
9、0i10转转,否则转否则转 输出输出s s的值的值 特点:通俗易懂、文字冗长、含义不大严格。2、流程图流程图 用流程图符号表示算法。常用的流程图符号 起止框 输入输出框 处理框 流程线 判断框 对于计算 s=1+2+3+4+5+6+7+8+9+10 用流程图表示为:s+i si+1 iS+i sS+i si10输出s0 s1 i直观形象,易于理解,次序清楚YN3、结构化流程图结构化流程图 传统的流程图有一个弊端:对流程线没有严格的限制,对于较复杂的算法可能会变成乱麻一般(BS型算法)。为克服这一弊端,提出了由三个基本结构组成算法流程图的思想:结构化流程图 三个基本结构:顺序结构按固定顺序(从上
10、到下或从左到右)执行的结构。ABab选择结构 根据条件P选择执行哪一个分支。成立不成立 pABab成立不成立例:计算 y=1/x 当x0时 y=10000 当x=0时 的算法流程图图:选择结构输入xX=0?10000y1/xy输出yYN循环结构 重复执行某些操作的结构。分为两种:当型循环和直到型循环。当型循环 直到型循环 P1AAP2aabbYYNN 可以看出,每个基本结构都只有一个入口和一个出口,因此,用三个基本结构构成的流程图不会象乱麻一般,用三个基本结构构成的流程图就成为结构化流程图,用结构化流程图描述的算法称为结构化算法,相应的程序设计就称为结构化程序设计。观察前例:0 s1 iS+i
11、 si+1 ii10输出s顺序结构循环结构yn4N-SN-S流程图流程图N-S流程图的三个基本结构:ABP成立不成立ABAB当P1直到P2顺序结构选择结构循环结构例:计算y=1/x 当x0时 y=10000 当x=0时 的N-S流程图:输入xX=0?是否10000y1/xy输出y 例:计算 s=1+2+3+4+5+6+7+8+9+10 的N-S流程图:i10 直到i10 直到型 当型0 s1 i输出s1 i0 ss+i si+1 is+i si+1 i输出s 第三章第三章 数据类型数据类型、运算符运算符 与与 表达式表达式 3.1 C 3.1 C 的数据类型的数据类型基本类型(整型、实型实型、
12、字符型字符型、枚举型)枚举型)构造类型(略)指针类型(略)空类型 各类型包含常量常量与与变量变量 3.2 3.2 常量与变量常量与变量 常量与符号常量常量与符号常量 常量常量 在程序运行过程中其值保持不变的量。在程序运行过程中其值保持不变的量。符号常量符号常量 用来代表一个常量的标识符。#define PI 3.1415926#define PI 3.1415926 例:例:#define#define PIPI 3.1415926 3.1415926 main()main()float float r r=2,=2,c c;c c=2*=2*PIPI*r r;printf(printf(“%
13、f%f”,c c););变量变量 其值可以改变的量。其值可以改变的量。变量的三要素变量的三要素:变量名变量名每每个个变变量量有有一一个个名名字字,作作为为识识别别该该变变量量的的标标识符。识符。变量的值变量的值 每每个个变变量量有有一一个个值值,变变量量的的值值是是随随时时可可以改变的。以改变的。变量的存储单元变量的存储单元 每每个个变变量量占占据据一一个个内内存存单单元元,用用于于存存放放变变量量的值的值。变量名a变量值存储单元3 变量的命名规则:变量的命名规则:由字母、数字和下划线组成由字母、数字和下划线组成 以字母或下划线开头以字母或下划线开头 a a、x1x1、y_2y_2、_b1_b
14、1、_1c _1c 合法合法 1x1x、a+2a+2、不合法不合法 变量必须先定义后使用。变量必须先定义后使用。程序中何时使用常量?何时使用变量?程序中何时使用常量?何时使用变量?3.3 3.3 整型数据整型数据 整型常量整型常量 即整常数,即整常数,c c的整常数有三种形式:的整常数有三种形式:十进制整数十进制整数 与数学中的整数一致,如:与数学中的整数一致,如:100100,123123,1515等。等。八进制整数八进制整数 以以0 0开头的整数,如:开头的整数,如:010,07,020010,07,020等。等。十六进制整数十六进制整数 以以0 x0 x开头的整数,如:开头的整数,如:0
15、 x10,0 xff,0 x2a0 x10,0 xff,0 x2a等。等。整型变量整型变量 用于存放整数的变量。用于存放整数的变量。分分4 4种类型:种类型:基本型:基本型:int aint a 16 16位,可表示的数值范围:位,可表示的数值范围:-32768-327683276732767 短整型:短整型:short int bshort int b 16 16位,可表示的数值范围:位,可表示的数值范围:-32768-327683276732767 长整型:长整型:long int clong int c 32 32位,数值范围:位,数值范围:-2147483648-21474836482
16、1474836472147483647 无符号型:加上无符号型:加上 unsignedunsigned 只存放正数。只存放正数。如:如:unsigned int xunsigned int x 变量变量x x为无符号整数,为无符号整数,1616位全表示数码,位全表示数码,数值范围:数值范围:0 06553565535 在在程程序序设设计计中中,如如果果要要使使用用整整型型变变量量,必必须须首首先先选选择择以以上上类类型型符符来来定定义义变变量量,然后才能使用;然后才能使用;例:例:main()main()定义定义 int a,b,c;int a,b,c;a=100;b=50;a=100;b=5
17、0;使用使用 c=a+b;c=a+b;printf(printf(“%d%d”,c);,c);一般根据什么原则选择变量的类型?一般根据什么原则选择变量的类型?3.4 3.4 实型数据实型数据 实型常量实型常量 可使用两种形式表示:可使用两种形式表示:小数形式:小数形式:如如 1.23,3.1415926 15.481.23,3.1415926 15.48 指数形式:指数形式:如如 1e-20 1.23e5 1e-20 1.23e5 实型变量实型变量 用于存放实数的变量用于存放实数的变量 分单精度和双精度两种:分单精度和双精度两种:float a,bfloat a,b 定义定义a a和和b b为
18、单精度型变量为单精度型变量 3232位,位,7 7位有效数字,位有效数字,1010-38-3810103838 double x,ydouble x,y 定义定义x x和和y y为双精度型变量为双精度型变量 6464位,位,1515位有效数字,位有效数字,1010-308-3081010308308 例:例:main()main()float r,c;float r,c;double r,c;double r,c;r=5;r=5;c=2*3.1415926*r;c=2*3.1415926*r;printf(printf(“%f%f”,c);,c);3.5 3.5 字符型数据字符型数据 字符常量
19、字符常量 用单引号括起来的一个字符。用单引号括起来的一个字符。a a,x x,*,1 1等等 除除 此此 外外,以以 开开 头头 的的 字字 符符 如如nn,tt等等 称为转义字符,祥见书表称为转义字符,祥见书表3.33.3 字符型变量字符型变量 用于存放字符的变量。用于存放字符的变量。char c1,c2 char c1,c2 定义定义c1c1和和c2c2为字符型变量为字符型变量 c1=c1=a a;c2=;c2=b b;字符赋值字符赋值 字符型变量存放一个字符,占据一个字节字符型变量存放一个字符,占据一个字节 字符型数据的存储形式字符型数据的存储形式 存放ASCII码 不是 而是 如如字字
20、符符a a在在内内存存中中存存放放9797,b b 存存放放9898。与与整整数数的的存存储储形形式式一一致致,它它们们之之间间可可以以通通用用 一一个个字字符符数数据据既既可可以以作作字字符符用用,也也可可以以作作整数用(取其整数用(取其ASCIIASCII代码)。代码)。如:如:32+32+a a相当于相当于 32+9732+97 若若 int x;char c;int x;char c;则则 x=x=a a;c=97;x=97;c=;c=97;x=97;c=a a;都允都允许许a97 字符串常量字符串常量 用双引号括起来的字符序列。用双引号括起来的字符序列。如:如:”abcdeabcde
21、”,”chinachina”a a”也也属属字字符符串串。注注意意”a a”与与a a的的区别。区别。对于:对于:char c;char c;c=c=”a a”;用法错误用法错误 字字符符串串中中每每个个字字符符各各占占一一个个字字节节,并并且且在在字符串结尾加上一个结束标记字符串结尾加上一个结束标记00 如:如:”chinachina”在内存中占在内存中占6 6个字节。个字节。c h i n a 0 C C语语言言中中专专门门的的字字符符串串变变量量,可可用用字字符符数数组存放(以后介绍)。组存放(以后介绍)。3.6 3.6 变量赋初值变量赋初值 在定义变量的同时给相应的变量赋初值。在定义变
22、量的同时给相应的变量赋初值。如:如:int a=3;int a=3;a a float b=5.2;float b=5.2;char c=char c=a a;int x=y=z=6;int x=y=z=6;效果:效果:在给变量分配内存单元的同时在相应的单在给变量分配内存单元的同时在相应的单 元中存放初值。元中存放初值。3 3.7 3.7 各数值型数据间的混合运算各数值型数据间的混合运算 整整型型、实实型型、字字符符型型数数据据间间可可以以进进行行混混合合运运算,如:算,如:10-10-a a*1.5*1.5 运运算算时时,参参加加运运算算的的两两个个数数据据如如果果类类型型不不同同,则则首首
23、先先将将其其类类型型转转换换成成一一致致再再运运算算,转转换换规规则则是:是:将优先级低的类型转换到优先级高的类型将优先级低的类型转换到优先级高的类型 数据类型的优先级:数据类型的优先级:高高 double floatdouble float long long unsignde unsignde 低低 int charint char 3.8 3.8 算术运算符与算术表达式算术运算符与算术表达式 基本的算术运算符基本的算术运算符 +-*/%算术表达式算术表达式 用算术运算符将运算对象连接起来的式子用算术运算符将运算对象连接起来的式子 用于表达数学公式的式子用于表达数学公式的式子 如:如:2*
24、x+y-1/a2*x+y-1/a 表达式经过运算最终得到一个值:表达式经过运算最终得到一个值:算术表达式的值算术表达式的值 运算符的优先级与结合性运算符的优先级与结合性 优先级:优先级:在在对对表表达达式式求求值值时时,如如果果存存在在多多个个运运算算符符,则则运运算的先后次序按运算符的优先级别从高到底进行。算的先后次序按运算符的优先级别从高到底进行。运算符的优先级关系为:运算符的优先级关系为:高:高:*/%/%低:低:+-+-如:如:a-2*x a-2*x 先算先算*2*(a+2)2*(a+2)有括号的情况?有括号的情况?结合性:结合性:如如果果在在一一个个运运算算对对象象两两边边的的运运算
25、算符符的的优优先先级级相相同,则按规定的同,则按规定的“结合方向结合方向”处理。处理。如:如:a-b+ca-b+c b b与与-结合是从左到右,称结合是从左到右,称“左结合性左结合性”。b b与与+结合是从右到左,称结合是从右到左,称“右结合性右结合性”。每个运算符都有相应的优先级和结合性。每个运算符都有相应的优先级和结合性。基本算术运算符都是基本算术运算符都是左结合性左结合性。计算表达式例:计算表达式例:2+2+A A-1/2.0 1+3/2-1-1/2.0 1+3/2-1构造表达式例构造表达式例 2x2x2 2+3x-1+3x-1a+ba-ba+ba-bx+yx-ya+b/a-b?(a+b
26、)/(a-b)2*x*x+3*x-1(*不能省)(a+b)/(a-b)/(x+y)/(x-y)(a+b)/(a-b)/(x+y)/(x-y)(a+b)/(a-b)/(x+y)*(x-y)强制类型转换强制类型转换可可以以用用强强制制类类型型转转换换运运算算符符将将一一个个表表达达式式的值转换成所需类型:的值转换成所需类型:如:如:(int)(x+y)(int)(x+y)(float)(7%3)(float)(7%3)应用举例:应用举例:int a=200,b=300,c;int a=200,b=300,c;c=a*b/100;c=a*b/100;?可知,有自动转换和强制转换,可知,有自动转换和强
27、制转换,当自动转换达不到目的时,可用强制转换。当自动转换达不到目的时,可用强制转换。c=(long)a*b/100;c=(long)(a*b)/100;自增、自减运算符自增、自减运算符 自增运算符:自增运算符:+使变量值加使变量值加1 1 自减运算符:自减运算符:-使变量值减使变量值减1 1 两种用法:两种用法:+i,-i +i,-i 先加(减)后用先加(减)后用 i+,i-i+,i-先用后加(减)先用后加(减)两种用法对两种用法对i i效果一样,但表达式的值不同。效果一样,但表达式的值不同。例例:假设:假设i i的原值为的原值为5 5:j=+i;j=?j=+i;j=?j=i+;j=?j=i+
28、;j=?注意:注意:+和和-只能用于变量。只能用于变量。如:如:3+3+和(和(a+1a+1)+不合法不合法+和和-为右结合性。为右结合性。(-i)+(-i)+-i+-i+-(i+)-(i+)若若i i的原值是的原值是5 5,则该表达式的值是多少?,则该表达式的值是多少?例:分析执行下列语句后的结果:例:分析执行下列语句后的结果:a=5;a=5;a b c da b c db=a+;b=a+;c=-a-b+;c=-a-b+;d=(a+)-(+b)+c-;d=(a+)-(+b)+c-;556 506 7-26-1 两种特殊情况:两种特殊情况:k=(i+)+(i+)+(i+)k=(i+)+(i+)
29、+(i+)i+j i+j 是是 i+(+j)i+(+j)还是还是 (i+)+j(i+)+j?i+i+虽虽然然与与i=i+1i=i+1等等效效,但但使使用用自自增增自自减减运运算算符符的的代代码码优优化化程程度度好好,因因而而经经常常使使用用;但用时需特别小心。但用时需特别小心。3.9 3.9 赋值运算符和赋值表达式赋值运算符和赋值表达式 赋值运算符赋值运算符 “=”称称赋赋值值运运算算符符,其其作作用用是是将将一一个个数数据据赋给一个变量。赋给一个变量。如:如:a=5a=5 不要理解为不要理解为“等号等号”。执执行行赋赋值值运运算算的的结结果果,是是将将右右边边的的数数据据存存入左边变量所对应
30、的内存单元中。入左边变量所对应的内存单元中。赋值规则赋值规则 如如果果赋赋值值运运算算符符两两侧侧的的类类型型不不一一致致,则则在在赋赋值时要进行类型转换,转换规则为:值时要进行类型转换,转换规则为:实型实型整变量整变量 舍去小数部分。舍去小数部分。int a=5.5;aint a=5.5;a中为中为5 5。整型整型实变量实变量 数值不变,以浮点形式存储。数值不变,以浮点形式存储。字符型字符型整变量整变量 放在整形变量低放在整形变量低8 8位。保持原值不变原则。位。保持原值不变原则。int a=int a=A A;复合赋值运算符复合赋值运算符 在在赋赋值值运运算算符符前前加加上上其其它它运运算
31、算符符,可可以以构构成成复合赋值运算符。复合赋值运算符。a+=3 a+=3 a=a+3 a=a+3 b-=x+5 b-=x+5 b=b-(x+5)b=b-(x+5)x*=c-6 x*=c-6 x=x*(c-6)x=x*(c-6)y/=a*4 y/=a*4 y=y/(a*4)y=y/(a*4)k%=b-2 k%=b-2 k=k%(b-2)k=k%(b-2)属于高效率运算符。属于高效率运算符。赋值表达式赋值表达式 主要实现赋值运算的表达式。主要实现赋值运算的表达式。一般形式:一般形式:=如:如:a=5 y=2*x+3 a=a+1a=5 y=2*x+3 a=a+1 不是衡等不是衡等作用:作用:将右边
32、表达式的值赋给左边的变量将右边表达式的值赋给左边的变量。赋值表达式的值取左边变量的值。赋值表达式的值取左边变量的值。赋赋值值表表达达式式右右边边的的 可可以以是是任任何何表表达式,如:达式,如:a=(b=5)a=(b=5)赋值表达式中包含赋值表达式赋值表达式中包含赋值表达式 赋赋值值运运算算符符的的优优先先级级低低于于所所有有算算术术运运算算符符,且是右结合性。且是右结合性。a=(b=5)a=(b=5)与与 a=b=5a=b=5 等效。等效。例:计算以下表达式的值:例:计算以下表达式的值:a=b=c=5a=b=c=5 a=5+(c=6)a=5+(c=6)a=(b=4)+(c=6)a=(b=4)
33、+(c=6)a=(b=4.5)+(c=6.5)a=(b=4.5)+(c=6.5)(a a、b b、c c为整型变量)为整型变量)a+=a-=a*a a+=a-=a*a (设设a a的原值为的原值为3)3)赋赋值值表表达达式式是是C C语语言言中中的的一一个个重重要要成成分分,在在赋赋值值表表达达式式后后加加一一分分号号就就成成为为常常用用的的赋赋值值语句。如语句。如 y=2*x+1;y=2*x+1;赋赋值值表表达达式式作作为为表表达达式式的的一一种种,可可以以出出现在任何表达式中,如:现在任何表达式中,如:x+2-(b/3-(x+2-(b/3-(a=k-5a=k-5)+)+b b 3.10 3
34、.10 逗号表达式逗号表达式 逗逗号号也也是是一一种种运运算算符符,用用它它对对两两个个表表达达式式实现连接运算。实现连接运算。3+5,6+8 3+5,6+8 称称逗号表达式逗号表达式。逗号表达式的一般形式:逗号表达式的一般形式:表达式表达式1 1,表达式,表达式2 2 取取表达式表达式2 2的值作为整个逗号表达式的值。的值作为整个逗号表达式的值。如:如:a=3*5,a*4a=3*5,a*4 逗号表达式的值为:逗号表达式的值为:6060 一一个个逗逗号号表表达达式式又又可可以以与与另另一一个个表表达达式式组组成成一个新的逗号表达式,如:一个新的逗号表达式,如:(a=3*5,a*4),a+5(a
35、=3*5,a*4),a+5 因此,逗号表达式的一般形式可以扩展为:因此,逗号表达式的一般形式可以扩展为:表达式表达式1 1,表达式,表达式2 2,表达式,表达式3 3,,表达式表达式n n 取取表达式表达式n n的值作为整个逗号表达式的值。的值作为整个逗号表达式的值。逗号运算符的优先级最低逗号运算符的优先级最低,且是左结合性。且是左结合性。逗号运算符只起到连接作用,没有实际操作逗号运算符只起到连接作用,没有实际操作。第四章第四章 最简单的最简单的C C程序设计程序设计 C C 程序最基本的成分是语句程序最基本的成分是语句 目前我们已掌握的语句:目前我们已掌握的语句:变量说明语句变量说明语句:i
36、nt a,b,c;int a,b,c;表达式语句:表达式语句:x+y;x+y;特别地:特别地:a=5;a=5;赋值语句赋值语句 可以编写简单程序如:可以编写简单程序如:main()main()int x,y;int x,y;x=5;x=5;y=2*x*x+3*x-1;y=2*x*x+3*x-1;该程序语法上完整,但还缺少输出。该程序语法上完整,但还缺少输出。数据的输出数据的输出 用输出函数实现用输出函数实现,其中的两种输出函数:其中的两种输出函数:1.putchar 1.putchar 函数函数 (字符输出函数)(字符输出函数)用于输出一个字符。用于输出一个字符。如如:putchar(a);p
37、utchar(100);char c=b;putchar(c);例例:输出单词:输出单词BoyBoy的完整程序:的完整程序:#include“stdio.h”注意该语句的作用注意该语句的作用 main()char a,b,c;a=B;b=o;c=y;putchar(a);putchar(b);putchar(c);2.printf2.printf函数函数(格式输出函数)(格式输出函数)任意类型、任意格式、任意个数。任意类型、任意格式、任意个数。例如:例如:int a=100,b=56;int a=100,b=56;printfprintf(“a=%d,b=%da=%d,b=%d”,a,ba,b
38、););普通字符普通字符 格式说明格式说明 格式控制格式控制 输出表列输出表列输出结果:输出结果:a=100,b=56a=100,b=56“%”后的字符称格式字符,不同格式字符对应不同的数据类型。后的字符称格式字符,不同格式字符对应不同的数据类型。d d格式符:格式符:按整数格式输出按整数格式输出 几种用法:几种用法:%d%d 不指定宽度,按实际宽度输出不指定宽度,按实际宽度输出%md%md 按指定宽度输出,按指定宽度输出,m m为宽度为宽度%ld%ld 用于输出长整型数用于输出长整型数 例:例:int a=125,b=453;int a=125,b=453;long c=65535;long
39、 c=65535;printf(printf(“a=%d,b=%5d,c=%lda=%d,b=%5d,c=%ld”,a,b,c);,a,b,c);输出结果:输出结果:a=125,b=453,c=65535a=125,b=453,c=65535%ld%ld也可以按指定宽度输出:也可以按指定宽度输出:printf(printf(“c=%8ldc=%8ld”,c);,c);输出结果:输出结果:c=65535c=65535注注意意:格格式式字字符符的的类类型型要要与与对对应应的的输输出出对对象象的类型一致。的类型一致。c c格式符:格式符:用于输出字符用于输出字符 char c=char c=A A;
40、printf(printf(“c=%c,%cc=%c,%c”,c,c,B B););输出结果输出结果:c=A,Bc=A,B 输输出出对对象象既既可可以以是是字字符符变变量量、字字符符常常量量,还还可以是整型表达式。可以是整型表达式。如:如:int a=100;int a=100;char b=char b=A A;printf(printf(“n%d,%cn%d,%c”,a,a);,a,a);printf(printf(“n%c,%dn%c,%d”,b,b);,b,b);输出结果:输出结果:100,d100,d A,65 A,65 s s格式符:格式符:用于输出字符串用于输出字符串%s%s 不
41、指定宽度不指定宽度%-ms%-ms 指定宽度,左靠齐指定宽度,左靠齐%ms%ms 指定宽度,右靠齐指定宽度,右靠齐%m.ns%m.ns 指定宽度指定宽度m m,只取左端,只取左端n n个字符,个字符,右靠齐右靠齐%-m.ns%-m.ns 指定宽度指定宽度m m,只取左端,只取左端n n个字符,个字符,左靠齐左靠齐例:例:printf(printf(“1:%s1:%s”,”abcdabcd”););printf(printf(“2:%8s2:%8s”,”abcdabcd”););printf(printf(“3:%-8s3:%-8s”,”abcdabcd”););printf(printf(“4
42、:%8.3s4:%8.3s”,”abcdabcd”););printf(printf(“5:%-8.3s5:%-8.3s”,”abcdabcd”););1:abcd2:abcd3:abcd 4:abc5:abc 1:abcd2:abcd3:abcd 4:abc5:abc f f格式符:格式符:按小数形式输出实数按小数形式输出实数%f%f 由系统指定宽度(由系统指定宽度(6 6位小数)位小数)%m.nf%m.nf 指定宽度指定宽度m m,小数位数,小数位数n n,右靠齐,右靠齐%-m.nf%-m.nf 指定宽度指定宽度m m,小数位数,小数位数n n,左靠齐,左靠齐 注意:宽度包括符号和小数点注
43、意:宽度包括符号和小数点。例:例:float a=3.141592654,b=14.326795,float a=3.141592654,b=14.326795,c=-125.2468;c=-125.2468;printf(printf(“na=%f,b=%8.3f,c=%-na=%f,b=%8.3f,c=%-10.2f10.2f”,a,b,c);,a,b,c);输出结果:输出结果:a=3.141592,b=14.326,c=-125.24a=3.141592,b=14.326,c=-125.24 完整前面的程序:完整前面的程序:完整前面的程序:完整前面的程序:main()main()int
44、x,y;int x,y;x=5;x=5;y=2*x*x+3*x-1;y=2*x*x+3*x-1;printf(printf(“n y=%dn y=%d”,y);,y);程序设计例:程序设计例:编写程序计算如图中的电流编写程序计算如图中的电流I I.假设假设 U=220,R1=30,R2=60,R3=45U=220,R1=30,R2=60,R3=45UIR1R2R3算法设计算法设计:I=U/R1+U/R2+U/R3I=U/R1+U/R2+U/R3程序设计:程序设计:main()main()I=U/R1+U/R2+U/R3;I=U/R1+U/R2+U/R3;int U=220,R1=30,R2=6
45、0,R3=45;int U=220,R1=30,R2=60,R3=45;float I;float I;printf(printf(“n n I=%fI=%f”,I);,I);正确的程序:正确的程序:main()main()int U=220,R1=30,R2=60,R3=45;int U=220,R1=30,R2=60,R3=45;float I;float I;I=I=(float)(float)U/R1+U/R1+(float)(float)U/R2+U/R2+(float)(float)U/R3;U/R3;printf(printf(“n I=%fn I=%f”,I);,I);考虑通用
46、考虑通用:main()main()int U,R1,R2,R3;int U,R1,R2,R3;float I;float I;输入输入 U,R1,R2,R3U,R1,R2,R3 I=(float)U/R1+(float)U/R2+(float)U/R3;I=(float)U/R1+(float)U/R2+(float)U/R3;printf(printf(“n I=%fn I=%f”,I);,I);数据的输入数据的输入 getchargetchar函数(函数(字符输入字符输入)#include#include“stdio.hstdio.h”main()main()char c;char c;c
47、=getchar();c=getchar();等待键盘输入等待键盘输入 putchar(c);putchar(c);scanf scanf 函数函数(格式输入)与与printfprintf函数相反。函数相反。用于输入若干任意类型的数据。用于输入若干任意类型的数据。scanfscanf(“%d%d%d%d%d%d”,&a,&b,&c&a,&b,&c););格式控制格式控制 地址列表地址列表 scanfscanf(“%d%d%d%d%d%d”,&a,&b,&c&a,&b,&c););执执行行此此函函数数时时,等等待待从从键键盘盘输输入入三三个个整整数给数给a,b,ca,b,c 若从键盘输入若从键盘
48、输入 3 5 83 5 8 则则系系统统即即从从键键盘盘缓缓冲冲区区取取出出这这三三个个数数分分别赋给别赋给a,b,ca,b,c 注意与注意与printfprintf的区别,注意格式的匹配的区别,注意格式的匹配如:如:scanf(scanf(“%3d%2d%4d%3d%2d%4d”,&a,&b,&c);,&a,&b,&c);若从键盘输入若从键盘输入123456789123456789 a=123,b=45,c=6789 a=123,b=45,c=6789 若想使若想使a=12,b=5,c=100a=12,b=5,c=100 则键盘输入应为:则键盘输入应为:12 5 10012 5 100 方便
49、的输入格式一般不方便的输入格式一般不 指定宽度,指定宽度,如:如:scanf(scanf(“%d%d%d%d%d%d”,&a,&b,&c);,&a,&b,&c);在在键键盘盘输输入入时时,用用分分隔隔符符把把每每个个数数据据隔隔开开,标准的分隔符是空格。标准的分隔符是空格。如:如:123 150 23123 150 23 若想用逗号作分隔符,则:若想用逗号作分隔符,则:scanf(scanf(“%d%d,%d%d,%d%d”,&a,&b,&c);,&a,&b,&c);不要随便使用普通字符,如使用:不要随便使用普通字符,如使用:scanf(scanf(“a=%da=%d,b=%d c=%db=%
50、d c=%d”,&a,&b,&c),&a,&b,&c)对应数据输入:对应数据输入:a=123,b=150,c=23a=123,b=150,c=23 前面的欧姆定律前面的欧姆定律:main()main()int U,R1,R2,R3;int U,R1,R2,R3;float I;float I;scanf(scanf(“%d%d%d%d%d%d%d%d”,&U,&R1,&R2,&R3);,&U,&R1,&R2,&R3);I=(float)U/R1+(float)U/R2+(float)U/R3;I=(float)U/R1+(float)U/R2+(float)U/R3;printf(printf