《简单程序》ppt课件_第1页
《简单程序》ppt课件_第2页
《简单程序》ppt课件_第3页
《简单程序》ppt课件_第4页
《简单程序》ppt课件_第5页
已阅读5页,还剩61页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、4.1 C4.1 C语句概述语句概述4.2 4.2 赋值语句赋值语句4.3 4.3 数据输入输出的概念及在数据输入输出的概念及在c c语言中的实现语言中的实现4.4 4.4 字符数据的输入输出字符数据的输入输出4.5 4.5 格式输入与输出格式输入与输出4.6 4.6 顺序结构程序设计举例顺序结构程序设计举例C程序源程序文件1源程序文件2源程序文件n预处理命令函数n函数1数据声明函数首部函数体数据声明执行语句 一个c程序可以由若干个源程序文件组成 一个源文件可以由若干个函数和预处理命令以及全局变量声明部分组成 一个函数由函数首部和函数体组成 函数体由数据声明和执行语句组成 C语句分为5类类控制

2、语句控制语句函数调用语句函数调用语句表达式语句表达式语句空语句空语句复合语句复合语句(一)控制语句完成一定的控制功能1 if() else 条件语句条件语句2 for() 循环语句循环语句 7 switch() 开关语句开关语句3 while() 循环语句循环语句 8 goto 转向语句转向语句 4 do while() 循环语句循环语句 9 return 返回语句返回语句5 continue 结束本次循环结束本次循环 6 break 终止终止switch语句或循环语句或循环(二)函数调用语句 由一个函数调用加一个分号构成一个语句 printf(“This is a C statement.”

3、);(三)表达式语句 由一个表达式加一个分号构成一个语句 a = 3 ;分号表达式表达式语句 a = 2b * 3c -2 ;(四)空语句只有一个分号的语句 (什么也不做)(什么也不做) 用来做流程的转向点(转到此处)用来做流程的转向点(转到此处) 用来作为循环语句中的循环体用来作为循环语句中的循环体(五)复合语句 用一对 括起来的语句 z=x+y;t=z/100;printf(“%f”,t);赋值语句是由赋值表达式加上一个分号构成例:例:a=100 赋值表达式 a=100; 赋值语句条件不能是赋值表达式,但是赋值表达式 可以包含于条件表达式中例:例:if(a=b) t=a; 并不是判断a=b

4、 if(a=b)0) t=a; 正确(一).输入输出是以计算机主机计算机主机为主体而言的 输出输出:从计算机向外部输出设备(显示器,打印机) 输出数据 输入输入:从输入设备(键盘,鼠标,扫描仪)向计算机 输入数据.(二).C语言本身不提供输入输出语句,输入和输出操作是由C函数库中的函数来实现的例如例如: :字符输入函数: getchar 字符输出函数:putchar格式输入函数: scanf 格式输出函数: printf字符串输入函数:gets 字符串输出函数:puts(三).在使用系统库函数时,要用预编译命令“#include”将有关的“头文件”包括到用户源文件中.例如:在调用标准输入输出库

5、函数时,文件开头应该有: #include “stdio.h” 或: #include 头文件(一).字符输出函数 一般形式:putchar(c) 函数作用:向终端输出一个字符 字符型变量或整型变量运行结果:BO Y#include void main() char a,b,c; a=B; b=O; c=Y; putchar(a); putchar(b); putchar(n); putchar(c); #include void main() putchar(103); putchar(015); putchar(x42); ASCII值值 代码:代码: 42 * 66 B 67 C 103

6、 q 13 CR(回车,但不换行)回车,但不换行) 8 进制进制 十进制十进制 十六进制:十六进制: 15 13 D 42 34 22 102 66 42 103 67 43 (二)(二). .字符输入函数字符输入函数 一般形式:一般形式:getchargetchar()() 函数作用:从终端(或系统隐含指定的输入设备函数作用:从终端(或系统隐含指定的输入设备)输入一个字符。)输入一个字符。 函数值:函数值: 从输入设备得到的字符。从输入设备得到的字符。运行程序:从键盘输入字符a按Enter键屏幕上将显示输出的字符aaa例例4.2 输入单个字符输入单个字符#include void main(

7、) char c; c=getchar(); putchar(c); putchar(n); (一)(一). .格式输出函数格式输出函数 函数作用:向终端(或系统隐含指定的输出设备函数作用:向终端(或系统隐含指定的输出设备)输出)输出若干个任意类型若干个任意类型的数据。的数据。 一般格式:一般格式:printfprintf(格式控制,输出表列)(格式控制,输出表列)%d%d: :以带符号的十进制形式输出整数以带符号的十进制形式输出整数%o%o: :以八进制无符号形式输出整数以八进制无符号形式输出整数%x%x: :以十六进制无符号形式输出整数以十六进制无符号形式输出整数%u%u: :以无符号十进

8、制形式输出整数以无符号十进制形式输出整数%c%c: :以字符形式输出,只输出一个字符以字符形式输出,只输出一个字符%s%s: :输出字符串输出字符串%f%f: :以小数形式输出单,双精度数,隐含输出六位小数以小数形式输出单,双精度数,隐含输出六位小数%e%e: :以指数形式输出实数以指数形式输出实数%g%g: :选用选用%f%f或或%e%e格式中输出宽度较短的一种格式,不输格式中输出宽度较短的一种格式,不输 出无意义的出无意义的0 0几种常见的格式符的修饰符:L L:用于长整型整数,可加在格式符:用于长整型整数,可加在格式符d d,o o,x x,u u前面前面 用于用于doubledoubl

9、e型浮点数,可加在格式符型浮点数,可加在格式符f f,e e前面前面M M(代表一个正整数):数据最小宽度(代表一个正整数):数据最小宽度N N(代表一个正整数):对实数,表示输出(代表一个正整数):对实数,表示输出n n位小数;位小数; 对字符串,表示截取的字符个数对字符串,表示截取的字符个数:输出的数字或字符在域内向左靠:输出的数字或字符在域内向左靠#include void main() long a ;a=65536;printf(%dn, a); printf(%ldn, a); printf(%8ldn, a); printf(%-8ldn, a); :为指定的输出字段的为指定的输

10、出字段的宽度。如果数据的位数小于,宽度。如果数据的位数小于, 则左端补以空格,若大于,则则左端补以空格,若大于,则按实际位数输出按实际位数输出- , 左对齐左对齐#include void main() double a ;a=1234.12345678;printf(%fn, a); printf(%lfn, a); printf(%8.2lfn, a); printf(%-8.2lfn, a); (1)格式符。用来输出十进制整数。格式符。用来输出十进制整数。(2)(2)几种用法:几种用法: : :按十进制整型数据的实际长度输出。按十进制整型数据的实际长度输出。 : :为指定的输出字段的宽度

11、。如果数据的位数小于,为指定的输出字段的宽度。如果数据的位数小于, 则左端补以空格,若大于,则按实际位数输出。则左端补以空格,若大于,则按实际位数输出。 : :输出长整型数据。输出长整型数据。 例例: : ;/ /* * 定义定义a a为长整型变量为长整型变量* */ / (,);,);(2) (2) 格式符。以八进制整数形式输出。格式符。以八进制整数形式输出。 输出的数值不带符号,符号位也一起作为八进制数的一部分输出。输出的数值不带符号,符号位也一起作为八进制数的一部分输出。 不会输出带负号的八进制整数。对长整数(型)可以不会输出带负号的八进制整数。对长整数(型)可以用用“”格式输出。还可以

12、指定字段宽度,格式输出。还可以指定字段宽度,例例: :( ,),); ; 输出为输出为: 177777: 177777。 ( (数字前有数字前有2 2个空格个空格) )(3)(3)格式符。以十六进制数形式输出整数。同样不会出格式符。以十六进制数形式输出整数。同样不会出现负的十六进制数。现负的十六进制数。例:例: ; (,);,); 输出结果为输出结果为: : ffff ffff,可以用可以用“”输出长整型数,也可以输出长整型数,也可以指定输出字段的宽度指定输出字段的宽度例例: : “ “”(4)(4)格式符,用来输出格式符,用来输出 unsigned int unsigned int 型数据型

13、数据. .一个有符号整数(一个有符号整数(int型)也可以用格式输出;型)也可以用格式输出;一个一个unsigned型数据也可以用格式输出。型数据也可以用格式输出。unsigned型数据也可用或格式输出。型数据也可用或格式输出。#include void main() int a=-1;printf(d): %d n, a); printf(x): %x n, a); printf(o): %o n, a); printf(u): %u n, a); o, x ,u 参数,输出的数值不带符参数,输出的数值不带符号,符号位也一起作为进制数的号,符号位也一起作为进制数的一部分输出。一部分输出。-1

14、 写成原码:写成原码:1 000 0000 0000 0001反码:反码: (负数:除符号位外,其它位取反)(负数:除符号位外,其它位取反)1 111 1111 1111 1110补码补码 (负数:,反码(负数:,反码+1)1 111 1111 1111 1111= FFFF (h)= 177777 (o)= 65535 (d)正数:正数: 原码原码 = 反码反码 =补码补码负数反码:除符号位外,其它位取反负数反码:除符号位外,其它位取反 补码:反码补码:反码+1补码的知识补码的知识#include void main() int a=-1;printf(d): %d n, a); print

15、f(x): %x n, a); printf(o): %o n, a); printf(u): %u n, a); 执行结果:执行结果:(d) : -1(x) : ffff(o) : 177777 (u) : 65535(5)(5)格式符,用来输出一个字符。格式符,用来输出一个字符。如:如:d d; (,d d);); 输出字符输出字符.一个整数,只要它的值在范围内,可以用一个整数,只要它的值在范围内,可以用“”使之按字符形式输出,在输出前,系统会将该整数使之按字符形式输出,在输出前,系统会将该整数作为作为ASCIIASCII码转换成相应的字符;一个字符数据也可以用码转换成相应的字符;一个字符

16、数据也可以用整数形式输出。整数形式输出。 例4.4 字符数据的输出。#includevoid main()char c=a;int i=97;printf(“%c,%dn”,c,c);printf(“%c,%dn”,i,i); 运行结果:运行结果:a,97a,97a,97a,97#include void main() int a=97;printf(c): %3c n, a); printf(x): %3x n, a); printf(o): %3o n, a); printf(u): %3u n, a); (6)s(6)s格式符格式符 输出字符串输出字符串. . s s。例如:。例如: (

17、,) 输出字符串输出字符串“”(不包括双引号)。(不包括双引号)。 %ms%ms,输出的字符串占,输出的字符串占m m列,若串长大于列,若串长大于m m,则全部输出,若串长,则全部输出,若串长 小于小于m m,则左补空格。,则左补空格。 %-ms%-ms,若串长小于,若串长小于m m,字符串向左靠,右补空格。,字符串向左靠,右补空格。 %m.ns%m.ns, ,输出占输出占m m列,只取字符串中左端列,只取字符串中左端n n个字符,输出在个字符,输出在m m列的列的 右侧,左补空格。右侧,左补空格。 %-m.ns%-m.ns,n n个字符输出在个字符输出在m m列的左侧,右补空格,若列的左侧,

18、右补空格,若n nm m,m m自自 动取动取n n值。值。(7)格式符。格式符。用来以小数形式输出实数(包括单双精度)有以下几种用法: 。不指定字段宽度,由系统自动指定字段宽度,使整数部分全部输出,并输出位小数。应当注意,在输出的数字中并非全部数字都是有效数字并非全部数字都是有效数字。单精度实数的有效位数一般为位。.。指定输出的数据共占列,其中有位小数。如果数值长度小于,则左端补空格。.与.基本相同,只是使输出的数值向左端靠,右端补空格。 例例4.6 4.6 输出实数时的有效位数输出实数时的有效位数(7(7位)。位)。#include #include void void ()() ,;,;

19、(,);,);运行结果:运行结果:. .例例4.74.7输出双精度数时的有效位数(输出双精度数时的有效位数(1616位)。位)。#include #include void void ()() ,;,;x=1111111111111.111x=1111111111111.111111111111111; ; y=2222222222222.222 y=2222222222222.222222222222222; ;printf(“%f”printf(“%f”,x+y);x+y);运行结果:运行结果:3333333333333.3333333333333333.333010010(8)格式符格式

20、符,以指数形式输出实数。可用以下形式: 。不指定输出数据所占的宽度和数字部分的小数位数.例: (,);输出: 6列 5列所输出的实数共占列宽度。(注:不同系统的规定略有不同) (9)(9)格式符,用来输出实数格式符,用来输出实数. . 它根据数值的大小,自动选格式或格式(选择输出时占宽度它根据数值的大小,自动选格式或格式(选择输出时占宽度较小的一种),且不输出无意义的零。较小的一种),且不输出无意义的零。#include stdio.hvoid main() double a=12345678.456; printf(a=12345678.456n); printf(f):%lf,n, a);

21、 printf(e):%e,n, a); printf(g):%g,nn, a); a=123.468; printf(a=123.468n); printf(%f):%f,n, a); printf(%E):%E,n, a); printf(%G):%G,n, a); 说明:说明: 除了除了X,E,G外,其他格式字符必须用小写。外,其他格式字符必须用小写。 可以在可以在printf函数中的函数中的“格式控制格式控制”字符串中包含转义字符字符串中包含转义字符。 一个格式说明必须以一个格式说明必须以“%”开头,以开头,以9个格式字符之一为结束个格式字符之一为结束,中间可以插入附加格式字符。,中间

22、可以插入附加格式字符。 想输出想输出%,则应该在格式控制字符串中用连续两个,则应该在格式控制字符串中用连续两个%表示表示(一).格式输入函数 函数作用:按照变量在内存的地址将变量值存 进去。 一般格式:scanf(格式控制,地址表列)同同printf函数函数是由若干个地址组成的表列,可以是变量的是由若干个地址组成的表列,可以是变量的地址,或字符串的首地址地址,或字符串的首地址#include stdio.hvoid main() int a, b, c; scanf(%d %d %d, &a,&b,&c); printf(%d %d %dn,a,b,c); scanf(

23、%d,%d,%d, &a,&b,&c); printf(%d %d %d,a,b,c);a a在内存中的地在内存中的地址址& &是地址运算符是地址运算符说明: 对unsigned型变量所需要的数据,可以用%u,%d或%o,%x格式输入。 可以指定输入数据所占的列数,系统自动按它截取所需数据。 如果在%后有一个“*”附加说明符,表示跳过它指定的列数。 输入数据时不能规定精度。 使用函数时应注意的问题使用函数时应注意的问题 :(1)(1)函数中的函数中的“格式控制格式控制”后面应当是变量地址,而不应后面应当是变量地址,而不应 是变量名。是变量名。 (2)(2

24、) 如果在如果在“格式控制格式控制”字符串中字符串中除了格式说明以外还有其他字符除了格式说明以外还有其他字符, 则在输入数据时则在输入数据时在对应位置应输入与这些字符相同的字符在对应位置应输入与这些字符相同的字符。 (3) (3) 在用在用“”格式输入字符时,空格字符和格式输入字符时,空格字符和“转义字符转义字符”都作为都作为 有效字符输入有效字符输入 (4) (4) 在输入数据时,遇以下情况时认为该数据结束。在输入数据时,遇以下情况时认为该数据结束。 遇空格,或按遇空格,或按“回车回车”或或“跳格跳格”(TabTab)键;)键; 按指定的宽度结束,如按指定的宽度结束,如“”,只取列;,只取列

25、; 遇非法输入。遇非法输入。#include stdio.hvoid main() int a, b, c; scanf(%da%d, &a,&b); printf(%d,%dn,a,b); scanf(%*d, &a); printf(%dn,a); scanf(%3d, &c); printf(c=%dn,c); 例例4.10 4.10 输入三角形的三边输入三角形的三边长,求三角形面积。长,求三角形面积。假设:三个边长假设:三个边长a a,b b,c c能构能构成三角形。成三角形。已知面积公式:已知面积公式:area=area=s=(a+b+c)s=(a+b

26、+c)* *0.50.5c)b)(sa)(ss(s开始输入三边长计算s计算面积结束#include #include void main() float a,b,c,s,area; scanf(%f,%f,%f,&a,&b,&c); s=(a+b+c)/2.0; area=sqrt(s*(s-a)*(s-b)*(s-c); printf(a=%7.2f, b=%7.2f, c=%7.2fn,a,b,c);printf(s=%7.2fn,s); printf(area=%7.2fn,area); 从键盘输入一个大写字母,要求改用小写字母输出从键盘输入一个大写字母,要求改用

27、小写字母输出#include stdio.hvoid main() char c1, c2;puts(请输入一个大写字母请输入一个大写字母);c1=getchar();printf(%d, %cn, c1,c1);c2=c1+32;printf(%d, %c, c2,c2);例例4.12 4.12 求求x x2 2方程的根。方程的根。a a,b b,c c由键盘输入,设由键盘输入,设 。众所周知,一元二次方程式的根为众所周知,一元二次方程式的根为x1= x2= x1= x2= 可以将上面的分式分为两项:可以将上面的分式分为两项:p= p= , q= x1=p+qq= x1=p+q, x2=p-

28、qx2=p-qacb42aacbb242aacbb242ab2aacb242#include #include 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(nnx1=%5.2fnx2=%5.2fn,x1,x2); 2 要求:要求:1、提示输入一个指定的十进制数、提示输入一个指定的十进制数2、从键盘中输入一个数。、从键盘中输入一个数

29、。3、将这个数转变成八进制,及十六进制并输出结果。、将这个数转变成八进制,及十六进制并输出结果。 从键盘中输入火车到达本站时间及火车开到下一站所需从键盘中输入火车到达本站时间及火车开到下一站所需时间,计算后输入火车到达下一站的时间。时间,计算后输入火车到达下一站的时间。 要求:从键盘中输入火车到达本站的时间(小时和分钟要求:从键盘中输入火车到达本站的时间(小时和分钟),及及火车开到下一站所需时间(小时和分钟),执),及及火车开到下一站所需时间(小时和分钟),执行后输入结果,如果该时间超过超过行后输入结果,如果该时间超过超过24小时,则从零点小时,则从零点开始。例,如输入开始。例,如输入22:1

30、0,经过,经过3:15,计算后结果为,计算后结果为25:25,则显示为,则显示为1:25 执行程序后,显示结果需与下图一致。其中执行程序后,显示结果需与下图一致。其中21:18和和 4:55为输入的数据为输入的数据#include stdio.hvoid main() int h, m, t1,t2, h2,m2,h3,m3; printf(请输入火车到达本站的时间(如3:20)=); scanf(%d:%d,&h,&m); t1=h*60+m; printf(请输入火车开到下一站所需时间(如4:20)=); scanf(%d:%d,&h2,&m2); t2=t

31、1+h2*60+m2; h3=t2/60; h3=h3%24; m3=t2%60; printf(%d:%d经过%d:%d后是%d:%2d,h,m,h2,m2,h3,m3); 假设有一假设有一 int 类型的数,值为类型的数,值为5, 5转换成二制是转换成二制是101 B,那么,那么,它在计算机中如何表示呢:,它在计算机中如何表示呢: 我们知道:我们知道:int类型的数占用类型的数占用2字节(字节(TC2.0标准,标准,16位),所位),所以要在它的有效位前面填上一堆以要在它的有效位前面填上一堆0,补足,补足16位。位。 写成:写成: 00000000 00000101 写成十六进制就是:写成

32、十六进制就是: 00 05 long int 则是:则是:00000000 00000000 00000000 00000101 十六进制就是:十六进制就是:00 00 00 05 -5在计算机中如何表示呢?在计算机中如何表示呢? 在计算机中,负数以其正数的补码形式表达。在计算机中,负数以其正数的补码形式表达。 什么叫补码呢?这得从原码,反码说起。什么叫补码呢?这得从原码,反码说起。 原码:一个整数,按照绝对值大小转换成的二进制数,原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。其最高位为符号位。称为原码。其最高位为符号位。 如如 0000 0000 0000 0101 是十进制数是

33、十进制数5的原码。的原码。 最高位是符号位(正数符号位为最高位是符号位(正数符号位为0) -5的原码:的原码: 1000 0000 0000 0101 负数符号位为负数符号位为1 反码:正数的反码是其本身。反码:正数的反码是其本身。 负数的反码:负数的反码: 符号位不变,将其余二进制数按位取反,所得的新符号位不变,将其余二进制数按位取反,所得的新二进制数为原二进制数的反码。二进制数为原二进制数的反码。 取反操作指:原数为取反操作指:原数为1,取反后得,取反后得0;原为;原为0,得,得1。(。(1变变0; 0变变1)如:将如:将 1000 0000 0000 0101 (-5)除符号位外每一位取

34、反,除符号位外每一位取反,得得 1111 1111 1111 1010称:称:1111 1111 1111 1010 是是 1000 0000 0000 0101 的反码。的反码。反码是相互的,所以也可称:反码是相互的,所以也可称:11111111 11111010 和和 10000000 00000101 互为反码。互为反码。 补码:正数:补码补码:正数:补码 = 反码反码 = 原码原码 负数的补码求法:负数的补码求法: 求出反码,再加求出反码,再加1,(补码加法,如果进位到符号位,会连补码加法,如果进位到符号位,会连符号位一起加。符号位一起加。) 也就是说,要得到一个数的补码,先得到反码,然后将也就是说,要得到一个数的补码,先得到反码,然后将反码加上反码加上1,所得数称为补码。,所得数称为补码。 比如:比如: 10

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论