c语言程序设计.ppt

上传人:wj 文档编号:11590647 上传时间:2023-06-01 格式:PPT 页数:526 大小:6.12MB
下载 相关 举报
c语言程序设计.ppt_第1页
第1页 / 共526页
c语言程序设计.ppt_第2页
第2页 / 共526页
c语言程序设计.ppt_第3页
第3页 / 共526页
c语言程序设计.ppt_第4页
第4页 / 共526页
c语言程序设计.ppt_第5页
第5页 / 共526页
c语言程序设计.ppt_第6页
第6页 / 共526页
c语言程序设计.ppt_第7页
第7页 / 共526页
c语言程序设计.ppt_第8页
第8页 / 共526页
c语言程序设计.ppt_第9页
第9页 / 共526页
c语言程序设计.ppt_第10页
第10页 / 共526页
c语言程序设计.ppt_第11页
第11页 / 共526页
c语言程序设计.ppt_第12页
第12页 / 共526页
c语言程序设计.ppt_第13页
第13页 / 共526页
c语言程序设计.ppt_第14页
第14页 / 共526页
c语言程序设计.ppt_第15页
第15页 / 共526页
c语言程序设计.ppt_第16页
第16页 / 共526页
c语言程序设计.ppt_第17页
第17页 / 共526页
c语言程序设计.ppt_第18页
第18页 / 共526页
c语言程序设计.ppt_第19页
第19页 / 共526页
c语言程序设计.ppt_第20页
第20页 / 共526页
亲,该文档总共526页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

c语言程序设计.ppt

《c语言程序设计.ppt》由会员分享,可在线阅读,更多相关《c语言程序设计.ppt(526页珍藏版)》请在冰点文库上搜索。

c语言程序设计.ppt

C程序设计,奔腾电脑培训班,课程要求,课前请做好预习保持课堂安静,头脑清醒,思维活跃认真、独立、按时完成并提交作业重视上机实践,有效利用宝贵的上机时间,目录,第1章C语言概述,奔腾电脑培训第一章C语言概述,1.1C语言发展历史程序设计语言的发展,CPU指令系统,由0、1序列构成的指令码组成如:

10000000加10010000减,用助记符号描述的指令系统,可进行地址、位操作如ADDA,B编写系统软件,直接对硬件操作,可读性,移植性差,面向机器的语言,奔腾电脑培训第一章C语言概述,可读性,移植性好,编写应用程序一般较难实现汇编语言的某些功能如:

地址和位的操作,C语言兼有高级和低级语言的功能适合写系统软件和应用软件又称中级语言,1.2C语言的特点语言简洁、紧凑、灵活运算符丰富数据结构、数据类型丰富链表、树、栈程序设计结构化、模块化结构化控制语句:

ifelse、while、switch、for函数作为模块单位语法不严格、程序设计自由度大可以访问内存地址、进行位运算生成目标代码质量高可移植性好,奔腾电脑培训第一章C语言概述,32个关键字:

(由系统定义,不能重作其它定义)autobreakcasecharconstcontinuedefaultdodoubleelseenumexternfloatforgotoifintlongregisterreturnshortsignedsizeofstaticstructswitchtypedefunsignedunionvoidvolatilewhileTurboC扩充了11个关键字:

asm_cs_ds_es_sscdeclfarhugeinterruptnearpascal注意:

在C语言中,关键字都是小写的。

奔腾电脑培训第一章C语言概述,C语言简洁、紧凑,使用方便、灵活。

ANSIC一共只有32个关键字,见365页附录B,9种控制语句:

if()elsefor()while()dowhile()continuebreakswitchgotoreturn,奔腾电脑培训第一章C语言概述,C语言有9种控制语句,程序书写形式自由,主要用小写字母表示,压缩了一切不必要的成分。

34种运算符:

算术运算符:

+-*/%+-关系运算符:

=!

=逻辑运算符:

&|位运算符:

|&赋值运算符:

=及其扩展条件运算符:

?

:

逗号运算符:

指针运算符:

*&求字节数:

sizeof强制类型转换:

(类型)分量运算符:

.-下标运算符:

其它:

()-注意:

各种运算符混合使用,其优先级与结合方法是难点,可先预习。

奔腾电脑培训第一章C语言概述,C语言运算符丰富(附录C),奔腾电脑培训第一章C语言概述,C语言数据结构丰富,1.3简单的C程序介绍,/*example1.1ThefirstCProgram*/#includevoidmain()printf(“whatisyouname.n”);,奔腾电脑培训第一章C语言概述,输出:

Whatisyouname.,例1.1第一个程序Thisisacprogram.,printf语句中的“n”是换行符,例1.2求俩个数的和,/*example1.1calculatethesumofaandb*/#include/*Thisisthemainprogram*/voidmain()inta,b,sum;/*定义变量*/a=10;b=24;sum=add(a,b);printf(”sum=%dn,sum);/*Thisfunctioncalculatesthesumofxandy*/intadd(intx,inty)intz;z=x+y;return(z);,运行结果:

sum=34,奔腾电脑培训第一章C语言概述,printf语句中的“%d”是表示“十进制整数类型”,奔腾电脑培训第一章C语言概述,例1.3从键盘输入两个整数,输出其中较大的数,#includevoidmain()intmax(intx,inty)inta,b,c;scanf(“%d,%d”,scanf语句中“&a”的含义是“取地址”,输入:

10,20输出:

max=20,声明部分,定义变量,调用max函数,返回值赋给c,定义max子函数,函数值、形参x、y为整型,通过max函数将z值带回调用处,C语言格式特点习惯用小写字母,大小写敏感不使用行号,无程序行概念可使用空行和空格常用锯齿形书写格式,奔腾电脑培训第一章C语言概述,main().,main()inti,j,sum;sum=0;for(i=1;i10;i+)for(j=1;j10;j+)sum+=i*j;printf(“%dn”,sum);,优秀程序员的素质之一:

使用TAB缩进对齐有足够的注释有合适的空行,C语言结构特点函数与主函数程序由一个或多个函数组成必须有且只能有一个主函数main(),可以放在程序中任一位置程序执行从main开始,在main中结束,其它函数通过嵌套调用得以执行。

程序语句C程序由语句组成用“;”作为语句终止符注释/*/为注释,不能嵌套不产生编译代码,例:

/*Thisisthemain/*ofexample1.1*/*/,编译预处理命令,奔腾电脑培训第一章C语言概述,1.4C程序的上机步骤C程序开发步骤,file.exe,奔腾电脑培训第一章C语言概述,程序代码的录入,生成源程序*.c,语法分析查错,翻译生成目标程序*.obj,与其它目标程序或库链接装配,生成可执行程序*.exe,算法的概念,简单算法举例,算法的特性,怎样表示一个算法,第2章程序的灵魂算法,奔腾电脑培训第二章程序的灵魂算法,结构化程序设计方法,奔腾电脑培训第二章程序的灵魂算法,程序包括的内容:

数据结构:

数据的类型和组织形式算法:

操作步骤的描述,NikiklausWirth提出:

教材认为:

程序,=算法+数据结构+程序设计方法+语言工具和环境,灵魂,加工对象,工具,奔腾电脑培训第二章程序的灵魂算法,2.1算法的概念为解决一个问题而采取的方法和步骤,就成为算法。

例如:

歌曲的乐谱,建造房子等。

算法核心是解决“做什么”和“怎么做”的问题。

P15页的例2.1,求15之积。

可以有多种方法,一般采用简单和运算步骤少的。

准确、高效计算机算法类别数值运算算法非数值运算算法,奔腾电脑培训第二章程序的灵魂算法,2.3算法的特性有穷性在合理范围内可完成确定性无歧义性有零个或多个输入从外界得到信息有一个或多个输出问题的答案有效性每步有确定的结果,奔腾电脑培训第二章程序的灵魂算法,2.4怎样表示一个算法自然语言表示2.2节例。

易懂,文字冗长,易歧义性流程图表示用流程图符号构成,直观,易懂N-S流程图表示伪代码表示计算机语言表示,顺序结构选择结构循环结构,奔腾电脑培训第二章程序的灵魂算法,传统流程图流向混乱、可读性差,所以应该采用结构化流程图。

结构化程序设计基本思想:

任何程序都可以用三种基本结构表示,限制使用无条件转移语句(goto)结构化程序:

由三种基本结构反复嵌套构成的程序优点:

结构清晰,易读,提高程序设计质量和效率,三种基本结构顺序结构,奔腾电脑培训第二章程序的灵魂算法,选择结构,二分支选择结构,多分支选择结构,奔腾电脑培训第二章程序的灵魂算法,循环结构,当型循环结构,直到型循环结构,注:

A,B,A1.An可以是一个简单语句,也可以是一个基本结构,奔腾电脑培训第二章程序的灵魂算法,三种基本结构的共同特点:

只有一个入口;只有一个出口;结构内的每一部分都有机会被执行到;结构内不存在“死循环”。

奔腾电脑培训第二章程序的灵魂算法,2.5结构化程序设计方法结构化程序:

用三种基本结构组成的程序基本设计思路:

复杂问题分解成几个最基本问题,再分别处理。

采用的方法:

自顶向下;逐步细化;模块化设计:

复杂问题按功能分成多个子模块结构化编码:

正确采用三种基本结构实现,第3章数据类型、运算符与表达式,奔腾电脑培训第三章程序的灵魂算法,C的数据类型,常量与变量,整型数据,实型数据,字符型数据,变量赋初值,各种数值型数据间的混合运算,算术运算符和算术表达式,赋值运算符和赋值表达式,逗号运算符和逗号表达式,奔腾电脑培训第三章程序的灵魂算法,3.1C的数据类型,数据类型决定:

1.数据占内存字节数2.数据取值范围3.可以进行的操作,奔腾电脑培训第三章程序的灵魂算法,常量和符号常量定义:

程序运行过程中,其值不能被改变的量(常数)分类:

直接常量、符号常量,3.2常量与变量,奔腾电脑培训第三章程序的灵魂算法,符号常量:

用标识符代表常量一般用大写字母:

PRICE、PI定义格式:

#define符号常量常量其值在作用域内不能改变和再赋值。

例3.1符号常量举例#definePRICE30#includevoidmain()intnum,total;num=10;total=num*PRICE;printf(total=%dn,total);,符号常量的优点是:

见名知意、一改全改,奔腾电脑培训第三章程序的灵魂算法,变量定义:

其值可以改变的量。

定义格式:

数据类型变量名;变量应该有名字,并在内存中占据一定的存储单元。

变量名和变量值有不同的含义变量名实为一个符号地址,例变量的使用main()inta;a=3;printf(“a=%d,a);,奔腾电脑培训第三章程序的灵魂算法,标识符定义:

标识变量名、符号常量名、函数名、数组名、文件名的字符串序列名字。

命名规则:

只能由字母、数字、下划线组成,且第一个字符必须是字母或下划线大小写字母含义不同,一般用小写不能使用关键字TC允许最长32个字符,建议长度不超过8个字符使用:

先定义、后使用,标识符应该“见名知意”,如total,max标识符应该“不宜混淆”,如l与1,O与0,这些标识符合法吗?

1A、M.D.John、¥123、#33、Tatol、int、max,奔腾电脑培训第三章程序的灵魂算法,3.3整型数据整型常量(整常数)的三种表示方法十进制整数:

由数字09和正负号表示.如123,-456,0八进制整数:

由数字0开头,后跟数字07表示.如0123,011十六进制整数:

由0x开头,后跟09,af,AF表示.如0x123,0xff,奔腾电脑培训第三章程序的灵魂算法,补充知识:

字节和位内存以字节为单元组成每个字节有一个地址一个字节一般由8个二进制位组成每个二进位的值是0或1,奔腾电脑培训第三章程序的灵魂算法,数值的表示方法原码、反码和补码原码:

最高位为符号位,其余各位为数值本身的绝对值反码:

正数:

反码与原码相同负数:

符号位为1,其余位对原码取反补码:

正数:

原码、反码、补码相同负数:

最高位为1,其余位为原码取反,再对整个数加1,9-5=49+7=16=(14)12,奔腾电脑培训第三章程序的灵魂算法,负数补码转换成十进制数:

最高位不动,其余位取反加1,例补码:

11111001取反:

10000110加1:

10000111=-7,奔腾电脑培训第三章程序的灵魂算法,整型变量整型数据在内存中的存放形式数据在内存中以二进制补码形式存放每一个整型变量在内存中占2个字节10的原码反码补码-10的原码取绝对值反码补码,整数的最左二进制位是符号位,0正、1负,奔腾电脑培训第三章程序的灵魂算法,整型变量的分类三类整型变量,整数类型和取值范围,奔腾电脑培训第三章程序的灵魂算法,整型变量的定义先定义后使用强制类型定义inta,b;(指定变量a、b为整型)unsignedshortc,d;(指定变量c、d为无符号短整型)longe,f;(指定变量e、f为长整型),例3.2整型变量的定义与使用#includevoidmain()inta,b,c,d;unsignedu;a=12;b=-24;u=10;c=a+u;d=b+u;printf(“a+u=%d,b+u=%dn,c,d);,指定abcd为整型变量,指定u为无符号整型变量,定义放在函数开头的声明部分,不同类型混合运算,类型自动转换,结果:

a+u=22,b+u=-14,定义与赋值同时进行:

inta=12;,奔腾电脑培训第三章程序的灵魂算法,整型数据的溢出此情况称为“溢出”,运行时不报错,编程时要注意,整型变量最大值32767,加1后是32768的补码形式,例3.3整型数据的溢出#includevoidmain()inta,b;a=32767;b=a+1;printf(%d,%dn,a,b);,改为:

longb;结果是什么?

奔腾电脑培训第三章程序的灵魂算法,整型常量的类型整型常量的值在-32768+32767范围内,编译器认为是int类型整型常量的值超过上述范围,而在2147483648+2147483647范围内,编译器认为是long类型当系统定义shortint与int占内存长度相同,则两种类型常量均可以赋给int和shortint型变量在整型常量后面加大写L或小写l,则告诉编译器,把该整型常量作为long类型处理。

例:

123L、0L在整型常量后面加u,则按无符号整型方式存放,负数转换成补码再按无符号整型方式存放。

奔腾电脑培训第三章程序的灵魂算法,3.4浮点型数据浮点型常量的表示方法浮点数(float)又称为实数(real)两种表示方法:

十进制小数形式:

必须有小数点如0.123、.123、123.0、0.0、123.指数形式:

e或E之前后必须有数字;指数必须为整数如123.456e0、12.3456e1、1.23456e2、0.123456e3、0.0123456e4等规范化指数形式只有一位非零整数的指数形式是指数的输出形式,6.28e-2表示6.2810-2,-3.0824e4表示3.0824104,奔腾电脑培训第三章程序的灵魂算法,浮点型变量浮点型数据在内存中的存放形式浮点型数据在内存中占4个字节(32位)在内存中分成3部分,指数为2的幂次,+.3141591,数符,小数部分,指数,浮点型变量的分类,floatx,y;(指定x、y为单精度浮点型变量)doublez;(指定z为双精度浮点型变量)longdoublet;(指定t为长双精度浮点型变量),奔腾电脑培训第三章程序的灵魂算法,浮点型数据的舍入误差数据超过有效位数,则产生误差要避免一个很大的数与一个很小的数加减,例3.4浮点型数据的舍入误差#includevoidmain()floata,b;a=123456.789e5;b=a+20;printf(%fn,b);,舍入误差使1.0/3*3的结果并不等于1!

浮点型常量的类型浮点型常量一般按双精度64位处理,数后加F或f按单精度浮点型常量不分float和double,奔腾电脑培训第三章程序的灵魂算法,3.5字符型数据字符常量定义:

用单引号括起来的单个字符或转义字符字符常量的值:

该字符的ASCII码值定义格式:

char变量名=值转义字符:

反斜线后面跟一个字符或一个代码值表示,如aAnt,如a97,A65n10,t9,charch=65与charch=A与char=101是等效的,奔腾电脑培训第三章程序的灵魂算法,例3.5转义字符的使用#includevoidmain()printf(“abctderftgn”);printf(“htibbjk”);,奔腾电脑培训第三章程序的灵魂算法,字符变量存放字符常量,占用一个字节,存放一个字符定义形式:

赋值:

charc1,c2;c1=a;c2=b;,字符数据在内存中的存储形式及其使用方法以二进制存放字符的ASCII码值(0255整数)与整数的存储形式类似以字符或整数形式输出,例3.6向字符变量赋整数#includevoidmain()charc1,c2;c1=97;c2=98;printf(“%c%cn,c1,c2);printf(“%d%dn,c1,c2);,输出形式取决于printf函数中的格式符,格式符为“%c”时输出的变量值为字符格式符为“%d时输出的变量值为整数,奔腾电脑培训第三章程序的灵魂算法,对字符数据进行算术运算实质是对其ASCII值进行算术运算,例3.7大小写字母的转换#includevoidmain()charc1,c2;c1=a;c2=b;c1=c1-32;c2=c2-32;printf(“%c%c,c1,c2);,字符型与整型间互相赋值,例:

互相赋值#includevoidmain()intc1;charc2;c1=a;c2=98;c1=c1-32;c2=c2-32;printf(“%c%c,c1,c2);,小写字母比大写字母的ASCII码大(32)10,奔腾电脑培训第三章程序的灵魂算法,字符串常量定义:

用双引号(“”)括起来的字符序列“Howdoyoudo”,“CHINA”,“a”,“$123.45”存储:

每个字符串尾自动加一个0作为字符串结束标志,字符常量与字符串常量不同,例:

charch;ch=“A”;,没有字符串变量,只能用字符数组存放,奔腾电脑培训第三章程序的灵魂算法,3.6变量赋初值变量的使用:

先定义,后使用变量定义位置:

一般放在函数开头变量初始化:

可以在定义时赋初值,例:

inta=1,b=-3,c;floatdata=3.67;charch=A;intx=1,y=1,z=1;intx=y=1;(),错!

inta=b=c=3,奔腾电脑培训第三章程序的灵魂算法,3.7各类数值型数据间的混合运算整型、实型、字符型数据间可以混合运算,自动转换什么情况下发生运算转换-不同类型数据混合运算时赋值转换-把一个值赋给与其类型不同的变量时输出转换-输出时转换成指定的输出格式函数调用转换-实参与形参类型不一致时转换运算转换规则:

不同类型数据运算时先自动转换成同一类型,奔腾电脑培训第三章程序的灵魂算法,奔腾电脑培训第三章程序的灵魂算法,强制转换(见P56强制类型转换运算符部分)一般形式:

(类型名)(表达式)例:

(int)(x+y)(int)x+y(double)(3/2)(int)3.6说明:

强制转换得到所需类型的中间变量,原变量类型不变,例3.8#includemain()floatx;inti;x=3.6;i=(int)x;printf(“x=%f,i=%d”,x,i);结果:

x=3.600000,i=3,精度损失问题,强制类型转换运算符,表达式仅一个变量时,括号可以省略,奔腾电脑培训第三章程序的灵魂算法,3.8算术运算符和算术表达式,学习运算符应注意:

运算符功能与运算量关系要求运算量个数要求运算量类型运算符优先级别结合方向结果的类型,奔腾电脑培训第三章程序的灵魂算法,算术运算符和算术表达式基本算术运算符:

+-*/%结合方向:

从左向右优先级:

-*/%-+-

(2)(3)(4)说明:

“-”可为单目运算符时,右结合性两整数相除,结果为整数%要求两侧均为整型数据+-*/运算的两个数中有一个数为实数,结果是double型,例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=-11%10=15%1=05.5%2(),奔腾电脑培训第三章程序的灵魂算法,自增、自减运算符+作用:

使变量值加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,j=4,/3,j=4,/c=20,a=4,/c=15,a=4,奔腾电脑培训第三章程序的灵魂算法,几点说明:

例-i+i=3;printf(“%d”,-i+);,-(i+),/-3,+-不能用于常量和表达式,如5+,(a+b)+-结合方向:

自右向左优先级:

-+-*/%-+-

(2)(3)(4)该运算符常用于循环语句中,使循环变量加减1,有关表达式使用中的问题说明不同系统对运算符和表达式的处理次序不同,尽可能写通用性强的语句不要写有歧义和不知系统如何执行的程序,奔腾电脑培训第三章程序的灵魂算法,3.9赋值运算符和赋值表达式,简单赋值运算符符号:

=格式:

变量标识符=表达式作用:

将一个数据(常量或表达式)赋给一个变量左侧必须是变量,不能是常量或表达式,例a=3;d=func();c=d+2;,例3=x-2*y;a+b=3;(),类型转换赋值转换规则:

使赋值号右边表达式值自动转换成其左边变量的类型,例floatf;inti=10;f=i;则f=10.0,例inti;i=2.56;/结果i=2;,复合赋值运算符种类:

+=-=*=/=%=&=|=含义:

exp1op=exp2exp1=exp1opexp2,奔腾电脑培训第三章程序的灵魂算法,赋值表达式形式:

赋值表达式的值与变量值相等,且可嵌套,例:

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,奔腾电脑培训第三章程序的灵魂算法,3.10逗号运算符和逗号表达式形式:

表达式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,奔腾电脑培训第三章程序的灵魂算法,例:

逗号表达式使用main()intx,y=7;floatz=4;x=(y=y+6,y/z);printf(x=%dn,x);,本章的内容散乱而复杂,但却是程序设计的基础,要认真看书,通过编程序才可以深入理解。

第4章最简单的C程序设计顺序程序设计,奔腾电脑培训第四章顺序程序设计,C语言概述,赋值语句,数据输入输出的概念及在C语言中的实现,字符数据的输入输出,格式输入与输出,顺序结构程序设计举例,4.1C语句概述C程序结构:

一个C程序可以由多个源程序文件构成一个源程序文件由若干函数、预编译命令及全局变量声明部分构成函数包括数据定义部分和执行部分,执行部分是C语言语句,完成对数据的操作,奔腾电脑培训第四章顺序程序设计,C语句分为5类控制语句:

共9种完成一定的控制功能,这些语句能够根据一定的测试条件决定某些语句是否被执行,如分支、循环、跳转等语句。

奔腾电脑培训第四章顺序程序设计,奔腾电脑培训第四章顺序程序设计,空语句:

只有一个“;”,什么也不做,表达式语句:

由表达式加“;”组成典型的是赋值语句,由赋值表达式加分号构成,如:

y=x+1是表达式,而y=x+1;则是赋值语句。

实际上函数调用语句也属于表达式语句。

函数调用语句:

由函数加“;”组成,printf(“ThisisaCprogram”);,a=3;i+;,for

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

当前位置:首页 > 自然科学 > 物理

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2