版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
C语言程序设计教学安排本学期共18周(3.8-7.12),其中考试考核2周,节假日按照国家法定假日执行。总学时:64学时平时成绩:50分平时成绩=考勤+上机+作业(写上课编写的程序)上机:课本+作业本期末考试/课程设计:50分成绩计算C语言的功能?编写系统软件。编写应用软件。数据计算。信息处理。图形处理。兴趣是最好的老师!学好C语言,成为C高手,可以让你今后衣食无忧,能够无忧无虑地生活。C语言发展历史C语言特点C程序格式和结构特点C程序上机步骤第一章C语言概述与程序逻辑
程序设计语言的发展机器语言汇编语言高级语言面向过程面向对象CPU指令系统,由0、1序列构成的指令码组成如:10000000加
10010000减用助记符号描述的指令系统如ADDA,B面向机器的语言程序设计是数据被加工的过程客观世界可以分类,对象是类的实例对象是数据和方法的封装对象间通过发送和接受消息发生联系程序设计关键是定义类,并由类派生对象冯.诺依曼结构:计算机运算器控制器存储器主机:I/O设备:键盘、显示器等中央处理器CPU>>1.1C语言发展历史5254565860626466687072747678808284868890929496AdaALGOL60ALGOL68PascalModula-2CPLBCPLBCC++JavaLISPPROLOGCOBOLFORTRAN77FORTRANPL/1Simula67Smalltalk80BASICANSI-BASICQBASICVBFORTRAN90<>产生背景产生过程时间:1972~1973地点:美国贝尔实验室目的:UNIX操作系统设计人:Ken.Thompson(肯·汤普森)和Dennis.M.Ritchie(丹尼斯.里奇)C标准标准C:K&R合著《TheCProgrammingLanguage》ANSIC:1983年87ANSIC:1987年1990年国际标准的ANSIC<>C语言发展过程C语言的设计者
Ken.Thompson(肯·汤普森)和Dennis.M.Ritchie(丹尼斯.里奇)接受美国国家技术勋章(右为当时的美国总统克林顿)Ritchie和Thompson用C语言在开发UNIX操作系统语言简洁、紧凑、灵活运算符和数据类型丰富程序设计结构化、模块化生成目标代码质量高可移植性好<>>>>>>中级语言>1.2C语言特点(由系统定义,不能重作其它定义)autobreakcasecharconstcontinuedefaultdodoubleelseenumexternfloatforgotoifintlongregisterreturnshortsignedsizeofstaticstructswitchtypedefunsignedunionvoidvolatilewhile<32个关键字if()~else~for()~while()~do~while()continuebreakswitchgotoreturn<9种控制语句算术运算符:+-*/%++--关系运算符:<<===>>=!=逻辑运算符:!&&||位运算符:<<>>~|^&赋值运算符:=及其扩展条件运算符:?:逗号运算符:,指针运算符:*&求字节数:sizeof强制类型转换:(类型)分量运算符:.->下标运算符:[]其它:()-<34种运算符:基本类型构造类型指针类型空类型void定义类型typedef数值类型字符类型char枚举类型enum整型浮点型单精度型float双精度型double短整型short长整型long整型int数组结构体struct共用体union<
C数据类型:三种基本结构的图示:
顺序结构选择结构循环结构的图示:
当型(While型)循环结构
直到型(Until型)循环
实例1.1:第一个程序Hello,World!/*example1.1ThefirstCProgram*/#include<stdio.h>main(){
printf(“Hello,World!”);}>注释编译预处理函数语句输出:Hello,World!1.3C程序格式和结构特点/*example1.2calculatethesumofaandb*/#include<stdio.h>/*Thisisthemainprogram*/main(){
int
a,b,sum;
a=10;
b=24;
sum=add(a,b);
printf(”sum=%d\n",sum);}/*Thisfunctioncalculatesthesumofxandy*/int
add(int
x,int
y){
int
z;
z=x+y;return(z);}运行结果:sum=34函数语句预处理命令注释>实例1.2习惯用小写字母,大小写敏感不使用行号,无程序行概念可使用空行和空格常用锯齿形书写格式<>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程序开发步骤<>file.exe程序代码的录入,生成源程序*.c语法分析查错,翻译生成目标程序*.obj与其它目标程序或库链接装配,生成可执行程序*.exe1.4C程序的上机步骤一个程序应包括两个方面的内容:对数据的描述:数据结构(datastructure)对操作的描述:算法(algorithm)著名计算机科学家沃思提出一个公式:
数据结构+算法=程序
数据结构+算法+程序设计方法+语言工具完整的程序设计应该是:1.5
算法和程序一、算法的概念
为了有效地进行解题,不仅需要保证算法正确,还要考虑算法的质量,选择合适的算法。希望方法简单,运算步骤少。计算机算法可分为两大类别:数值运算算法:求数值解,例如求方程的根、求函数的定积分等。非数值运算:包括的面十分广泛,最常见的是用于事务管理领域,例如图书检索、人事管理、行车调度管理等。二、算法的特性有穷性:包含有限的操作步骤。确定性:算法中的每一个步骤都应当是确定的。有零个或多个输入:输入是指在执行算法时需要从外界取得必要的信息。有一个或多个输出:算法的目的是为了求解,“解”就是输出。有效性:算法中的每一个步骤都应当能有效地执行,并得到确定的结果。三、算法的表示可以用不同的方法表示算法,常用的有:自然语言传统流程图结构化流程图
1、
用自然语言表示算法自然语言就是人们日常使用的语言,可以是汉语或英语或其它语言。用自然语言表示通俗易懂,但文字冗长,容易出现“歧义性”。自然语言表示的含义往往不大严格,要根据上下文才能判断其正确含义,描述包含分支和循环的算法时也不很方便。因此,除了那些很简单的问题外,一般不用自然语言描述算法。
2、用流程图表示算法美国国家标准化协会ANSI(AmericanNationalStandardInstitute)规定了一些常用的流程图符号:起止框判断框处理框输入/输出框注释框流向线连接点
3、用N-S流程图表示算法
1973年美国学者I.Nassi和B.Shneiderman提出了一种新的流程图形式。在这种流程图中,完全去掉了带箭头的流程线。全部算法写在一个矩形框内,在该框内还可以包含其它的从属于它的框,或者说,由一些基本的框组成一个大的框。这种流程图又称N--S结构化流程图。
N-S流程图用以下的流程图符号:(1)顺序结构
(2)选择结构
(3)循环结构
判定2000~2500年中的每一年是否闰年,将结果输出。
分析:闰年的条件是:(1)能被4整除,但不能被100整除的年份都是闰年,如1996,2004年是闰年;(2)能被100整除,又能被400整除的年份是闰年。如1600,2000年是闰年。不符合这两个条件的年份不是闰年。
设y为被检测的年份,算法可表示如下
:S1:2000→yS2:若y不能被4整除,则输出y“不是闰年”。然后转到S6。S3:若y能被4整除,不能被100整除,则输出y“是闰年”。然后转到S6。S4:若y能被100整除,又能被400整除,输出y“是闰年”,否则输出“不是闰年”。然后转到S6。S5:输出y“不是闰年”。S6:y+1→yS7:当y≤2500时,转S2继续执行,如y>2500,算法停止。
判定闰年的算法用自然语言表示
判定闰年的算法用流程图表示
用流程图表示算法要比用文字描述算法逻辑清晰、易于理解。判定闰年的算法用N-S图表示自顶向下,模块化,逐步细化方法考虑周全,结构清晰,层次分明,作者容易写,读者容易看。如果发现某一部分中有一段内容不妥,需要修改,只需找出该部分修改有关段落即可,与其它部分无关。我们提倡用这种方法设计程序。这就是用工程的方法设计程序。
四、程序设计方法:模块设计的方法:模块化设计的思想实际上是一种“分而治之”的思想,把一个大任务分为若干个子任务,每一个子任务就相对简单了。在拿到一个程序模块以后,根据程序模块的功能将它划分为若干个子模块,如果这些子模块的规模还嫌大,还再可以划分为更小的模块。这个过程采用自顶向下方法来实现。子模块一般不超过50行。划分子模块时应注意模块的独立性,即:使一个模块完成一项功能,耦合性愈少愈好。
(1)C程序总是从main函数开始执行的,与main函数的位置无关。(2)C程序书写格式自由,一行内可以写几个语句,一个语句可以分写在多行上,C程序
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年地质工程师考试《工程地质学基础》备考题库及答案解析
- 2025年厨师资格考试《刀工技术》备考题库及答案解析
- 软件开发合同协议2025年
- 汽车租赁保险补偿协议2025
- 民宿预订协议2025
- 2025年新员工入职培训体系考试试题及答案
- 2025年企业年终奖发放政策与税务筹划考试试题及答案
- 建筑兼职施工合同协议2025年
- 嘉兴塔吊出租合同范本
- 商业招商租赁合同范本
- 2025年配电安规知识考试题附答案
- 企业行政管理制度模板库
- 2025年党员干部在委理论学习中心组“改文风转作风”专题研讨会上的交流发言范文
- 安全生产第四季度工作计划
- 湖北中烟2025年招聘综合测试h
- 巴厘岛旅游攻略
- 机关单位档案数字化管理办法
- 支委会会议记录1一12月
- 2025年河北省政府采购评审专家考试真题含答案
- 新教科版小学1-6年级科学需做实验目录
- 医院第九届职工代表大会换届选举实施方案
评论
0/150
提交评论