版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
第一章C语言概述C语言发展历史C语言特点简单的c程序介绍C程序上机步骤1.1C语言出现的历史背景1.C语言的诞生与发展(1)在C语言诞生以前,系统软件主要是用汇编语言编写的。由于汇编语言程序依赖于计算机硬件,其可读性和可移植性都很差;但一般的高级语言又难以实现对计算机硬件的直接操作(这正是汇编语言的优势),于是人们盼望有一种兼有汇编语言和高级语言特性的新语言。(2)C语言是贝尔实验室于70年代初研制出来的,后来又被多次改进,并出现了多种版本。80年代初,美国国家标准化协会(ANSI),根据C语言问世以来各种版本对C语言的发展和扩充,制定了ANSIC标准(1989年再次做了修订)。本书以ANSIC新标准来介绍。(3)目前,在微机上广泛使用的C语言编译系统有MicrosoftC、TurboC、BorlandC等。虽然它们的基本部分都是相同的,但还是有一些差异,所以请大家注意自己所使用的C编译系统的特点和规定(参阅相的手册)。本书选定的上机环境是TCV2.0(DOS操作系统)。
1.2C语言特点语言简洁、紧凑、灵活运算符和数据类型丰富程序设计结构化、模块化生成目标代码质量高可移植性好<>>>>>>中级语言
C语言程序设计
第一章C语言概述>32个关键字:(由系统定义,不能重作其它定义)autobreakcasecharconstcontinuedefaultdodoubleelseenumexternfloatforgotoifintlongregisterreturnshortsignedsizeofstaticstructswitchtypedefunsignedunionvoidvolatilewhile<
C语言程序设计
第一章C语言概述9种控制语句:if()~else~for()~while()~do~while()continuebreakswitchgotoreturn<
C语言程序设计
第一章C语言概述例C语言与Pascal语言比较C语言
Pascal语言含义{}
BEGIN….END
复合语句if(e)s;
IF(e)THENs
条件语句inti;
VARi:INTEGER
定义i为整型变量inta[10];
VARa:ARRAY[1..10]OFINTEGER
定义整型数组aintf();
FUNCTIONf():INTEGER
定义f为返值整型的函数int*p;
VARp:INTEGER
定义p为指向整型变量的指针i+=2;
i=i+2
赋值i+2ii++,++i;
i=i+1 i自增值结论:C比Pascal简练,源程序短。<
C语言程序设计
第一章C语言概述34种运算符:算术运算符:+-*/%++--关系运算符:<<===>>=!=逻辑运算符:!&&||位运算符:<<>>~|^&赋值运算符:=及其扩展条件运算符:?:逗号运算符:,指针运算符:*&求字节数:sizeof强制类型转换:(类型)分量运算符:.->下标运算符:[]其它:()-<
C语言程序设计
第一章C语言概述C数据类型基本类型构造类型指针类型空类型void定义类型typedef数值类型字符类型char枚举类型enum整型浮点型单精度型float双精度型double短整型short长整型long整型int数组结构体struct共用体union<
C语言程序设计
第一章C语言概述1.3
简单的C程序介绍例1.1第一个程序Hello,World!/*example1.1ThefirstCProgram*/#include<stdio.h>main(){printf(“Hello,World!”);}
C语言程序设计
第一章C语言概述注释编译预处理函数语句输出:Hello,World!例1.3
由main()函数和1个其它函数max()构成的C语言程序。/main()/*主函数*/{inta,b,c;/*声明部分,定义变量*/scanf(“%d,%d”,&a,&b);/*输入变量a和b的值*/c=max(a,b);/*调用max函数,将得到的值赋给c*/printf(“max=%d”,c);/*输出c的值*/}intmax(intx,inty)/*定义max函数*/{intz;/*定义变量z*/if(x>y)z=x;elsez=y;return(z);/*将z的值返回,通过max带回调用*/}
格式特点习惯用小写字母,大小写敏感不使用行号,无程序行概念可使用空行和空格常用锯齿形书写格式<>
C语言程序设计
第一章C语言概述main(){
……………….………………
…………..…………..
……………….
………………………….
……………….………………..}main(){
inti,j,sum;sum=0;for(i=1;i<10;i++){for(j=1;j<10;j++){sum+=i*j;}}printf(“%d\n”,sum);}优秀程序员的素质之一:使用TAB缩进{}对齐有足够的注释有合适的空行结构特点函数与主函数程序由一个或多个函数组成必须有且只能有一个主函数main()程序执行从main开始,在main中结束,其它函数通过嵌套调用得以执行。程序语句C程序由语句组成用“;”作为语句终止符注释/**/为注释,不能嵌套不产生编译代码<>例:/*Thisisthemain/*ofexample1.1*/*/非法编译预处理命令
C语言程序设计
第一章C语言概述编辑链接编译执行1.4
C程序的上机步骤C程序开发步骤<>file.exe
C语言程序设计
第一章C语言概述程序代码的录入,生成源程序*.c语法分析查错,翻译生成目标程序*.obj与其它目标程序或库链接装配,生成可执行程序*.exe进入TurboCD:\TC>TC.exe
主控菜单文件操作FILE:New
Load
Save
Writeto编辑操作EDIT:插入/修改
块
查找/替换编译链接COMPILE
LINK
MAKE执行RUN退出TurboCAlt+xAlt+F,Q帮助HelpF1Ctrl+F1运行一个C语言程序的一般过程
TurboC是一个集源程序编辑、编译、连接、运行与调试于一体、用菜单驱动的集成软件环境。运行一个C语言程序的一般过程:(1)启动TC,进入TC集成环境。(2)编辑(或修改)源程序。(3)编译。如果编译成功,则可进行下一步操作;否则,返回(2)修改源程序,再重新编译,直至编译成功。(4)连接。如果连接成功,则可进行下一步操作;否则,根据系统的错误提示,进行相应修改,再重新连接,直至连接成功。(5)运行。通过观察程序运行结果,验证程序的正确性。如果出现逻辑错误,则必须返回(2)修改源程序,再重新编译、连接和运行,直至程序正确。(6)退出TC集成环境,结束本次程序运行。进入TurboC2.0集成开发环境中后,屏幕上显示:小结:一、函数是C语言程序的基本单位。C语言程序总是从main()函数开始执行
被调用的函数可以是系统提供的库函数,也可以使用户根据需要自己编制设计的函数。C的函数相当于其他语言的子程序,用函数来实现特定的功能。main()函数的作用,相当于其它高级语言中的主程序;其它函数的作用,相当于子程序。一个C语言程序,总是从main()函数开始执行,而不论其在程序中的位置。当主函数执行完毕时,亦即程序执行完毕。习惯上,将主函数main()放在最前头。二、源程序书写格式1.所有语句都必须以分号“;”结束,函数的最后一个语句也不例外。2.程序行的书写格式自由,既允许1行内写几条语句,也允许1条语句分写在几行上。3.允许使用注释。C语言的注释格式为:/*……*/
第二章算法2.1算法的概念
做任何事情都有一定的步骤。为解决一个问题而采取的方法和步骤,就称为算法。计算机算法:计算机能够执行的算法。计算机算法可分为两大类:
数值运算算法:求解数值;非数值运算算法:事务管理领域。
2.2
简单算法举例【例2.1】求1×2×3×4×5。最原始方法:步骤1:先求1×2,得到结果2。步骤2:将步骤1得到的乘积2乘以3,得到结果6。步骤3:将6再乘以4,得24。步骤4:将24再乘以5,得120。这样的算法虽然正确,但太繁。改进的算法:S1:使t=1S2:使i=2S3:使t×i,乘积仍然放在在变量t中,可表示为t×i→tS4:使i的值+1,即i+1→iS5:如果i≤5,返回重新执行步骤S3以及其后的S4和S5;否则,算法结束。
如果该求1×3×5×7×9×11,算法也只需做很少的改动:S1:1→tS2:3→iS3:t×i→tS4:i+2→tS5:若i≤11,返回S3,否则,结束。该算法不仅正确,而且是计算机较好的算法,因为计算机是高速运算的自动机器,实现循环轻而易举。思考:若将
S5写成:S5:若i<11,返回S3;否则,结束。
【例2.2】有50个学生,要求将他们之中成绩在80分以上者打印出来。如果,n表示学生学号,ni表示第个学生学号;g表示学生成绩,gi表示第个学生成绩;则算法可表示如下:S1:1→iS2:如果gi≥80,则打印ni和gi,否则不打印S3:i+1→iS4:若i≤50,返回S2,否则,结束。【例2.3】判定2000—2500年中的每一年是否闰年,将结果输出。润年的条件:
1)
能被4整除,但不能被100整除的年份;
2)
能被100整除,又能被400整除的年份;设y为被检测的年份,则算法可表示如下:S1:2000→yS2:若y不能被4整除,则输出y“不是闰年”,然后转到S6S3:若y能被4整除,不能被100整除,则输出y“是闰年”,然后转到S6S4:若y能被100整除,又能被400整除,输出y“是闰年”否则输出y“不是闰年”,然后转到S6S5:输出y“不是闰年”。S6:y+1→yS7:当y≤2500时,返回S2继续执行,否则,结束。
【例2.4】求算法可表示如下:S1:sigh=1S2:sum=1S3:deno=2S4:sigh=(-1)×sighS5:term=sigh×(1/deno)S6:term=sum+termS7:deno=deno+1S8:若deno≤100,返回S4;否则,结束。【例2.5】对一个大于或等于3的正整数,判断它是不是一个素数。算法可表示如下:S1:输入n的值S2:i=2S3:n被i除,得余数rS4:如果r=0,表示n能被i整除,则打印n“不是素数”,算法结束;否则执行S5S5:i+1→iS6:如果i≤n-1,返回S3;否则打印n“是素数”;然后算法结束。改进:S6:如果i≤,返回S3;否则打印n“是素数”;然后算法结束。
2.3算法的特性l有穷性:一个算法应包含有限的操作步骤而不能是无限的。l确定性:算法中每一个步骤应当是确定的,而不能应当是含糊的、模棱两可的。l有零个或多个输入。l
有一个或多个输出。l有效性:算法中每一个步骤应当能有效地执行,并得到确定的结果。对于程序设计人员,必须会设计算法,并根据算法写出程序。2.4怎样表示一个算法2.4.1
用自然语言表示算法除了很简单的问题,一般不用自然语言表示算法。
2.4.2
用流程图表示算法流程图表示算法,直观形象,易于理解。
5的阶乘2.4.4
用N-S流程图表示算法1973年美国学者提出了一种新型流程图:N-S流程图。顺序结构:选择结构:循环结构:
2.4.5
用伪代码表示算法伪代码使用介于自然语言和计算机语言之间的文字和符号来描述算法。2.4.6用计算机语言表示算法l
任务是用计算机解题,就是用计算机实现算法;l用计算机语言表示算法必须严格遵循所用语言的语法规则。【例2.20】求1×2×3×4×5用C语言表示。
main(){inti,t;t=1;i=2;while(i<=5){t=t*i;i=i+1;}printf(“%d”,t);}2.5
结构化程序设计方法
自顶向下;
逐步细化;
模块化设计;结构化编码
第一、二章作业【题1.1】一个C程序的执行是从
。A)
本程序的main函数开始,到main函数结束B)
本程序文件的第一个函数开始,到本程序文件的最后一个函数结束C)
本程序的main函数开始,到本程序文件的最后一个函数结束D)
本程序文件的第一个函数开始,到本程序main函数结束
【题1.2】以下叙述正确的是
。A)
在C程序中,main函数必须位于程序的最前面B)
C程序的每行中只能写一条语句C)
C语言本身没有输入输出语句D)
在对一个C程序进行编译的过程中,可发现注释中的拼写错误
【题1.3】以下叙述不正确的是
。A)
一个C源程序可由一个或多个函数组成B)
一个C源程序必须包含一个main函数C)
C程序的基本组成单位是函数D)
在C程序中,注释说明只能位于一条语句的后面【题1.4】C语言规定:在一个源程序中,main函数的位置
。A)
必须在最开始B)
必须在系统调用的库函数的后面C)
可以任意D)
必须在最后
【题1.5】一个C语言程序是由
。A)
一个主程序和若干子程序组成B)
函数组成C)
若干过程组成
D)若干子程序组成
【题1.6】C源程序的基本单位是【
】。
【题1.7】一个C源程序至少应包括一个【
】。
【题1.8】在一个C源程序中,注释部分两侧的分界符分别为【1】和【2】。【题1.9】在C语言中,输入操作是由库函数【1】完成的,输出操作是由库函数【2】完成的。P372.42.8【题1.1-1.5】ACDCB【题1.6】函数【题1.7】主函数(或:main函数)【题1.8】【1】/* 【2】*/【题1.9】【1】scanf 【2】printf
第三章数据类型运算符与表达式预备知识数据类型常量与变量不同类型数据间的转换运算符和表达式3.0
预备知识计算机中数的表示及进制转换数码、基与权数码:表示数的符号基:数码的个数权:每一位所具有的值数制<>语言程序设计第三章数据描述C各种进制之间的转换二进制、八进制、十六进制转换成十进制方法:按权相加<>语言程序设计第三章数据描述C各种进制之间的转换(整数)二进制、八进制、十六进制转换成十进制方法:按权相加十进制转换成二进制、八进制、十六进制方法:连续除以基,从低到高记录余数,直至商为0例把十进制数59转换成二进制数5922921427232120(59)10=(111011)2110111111011余余余余余余例把十进制数159转换成八进制数1598198280(159)10=(237)8237余7余3余2例把十进制数459转换成十六进制数4591628161160(459)10=(1CB)161CB余11余12余1语言程序设计第三章数据描述C二进制与八进制之间的转换二进制转换成八进制:从右向左,每3位一组(不足3位左补0),转换成八进制八进制转换成二进制:用3位二进制数代替每一位八进制数例(1101001)2=(001,101,001)2=(151)8例(246)8=(010,100,110)2=(10100110)2000~0001~1010~2011~3100~4101~5110~6111~7<>语言程序设计第三章数据描述C二进制与十六进制之间的转换二进制转换成十六进制:从右向左,每4位一组(不足4位左补0),转换成十六进制十六进制转换成二进制:用4位二进制数代替每一位十六进制数例(11010101111101)2=(0011,0101,0111,1101)2=(357D)16例(4B9E)16=(0100,1011,1001,1110)2=(100101110011110)20000~00001~10010~20011~30100~40101~50110~60111~71000~81001~91010~A1011~B1100~C1101~D1110~E1111~F<>语言程序设计第三章数据描述C字节和位内存以字节为单元组成每个字节有一个地址一个字节一般由8个二进制位组成每个二进位的值是0或101234567012345678910……...<>语言程序设计第三章数据描述C7643251数值的表示方法——原码、反码和补码原码:最高位为符号位,其余各位为数值本身的绝对值反码:正数:反码与原码相同负数:符号位为1,其余位对原码取反补码:正数:原码、反码、补码相同负数:最高位为1,其余位为原码取反,再对整个数加1<>语言程序设计第三章数据描述C原码反码补码+7000001110000011100000111-7100001111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围01111111~11111111(-127~+127)01111111~10000000(-127~+127)01111111~10000000(-128~+127)(用一字节表示数)负数补码转换成十进制数:最高位不动,其余位取反加1例补码:11111001
取反:10000110
加1:10000111=-7<>语言程序设计第三章数据描述C3.1
数据类型数据类型总表<>C数据类型基本类型构造类型指针类型空类型void定义类型typedef字符类型char枚举类型enum整型实型单精度型float双精度型double数组结构体struct共用体union短整型short长整型long整型int数据类型决定:1.数据占内存字节数2.数据取值范围3.其上可进行的操作语言程序设计第三章数据描述C基本数据类型<>类型符号关键字数的表示范围所占位数整型字符型实型有无(signed)int16-32768~32767(signed)short16-32768~32767(signed)long32-2147483648~214748364716unsigned
int0~65535320~4294967295unsigned
longunsigned
short160~65535有float323.4e-38~3.4e38有double641.7e-308~1.7e308有char8-128~127无unsignedchar80~255说明:数据类型所占字节数随机器硬件不同而不同,上表以IBMPC机为例:语言程序设计第三章数据描述C3.2
常量与变量标识符定义:用来标识变量、常量、函数等的字符序列组成:只能由字母、数字、下划线组成,且第一个字母必须是字母或下划线大小写敏感不能使用关键字长度:最长32个字符命名原则:见名知意不宜混淆如l与I,o与0例:判断下列标识符号合法性sumSumM.D.JohndayDate3daysstudent_name#33lotus_1_2_3chara>b_above$123<>M.D.John3days#33char$123a>b语言程序设计第三章数据描述C一般用大写字母是宏定义预处理命令,不是C语句直接常量:整型常量实型常量字符常量字符串常量如#definePRICE30常量定义:程序运行时其值不能改变的量(即常数)分类:符号常量:用标识符代表常量定义格式:#define
符号常量常量>>>><>例符号常量举例(ch2_1.c)#definePRICE30main(){intnum,total;num=10;total=num*PRICE;printf("total=%d",total);}运行结果:total=300语言程序设计第三章数据描述C整型常量(整常数)三种形式:十进制整数:由数字0~9和正负号表示.如123,-456,0八进制整数:由数字0开头,后跟数字0~7表示.如0123,011十六进制整数:由0x开头,后跟0~9,a~f,A~F表示.如0x123,0Xff<例12与12L例30000为int型65536为longint型整型常量的类型根据其值所在范围确定其数据类型在整常量后加字母l或L,认为它是longint
型常量问题:0123=()100x123=()100Xff=()1083291255问题:0123=()100x123=()100Xff=()10语言程序设计第三章数据描述C实型常量(实数或浮点数)表示形式:十进制数形式:(必须有小数点)如0.123,.123,123.0,0.0,123.指数形式:(e或E之前必须有数字;指数必须为整数)如12.3e3,123E2,1.23e4,e-5,1.2E-3.5
<实型常量的类型默认double型在实型常量后加字母f或F,认为它是float型语言程序设计第三章数据描述C字符常量定义:用单引号括起来的单个普通字符或转义字符.
字符常量的值:该字符的ASCII码值<转义字符及其含义:转义字符含义\n\v\r\a\‘\ddd\t\b\f\\\“\xhh转义字符含义换行垂直制表回车响铃单引号3位8进制数代表的字符水平制表退格换页反斜线双引号2位16进制数代表的字符如‘\101’‘A’‘\012’’\n’‘\376’’’‘\x61’’a’‘\60’’0’‘\483’(
)例:‘A’’\101’’\x41’65<如‘A’——65,‘a’——97,
‘0’——48,‘\n’——10如‘a’‘A’‘?’‘\n’‘\101’转义字符:反斜线后面跟一个字符或一个代码值表示例转义字符举例(ch2_001.c,ch2_004.c)
main(){printf("\101\x42C\n");printf("Isay:\"Howareyou?\"\n");printf("\\CProgram\\\n");printf("Turbo\'C\'");}运行结果:(屏幕显示)ABCIsay:”Howareyou?”\CProgram\Turbo‘C’<字符常量与字符串常量不同字符串常量定义:用双引号(“”)括起来的字符序列存储:每个字符串尾自动加一个‘\0’作为字符串结束标志hello\0例字符串“hello”在内存中aa\0例‘a’“a”例空串“”\0例:charch;ch=“A”;例:charch;ch=‘A’;语言程序设计第三章数据描述C编译程序根据变量定义为其分配指定字节的内存单元…...地址inta=1,b=-3,c;abc2字节2字节2字节地址地址…...内存1-3
随机数变量概念:其值可以改变的量变量名与变量值变量定义的一般格式:
数据类型变量1[,变量2,…,变量n];<>变量初始化:定义时赋初值例:inta,b,c;floatdata;决定分配字节数和数的表示范围合法标识符例:inta=2,b,c=4;floatdata=3.67;charch=‘A’;intx=1,y=1,z=1;
intx=y=z=1;变量的使用:先定义,后使用例1intstudent;stadent=19;//Undefinedsymbol‘statent’infunctionmain
例2floata,b,c;c=a%b;//Illegaluseoffloatingpointinfunctionmain
变量定义位置:一般放在函数开头main(){inta,b=2;floatdata;a=1;data=(a+b)*1.2;printf(“data=%f\n”,data);}变量定义可执行语句main(){inta,b=2;a=1;floatdata;data=(a+b)*1.2;printf(“data=%f\n”,data);}Ch2_005.c语言程序设计第三章数据描述Ca
变量名3变量值存储单元整型变量占字节数随机器不同而不同,一般占一个机器字short≤int≤long可用sizeof(类型标识符)测量实型变量float:占4字节,提供7位有效数字double:占8字节,提供15~16位有效数字字符型变量字符变量存放字符ASCII码char与int数据间可进行算术运算例floata;a=111111.111;/*a=111111.1*/doubleb;b=111111.111;/*b=111111.111*/例a=‘D’;/*a=68;*/x=‘A’+5;/*x=65+5;*/s=‘!’+‘G’/*s=33+71;*/<>没有字符串变量,用字符数组存放Ch2_006.c语言程序设计第三章数据描述C例/*ch2_003.c*/#definePRICE12.5main(){intnum=3;floattotal;charch1,ch2=‘D’;total=num*PRICE;ch1=ch2-‘A’+‘a’;printf(“total=%f,ch1=%c\n”,total,ch1);}宏定义变量定义输出结果运行结果:total=37.500000,ch1=d语言程序设计第三章数据描述C3.3不同类型数据间的转换隐式转换什么情况下发生运算转换不同类型数据混合运算时赋值转换把一个值赋给与其类型不同的变量时输出转换输出时转换成指定的输出格式函数调用转换实参与形参类型不一致时转换运算转换规则:不同类型数据运算时先自动转换成同一类型<>语言程序设计第三章数据描述Cdoublefloatlongunsignedintchar,short低高说明:必定的转换运算对象类型不同时转换例charch;inti;floatf;doubled;ch/i+f*d-(f+i)intintdoubledoubledoubledoubledoubledoubleintintdoubledoubledoubledoubledoubledouble10+‘a’+i*f-d/l例inti;floatf;doubled;longl;<>显式转换(强制转换)一般形式:(类型名)(表达式)例(int)(x+y)(int)x+y(double)(3/2)(int)3.6说明:强制转换得到所需类型的中间变量,原变量类型不变例main(){floatx;inti;x=3.6;i=(int)x;printf(“x=%f,i=%d”,x,i);}结果:x=3.600000,i=3精度损失问题较高类型向较低类型转换时可能发生<>Ch2_007.cCh2_008.c语言程序设计第三章数据描述C3.4
运算符和表达式C运算符算术运算符:(+-*/%++--)关系运算符:(<<===>>=!=)逻辑运算符:((!&&||)位运算符:(<<>>~|^&)赋值运算符:(=及其扩展)条件运算符:(?:)逗号运算符:(,)指针运算符:(*&)求字节数:(sizeof)强制类型转换:(类型)分量运算符:(.->)下标运算符:([])其它:(()-)<>语言程序设计第三章数据描述C学习运算符应注意:运算符功能与运算量关系要求运算量个数要求运算量类型运算符优先级别结合方向结果的类型<>语言程序设计第三章数据描述C算术运算符和表达式基本算术运算符:+-*/%结合方向:从左向右优先级:->*/%>+-(2)(3)(4)
说明:“-”可为单目运算符时,右结合性两整数相除,结果为整数%要求两侧均为整型数据例5/2=-5/2.0=例5%2=-5%2=1%10=
5%1=5.5%2<>例5/2=2
-5/2.0=-2.5例5%2=1
-5%2=-17%3=
1
5%1=
05.5%2()语言程序设计第三章数据描述C自增、自减运算符++--作用:使变量值加1或减1种类:前置++i,--i(先执行i+1或i-1,再使用i值)后置i++,i--(先使用i值,再执行i+1或i-1)例j=3;k=++j;j=3;k=j++;j=3;printf(“%d”,++j);j=3;printf(“%d”,j++);a=3;b=5;c=(++a)*b;a=3;b=5;c=(a++)*b;<>//k=4,j=4//k=3,j=4//4//3//c=20,a=4//c=15,a=4语言程序设计第三章数据描述C自增、自减运算符++--作用:使变量值加1或减1种类:前置++i,--i(先执行i+1或i-1,再使用i值)后置i++,i--(先使用i值,再执行i+1或i-1)说明:++--不能用于常量和表达式,如5++,(a+b)++++--结合方向:自右向左优先级:-++-->*/%>+-
(2)(3)(4)例-i++-(i++)i=3;printf(“%d”,-i++);//-3
例j+++k;(j++)+k;例-i++i=3;printf(“%d”,-i++);Ch2_009.c语言程序设计第三章数据描述C赋值运算符和表达式简单赋值运算符符号:=格式:变量标识符=表达式作用:将一个数据(常量或表达式)赋给一个变量复合赋值运算符种类:+=-=*=/=%=《=》=&=^=|=含义:exp1op=exp2
exp1=exp1opexp2a+=3a=a+3x*=y+8x=x*(y+8)x%=3x=x%3<>例a=3;d=func();c=d+2;语言程序设计第三章数据描述C说明:结合方向:自右向左优先级:14左侧必须是变量,不能是常量或表达式赋值表达式的值与变量值相等,且可嵌套赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例3=x-2*y;a+b=3;例
floatf;inti;i=10;f=i;则
f=10.0例inti;i=2.56;//结果i=2;例:a=b=c=5a=(b=5)a=5+(c=6)a=(b=4)+(c=6)a=(b=10)/(c=2)<>//表达式值为5,a,b,c值为5//b=5;a=5//表达式值11,c=6,a=11//表达式值10,a=10,b=4,c=6//表达式值5,a=5,b=10,c=2语言程序设计第二章数据描述C说明:结合方向:自右向左优先级:14左侧必须是变量,不能是常量或表达式赋值表达式的值与变量值相等,且可嵌套赋值转换规则:使赋值号右边表达式值自动转换成其左边变量的类型例:a=12;a+=a-=a*a例:main(){inta=3;printf(“%d\n”,(a+=a-=a*a));}<>//a=-264等价于a=a+(a=a-(a*a))//a=-12语言程序设计第三章数据描述C逗号运算符和表达式形式:表达式1,表达式2,……表达式n结合性:从左向右优先级:15逗号表达式的值:等于表达式n的值用途:常用于循环for语句中例a=3*5,a*4a=3*5,a*4,a+5例x=(a=3,6*3)x=a=3,6*a例a=1;b=2;c=3;printf(“%d,%d,%d”,a,b,c);printf(“%d,%d,%d”,(a,b,c),b,c);<>//a=15,表达式值60//a=15,表达式值20//赋值表达式,表达式值18,x=18//逗号表达式,表达式值18,x=3//1,2,3//3,2,3语言程序设计第二章数据描述C逗号运算符和表达式形式:表达式1,表达式2,……表达式n结合性:从左向右优先级:15逗号表达式的值:等于表达式n的值用途:常用于循环for语句中<>语言程序设计第三章数据描述C0111111111111111int型:最大:327671000000000000000最小:-327681111111111111111unsignedint型:最大:655350000000000000000最小:0语言程序设计第三章数据描述C【题3.44】在C语言中(以16位PC机为例),一个char型数据在内存中所占的字节数为【】;一个int型数据在内存中所占的字节数为【】。
【题3.45】在C语言中(以16位PC机为例),一个float型数据在内存中所占的字节数为【】;一个double型数据在内存中所占的字节数为【】。
【题3.46】若有以下定义,则执行表达式y+=y-=m*=y后的y值是【
】。
intm=5,y=2;
【题3.47】设C语言中,一个int型数据在内存中占2个字节,则int型数据的取值范围为【 】。【题3.48】在C语言中的实型变量分为两种类型,它们是【1】和【2】。
【题3.49】C语言所提供的基本数据类型包括:单精度型、双精度型、【1】、【2】和【3】。
【题3.50】若s是int型变量,且s=6,则下面表达式的值为【
】。
s%2+(s+1)%2
【题3.51】若a是int型变量,则下面表达式的值为【
】。
(a=4*5,a*2),a+6【题3.44】【1】1 【2】2【题3.45】【1】4 【2】8【题3.46】-16【题3.47】-32768~32767【题3.48】【1】单精度型(或:float) 【2】双精度型(或:double)【题3.49】【1】整型 【2】字符型 【3】枚举类型【题3.50】1【题3.51】26第四章最简单的C程序设计§4.1C语句概述一、C程序结构┌1┌预编译命令│2│函数1C程序┤若干源程序.──┤函数2┌函数名│.│.──┤说明部分│.│.└执行部分└n└函数n(语句)§4.2C语句分类1.控制语句有关选择、循环、转向、返回
2.函数调用printf(...)3.表达式语句表达式;
4.空语句;什么也不做
5.复合语句{语句1语句n}§4.3程序的三种基本结构顺序结构AB循环结构PATFAPFT选择结构ABPTF格式赋值表达式;
即变量=表达式;或
变量<复合赋值号>表达式;操作计算表达式的值,将该值赋予变量。例a=r*r*3.1415926;注▲赋值语句与赋值表达式的不同概念例if((a=b)>0)t=a;
其中a=b是表达式而不是语句上句相当于
a=b;if(a>0)t=a;可见使用了赋值语句能使程序得到简化。§4.4赋值语句§4.5数据输出一般每个程序都要用到数据的输入输出。数据输入:通过外设将数据输入内存。数据输出:将内存的数据通过外设输出。C语言的输入输出通过调用函数实现,这些输入输出函数一般存于stdio.h和io.h(TURBOC)库文件。使用输入输出函数要用预编译命令指出连接的库文件,程序编译连接时将其与用户程序相连。4.5.1putchar函数(字符输出函数)格式
putchar(C);其中C:一个实参,可以是字符变量、整型变量、整型常量及整型表达式操作输出C值对应的ASCII码,仅输出一个字符注
▲使用该函数将库函数stdio.h要预编译命令说明
格式#include"stdio.h"
或#include<stdio.h>例#include<stdio.h>main(){chara,b,c;a='B';b='O';c='Y';putchar(a);putchar(b);putchar(c);}输出结果BOY例putchar('\n');输出换行
putchar('\101');putchar('A');putchar(65);
输出AAA4.5.2
printf函数其中▲格式控制是由双引号括起来的字符串,包括两种信息
(1)格式说明%格式字符说明输出的数据按制定的类型格式输出如%d%10.2f(2)普通字符照原样输出字符或转义符如abcde\n▲输出表列是输出的数据,可以是常数、变量和表达式,
每个输出数据之间用逗号分隔。如123.45,x,2*a+b操作将输出表列中的数据按格式控制说明类型在显示屏输出格式
printf(格式控制,输出表列);例printf("a=%db=%d\n",a,b);格式控制输出表列其中%d格式说明;a=b=普通字符;\n转义符
a,b输出表列两个变量设a=3,b=4则输出a=3b=4
掌握使用printf()函数关键在于理解格式控制,格式控制中有格式字符和附加格式字符1.d格式字符用来输出十进制整数
%d按整数的实际长度输出
%mdm为指定输出长度。如数据位数小于m,则数据左端补上空格,数据位数大于m,数据按实际长度输出
%ldl表示输出长整型数据例#include<stdio.h>main(){inta=123,b=12345;printf("%d,%d\n",a,b);printf("%4d,%4d\n",a,b);}输出123,12345123,12345例#include<stdio.h>main(){longc;c=123456789;printf("%ld\n",c);}输出123456789注整型的数据必须使用%d
长整型的数据必须使用%ld
两者不能互换使用6.
s
格式字符用来输出字符串
%s
按字符串的实际长度输出
%ms
输出字符串占m列字符串长度小于m,则字符串向右靠,左补空格字符串长度大于m,则字符串按实际长度输出
%-ms
字符串长度小于m,则字符串向左靠,右补空格
%m.ns
输出字符串占m列,只取字符串中左端n个字符,字符串向
右靠,左补空格
%-m.ns
输出字符串占m列,只取字符串中左端n个字符,字符串向
左靠,右补空格例#include<stdio.h>main(){printf("%3s,%7.2s,%.4s,%-5.3s\n","CHINA","CHINA","CHINA","CHINA");}输出CHINA,□□□□□CH,CHIN,CHI□□注
%.ns表示%m.ns中m=n。例中%.4等价%4.4s7.f格式字符用来输出实数的基本型(包括单、双精度)%f
整数部分全部输出,小数部分6位%m.nf
输出数据共占m位,其中n位小数。如数值长度<m,则左端补空格%-m.nf
输出数据共占m位,其中n位小数。如数值长度<m,则右端补空格
例#include<stdio.h>main(){floatf=123.456;printf("%f,%10f,%10.2f,%-10.2f,%.2f\n",f,f,f,f,f);}输出123.456001,123.456001,123.46,123.46,123.46%f%10f%10.2%-10.2%.2注
一般格式说明与输出表列的个数、类型必须一一对应若格式符的个数>输出对象的个数,多余格式符按零值输出若格式符的个数<输出对象的个数,多余输出对象无用§4.6
数据输入4.6.1getchar()函数格式
getchar()操作执行该函数时,等待键盘输入一个字符。即从键盘接受一个字符注无参函数,括弧必须保留。
例3.8#include<stdio.h>main(){charc;c=getchar();putchar(c);}执行到c=getchar();等待键盘键入一个字符输入a<Enter>输出a注输完数据必须按<Enter>4.6.2scanf()函数
格式
scanf(格式控制,地址表列)其中1.格式控制是用双引号括起来的字符串,字符串由格式说明和普通字符构成
(1)
格式说明由%和格式字符构成,说明输入数据的格式格式字符见page43表3.3、表3.4
(2)普通字符作为输入数据之间的分隔符。如,空格
2.地址列表是输入数据存入内存的地址,可以是变量的地址、字符串的首地址,每个内存地址之间用逗号分隔。怎么知道变量的地址?利用地址运算符求出变量的地址格式&变量名例inta,b;则&a,&b表示取a,b变量的地址操作将键盘键入的数据按指定类型格式存入指定内存存储单元例#include<stdio.h>main(){inta,b,c;scanf("%d%d%d",&a,&b,&c);/*格式控制,地址表列*/printf("%d,%d,%d\n",a,b,c);}运行输入345<Enter>
输出3,4,5注1.键入数据之间可用空格、<Tab>或<Enter>分隔,即多各空格分格。上例输入可改为345<enter><Tab><Tab>一个<Tab>跳8个空格或3<Enter>4<Enter>5<Enter>注2.在格式说明中使用了普通字符,则要用普通字符作为数据之间的分隔符。如上例改用输入函数scanf()为
scanf("%d,%d,%d",&a,&b,&c);
输入则为3,4,5<Enter>3使用格式说明符“%c”输入单个字符时,空格和转义字符均作为有效字符被输入。例如,scanf("%c%c%c",&ch1,&ch2,&ch3);printf("ch1=%c,ch2=%c,ch3=%c\n",ch1,ch2,ch3);
假设输入:A□B□C↙,则系统将字母'A'赋值给ch1,空格'□'赋值给ch2,字母'B'赋值给ch3。C语言的格式输入输出的规定比较繁琐,在学习本书时不必花许多精力去死抠每一个细节,重点掌握最常用的一些规则即可。通过上机编写和调试程序来逐步深入面自然地学会输入输出的应用。提高人机交互性建议:为改善人机交互性,同时简化输入操作,在设计输入操作时,一般先用printf()函数输出一个提示信息,再用scanf()函数进行数据输入。例如,将scanf("num1=%d,num2=%d\n",&num1,&num2);改为:
printf("num1=");scanf("%d",&num1);printf("num2=");scanf("%d",&num2);考虑到printf和scanf函数使用频繁,系统允许在使用这两个函数时可不加#include<stdio.h>或#include”stdio.h”§4.7举例[例1]从键盘输入一个小写字母,要求用大小写字母形式输出该字母及对应的ASCII码值。分析:如何将一个小写字母转换成大写字母?一般表达式: (c2=c1-32)#include"stdio.h"main(){charc1,c2;c1=getchar();printf(“%c,%d\n",c1,c1);c2=c1-32; /*将小写字母转换成对应的大写字母*/printf("%c,%d\n",c2,c2);}程序运行情况如下:
A↙A,65 a,97[例2]输入三角形的三边长,求三角形面积。
分析:(1)(2)求平方根函数:sqrt()在math.h中说明
(3)其它一些函数,如:cos(),pow(),exp(),
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 浙教版五年级上册数学第一单元 小数的意义与加减法 测试卷及完整答案【各地真题】
- 2024年购销合同分期付款条款
- 诚信为魂不抄袭作业保证书
- 调峰天然气订购合同
- 货架订购销售协议
- 质量保证书撰写技巧指南汇编设计
- 购买招标文件情况单
- 车辆行驶期间车辆安全行驶保证书
- 软件优化合同模板
- 软件采购合同
- Java程序设计全套课件完整版
- 中国文学常识课件
- 译林版八年级英语下册unit3 reading课件
- 2022年秋粮收购行政执法监督检查方案四篇
- 药物临床试验培训课件
- 计算机图形学历年期末题大三上必考知识点哦
- 某县大河镇生猪交易市场建设项目可行性研究报告
- 住房公积金单位网上业务申请表
- 华北理工大学中药学课程教学大纲(48学时-耿增岩)
- 手术讲解模板臀位外倒转术
- 人体衰老和抗衰老研究讲座课件
评论
0/150
提交评论