c语言程序设计谭浩强完整.pptx
《c语言程序设计谭浩强完整.pptx》由会员分享,可在线阅读,更多相关《c语言程序设计谭浩强完整.pptx(533页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、熟记熟记C语言的基本概念语言的基本概念熟悉熟悉Turbo C的上机操作环境的上机操作环境会读、会编、会调试会读、会编、会调试C程序程序 学习要点 熟记熟记C语言的语法语言的语法 学会算法分析与算法设计学会算法分析与算法设计课程目的第1页/共533页课程要求课前请做好预习保持课堂安静,头脑清醒,思维活跃认真、独立、按时完成并提交作业重视上机实践,有效利用宝贵的上机时间第2页/共533页第1章C语言概述第2章程序的灵魂算法第3章数据类型、运算符与表达式第4章最简单的C程序设计顺序程序设计第5章选择结构程序设计第6章循环控制第7章数组第8章函数第9章预处理命令第10章指针第11章结构体与共用体第12
2、章位运算第13章文件目 录第3页/共533页C语言发展历史C语言的特点简单的C程序介绍C程序的上机步骤第1章 C语言概述 C语言程序设计 第一章 C语言概述第4页/共533页1.1 C语言发展历史程序设计语言的发展机器语言汇编语言高级语言面向过程面向对象CPU指令系统,由0、1序列构成的指令码组成如:10000000加10010000减用助记符号描述的指令系统,可进行地址、位操作如ADDA,B编写系统软件,直接对硬件操作,可读性,移植性差面向机器的语言 C语言程序设计 第一章 C语言概述可读性,移植性好,编写应用程序一般较难实现汇编语言的某些功能如:地址和位的操作C语言兼有高级和低级语言的功能
3、适合写系统软件和应用软件又称中级语言第5页/共533页C语言发展过程产生背景ALGOL 60CPL语言BCPLB语言,写UNIX系统产生过程时间:19721973地点:美国贝尔实验室目的:UNIX操作系统设计人和C标准标准C:1978年 K&R合著The C Programming LanguageANSI C:1983年87 ANSI C:1987年1990年国际标准的ANSI C,1994年再次修订。C版本Microsoft C 或称 MS-C Turbo C 或称 TC C语言程序设计 第一章 C语言概述第6页/共533页 C语言的特点语言简洁、紧凑、灵活运算符丰富数据结构、数据类型丰富
4、链表、树、栈程序设计结构化、模块化结构化控制语句:ifelse、while、switch、for函数作为模块单位语法不严格、程序设计自由度大可以访问内存地址、进行位运算生成目标代码质量高可移植性好 C语言程序设计 第一章 C语言概述第7页/共533页32个关键字:(由系统定义,不能重作其它定义由系统定义,不能重作其它定义)autobreakcasecharconstcontinuedefaultdodoubleelseenumexternfloatforgotoifintlongregisterreturnshortsignedsizeofstaticstructswitchtypedefun
5、signedunionvoidvolatilewhileTurboC扩充了11个关键字:asm_cs_ds_es_sscdecl farhuge interruptnearpascal注意:在C语言中,关键字都是小写的。C语言程序设计 第一章 C语言概述C语言简洁、紧凑,使用方便、灵活。ANSIC一共只有32个关键字,见365页附录B第8页/共533页9种控制语句:if()elsefor()while()dowhile()continuebreakswitchgotoreturn C语言程序设计 第一章 C语言概述C语言有9种控制语句,程序书写形式自由,主要用小写字母表示,压缩了一切不必要的成
6、分。第9页/共533页 C语言程序设计 第一章 C语言概述表1.1C语言与Pascal语言比较通过表1.1我们可以得出结论:C比Pascal简练,因此源程序更短,编程效率高。第10页/共533页34种运算符:算术运算符:+-*/%+-关系运算符:=!=逻辑运算符:!&|位运算符 :|&赋值运算符:=及其扩展条件运算符:?:逗号运算符:,指针运算符:*&求字节数 :sizeof强制类型转换:(类型)分量运算符:.-下标运算符:其它 :()-注意:各种运算符混合使用,其优先级与结合方法是难点,可先预习。C语言程序设计 第一章 C语言概述C语言运算符丰富(附录C)第11页/共533页C数据类型基本类
7、型构造类型指针类型空类型void定义类型typedef数值类型字符类型char枚举类型enum整型浮点型单精度型float双精度型double短整型short长整型long整型int数组结构体struct共用体union C语言程序设计 第一章 C语言概述C语言数据结构丰富第12页/共533页简单的C程序介绍/*example1.1ThefirstCProgram*/#includevoidmain()printf(“Thisisacprogram.n”);C语言程序设计 第一章 C语言概述注释编译预处理主函数语句输出:Thisisacprogram.例1.1 第一个程序Thisisacpro
8、gram.printf语句中的“n”是换行符 第13页/共533页例求俩个数的和/*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语言程序设计 第一章 C语言概述例1
9、.3 从键盘输入两个整数,输出其中较大的数#includevoidmain()intmax(intx,inty)inta,b,c;scanf(“%d,%d”,&a,&b);c=max(a,b);printf(max=%d,c);intmax(intx,inty)intz;if(xy)z=x;elsez=y;return(z);scanf语句中“&a”的含义是“取地址”输入:10,20输出:max=20声明部分,定义变量调用max函数,返回值赋给c定义max子函数,函数值、形参x、y为整型通过max函数将z值带回调用处第15页/共533页C语言格式特点习惯用小写字母,大小写敏感不使用行号,无程序
10、行概念可使用空行和空格常用锯齿形书写格式 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缩进对齐有足够的注释有合适的空行第16页/共533页C语言结构特点函数与主函数程序由一个或多个函数组成必须有且只能有一个主函数main(),可以放在程序中任一位置程序执行从main开始,在main中结束,其它函数通过嵌套调用得以执行。程序语句C程序由语句组成用“;”作为语句终止符注释/*/为注释,不能嵌套不产生编译代
11、码例:/*Thisisthemain/*ofexample1.1*/*/非法v编译预处理命令 C语言程序设计 第一章 C语言概述第17页/共533页编辑链接编译执行C程序的上机步骤C程序开发步骤file.exe C语言程序设计 第一章 C语言概述程序代码的录入,生成源程序*.c语法分析查错,翻译生成目标程序*.obj与其它目标程序或库链接装配,生成可执行程序*.exe第18页/共533页Turbo C集成开发环境配置要求UNIX,PC-DOS,MS-DOS,UCDOS操作系统硬盘容量约2M,448K RAM运行空间安装Turbo C创建子目录Install若不是可安装盘,将文件拷贝到对应的目录
12、下TC*.*INCLUDELIB*.*SYS*.*C语言程序设计 第一章 C语言概述第19页/共533页进入Turbo CD:TCTC.exe主控菜单文件操作FILE:New Load Save Write to编辑操作EDIT:插入/修改 块 查找/替换编译链接COMPILE LINK MAKE执行RUN退出Turbo CAlt +xAlt+F ,Q帮助HelpF1Ctrl+F1 C语言程序设计 第一章 C语言概述第20页/共533页第21页/共533页基本操作:F10-调用主菜单F2-存盘F3-打开F1-帮助信息Alt+F9-CompileCtrl+F9-RunAlt+F5-UserScr
13、eenAlt+X-退出Tcv常用热键文本编辑:-移动光标PgUp,PgDn-上下翻页Ctrl+PgUp,Ctrl+PgDn-文件首尾Home行首 End行尾Ddelete Insert Bkspace块操作:Ctrl+KB-块开始标记Ctrl+KK-块结束标记Ctrl+KC-块拷贝Ctrl+KV-块移动Ctrl+KY-块删除Ctrl+KH-块隐藏程序调试:F8-StepoverF7-TraceintoF4-GotoCursorCtrl+F7-AddWatchCtrl+F8-ToggleBreakpointCtrl+F2-ProgramReset窗口操作:F5-窗口缩放F6-窗口切换 C语言程序
14、设计 第一章 C语言概述第22页/共533页课后作业预习“题解与上机指导”一书中vP181199页的节vP236页实验1教材P12:、题。注意:有关设计程序的作业,必须经过上机调试!C语言程序设计 第一章 C语言概述第23页/共533页算法的概念简单算法举例算法的特性怎样表示一个算法第2章 程序的灵魂算法 C语言程序设计 第二章 程序的灵魂算法结构化程序设计方法第24页/共533页 C语言程序设计 第二章 程序的灵魂算法程序包括的内容:v数据结构:数据的类型和组织形式v算法:操作步骤的描述NikiklausWirth提出:程序=数据结构+算法教材认为:程序=算法+数据结构+程序设计方法+语言工
15、具和环境 灵魂加工对象工具第25页/共533页 C语言程序设计 第二章 程序的灵魂算法算法的概念为解决一个问题而采取的方法和步骤,就成为算法。例如:歌曲的乐谱,建造房子等。算法核心是解决“做什么”和“怎么做”的问题。vP15页的例,求15之积。v可以有多种方法,一般采用简单和运算步骤少的。准确、高效计算机算法类别v数值运算算法v非数值运算算法第26页/共533页 C语言程序设计 第二章 程序的灵魂算法简单算法举例例v方法1:累乘v方法2:用循环结构解决,灵活、通用。例v通过循环选择打印例v判断闰年例v累加求级数的和,循环改变正负号和分母加1。例v判断素数课后认真思考,加深什么是算法的概念第27
16、页/共533页 C语言程序设计 第二章 程序的灵魂算法算法的特性有穷性在合理范围内可完成确定性无歧义性有零个或多个输入从外界得到信息有一个或多个输出问题的答案有效性每步有确定的结果第28页/共533页 C语言程序设计 第二章 程序的灵魂算法怎样表示一个算法自然语言表示v节例。易懂,文字冗长,易歧义性流程图表示v用流程图符号构成,直观,易懂N-S流程图表示伪代码表示计算机语言表示q 顺序结构q 选择结构q 循环结构 C语言程序设计 第二章 程序的灵魂算法传统流程图流向混乱、可读性差,所以应该采用结构化流程图。结构化程序设计v基本思想:任何程序都可以用三种基本结构表示,限制使用无条件转移语句(go
17、to)v结构化程序:由三种基本结构反复嵌套构成的程序v优点:结构清晰,易读,提高程序设计质量和效率三种基本结构v 顺序结构ABAB流程图N-S图 C语言程序设计 第二章 程序的灵魂算法PAB真假PBA真假v选择结构A1A2AiAnk=k2k=k1k=knk=ki.l二分支选择结构l多分支选择结构 C语言程序设计 第二章 程序的灵魂算法v循环结构l当型循环结构l直到型循环结构PA假真当P为真AAP真假A直到P为真注:A,B,A1.An可以是一个简单语句,也可以是一个基本结构 C语言程序设计 第二章 程序的灵魂算法三种基本结构的共同特点:v只有一个入口;v只有一个出口;v结构内的每一部分都有机会被
18、执行到;v结构内不存在“死循环”。C语言程序设计 第二章 程序的灵魂算法结构化程序设计方法结构化程序:用三种基本结构组成的程序基本设计思路:v复杂问题分解成几个最基本问题,再分别处理。采用的方法:v自顶向下;v逐步细化;v模块化设计:复杂问题按功能分成多个子模块v结构化编码:正确采用三种基本结构实现 C语言程序设计 第二章 程序的灵魂算法课后作业P36页习题:v、(结合实验指导读懂答案)v用N-S图表示题中v用传统流程图求解以下问题:将一个16进制数转化为10进制数 复习二进制的基本概念v“计算机文化基础”一书中P2733页第35页/共533页第3章 数据类型、运算符与表达式 C语言程序设计
19、第三章 程序的灵魂算法C的数据类型常量与变量整型数据实型数据字符型数据变量赋初值各种数值型数据间的混合运算算术运算符和算术表达式赋值运算符和赋值表达式逗号运算符和逗号表达式第36页/共533页 C语言程序设计 第三章 程序的灵魂算法C的数据类型C数据类型基本类型构造类型指针类型空类型void字符型char整型实型(浮点型)单精度型float双精度型double数组类型结构体类型共用体类型短整型short长整型long整型int枚举类型enum数据类型决定:1.数据占内存字节数2.数据取值范围3.可以进行的操作第37页/共533页 C语言程序设计 第三章 程序的灵魂算法常量和符号常量v定义:程序
20、运行过程中,其值不能被改变的量(常数)v分类:直接常量、符号常量3.2常量与变量第38页/共533页 C语言程序设计 第三章 程序的灵魂算法l符号常量:用标识符代表常量u一般用大写字母:PRICE、PIu定义格式:#define 符号常量 常量u其值在作用域内不能改变和再赋值。例3.1符号常量举例#definePRICE30#includevoidmain()intnum,total;num=10;total=num*PRICE;printf(total=%dn,total);total=300运行结果:符号常量的优点是:见名知意、一改全改第39页/共533页 C语言程序设计 第三章 程序的灵
21、魂算法变量v 定义:其值可以改变的量。v 定义格式:数据类型 变量名;v 变量应该有名字,并在内存中占据一定的存储单元。v 变量名和变量值有不同的含义l变量名实为一个符号地址 a3例变量的使用main()inta;a=3;printf(“a=%d,a);变量名变量值存储单元第40页/共533页 C语言程序设计 第三章 程序的灵魂算法标识符v定义:标识变量名、符号常量名、函数名、数组名、文件名的字符串序列名字。v命名规则:l只能由字母、数字、下划线组成,且第一个字符必须是字母或下划线l大小写字母含义不同,一般用小写l不能使用关键字lTC允许最长32个字符,建议长度不超过8个字符v使用:先定义、后
22、使用标识符应该“见名知意”,如 total,max标识符应该“不宜混淆”,如 l与1,O与0这些标识符合法吗?1A、¥123、#33、Tatol、int、max第41页/共533页 C语言程序设计 第三章 程序的灵魂算法整型数据整型常量(整常数)的三种表示方法v十进制整数:由数字09和正负号表示.如 123,-456,0v八进制整数:由数字0开头,后跟数字07表示.如 0123,011v十六进制整数:由0 x开头,后跟09,af,AF表示.如 0 x123,0 xff第42页/共533页 C语言程序设计 第三章 程序的灵魂算法补充知识:字节和位v内存以字节为单元组成v每个字节有一个地址v一个字
23、节一般由8个二进制位组成v每个二进位的值是0或101234567012345678910.7643251第43页/共533页 C语言程序设计 第三章 程序的灵魂算法数值的表示方法原码、反码和补码v原码:最高位为符号位,其余各位为数值本身的绝对值v反码:l正数:反码与原码相同l负数:符号位为1,其余位对原码取反v补码:l正数:原码、反码、补码相同l负数:最高位为1,其余位为原码取反,再对整个数加13126912457810119-5=49+7=16=(14)12第44页/共533页 C语言程序设计 第三章 程序的灵魂算法原码反码补码+7000001110000011100000111-71000
24、01111111100011111001+0000000000000000000000000-0100000001111111100000000数的范围0111111111111111(-127+127)0111111110000000(-127+127)0111111110000000(-128+127)(用一字节表示数)v负数补码转换成十进制数:最高位不动,其余位取反加1例补码:11111001取反:10000110加1:10000111=-7第45页/共533页 C语言程序设计 第三章 程序的灵魂算法整型变量v整型数据在内存中的存放形式l数据在内存中以二进制补码形式存放l每一个整型变量在
25、内存中占2个字节10的原码反码补码-10的原码取绝对值反码补码0000000000001010000000000000101000000000000010101000000000001010000000000000101011111111111101011111111111110110整数的最左二进制位是符号位,0正、1负 C语言程序设计 第三章 程序的灵魂算法v整型变量的分类l三类整型变量有符号无符号基本型(简称整型)intunsignedint短整型short或shortintunsignedshort长整型long或longintunsignedlongl整数类型和取值范围TURBOC所
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 语言程序设计 谭浩强 完整
限制150内