收藏 分享(赏)

chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt

上传人:无敌 文档编号:1110858 上传时间:2018-06-12 格式:PPT 页数:36 大小:243.02KB
下载 相关 举报
chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt_第1页
第1页 / 共36页
chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt_第2页
第2页 / 共36页
chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt_第3页
第3页 / 共36页
chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt_第4页
第4页 / 共36页
chap1-引言---浙江大学计算机辅助设计与图形学国家重点实-….ppt_第5页
第5页 / 共36页
点击查看更多>>
资源描述

1、C语言程序设计基础与试验,刘新国、2012年秋,1,C语言程序设计基础与试验,教学要求掌握程序设计语言的基本知识常用算法初步的程序设计能力学习方法自主学习重视上机实践,2,如何尽快学会用C语言进行程序设计,了解程序设计语言(C语言)模仿、改写、编写通过不断的编程实践,逐步领会和掌握程序设计的基本思想和方法。,3,教材和参考书,C语言程序设计,何钦铭、颜晖主编,高等教育出版社,2008C语言编程(第3版),美Stephen, G.Kochan,张小潘译,电子工业出版社,2006C语言教程(第4版),美Al Kelley, Ira Pohl,徐波译,机械工业出版社,2007标准C语言基础教程(第4

2、版),美Gary J. Bronson,单先余等译,电子工业出版社,2006C程序设计语言,美Brian W. Kernighan, Dennis M. Ritchie,徐宝文等译,机械工业出版社,2006,4,Chap 1 引 言,一个C语言程序程序与程序设计语言C语言的发展历史与特点实现问题求解的过程,5,1.1 一个C语言程序,例1-1求阶乘问题。输入一个正整数n,输出n!。 #include /* 编译预处理命令 */int main(void) /* 主函数 */int n; /* 变量定义 */int factorial(int n); /* 函数声明 */scanf(%d, ,6

3、,1.2 程序与程序设计语言,程序人们为解决某种问题用计算机可以识别的代码编排的一系列加工步骤。程序的执行过程实际上是对程序所表达的数据进行处理的过程。程序设计语言提供了一种表达数据与处理数据的功能要求程序员按照语言的规范编程,7,1.2 程序与程序设计语言,程序与指令程序设计语言的功能程序设计语言的语法程序的编译与编程环境,8,程序与指令,指令:计算机的一个最基本的功能如实现一次加法运算或实现一次大小的判别计算机的指令系统:计算机所能实现的指令的集合 程序:一系列计算机指令的有序组合,9,程序与指令,例1-2 编写程序,分别求和与乘积虚拟的计算机指令系统(7条指令 )指令1:Input X

4、将当前输入数据存储到内存的X单元指令2:Output X 将内存X单元的数据输出。指令3:Add X Y Z 将内存X单元的数据与Y单元的数据相加并将结果存储到Z单元。指令4:Sub X Y Z 将内存X单元的数据与Y单元的数据相减并将结果存储到Z单元。指令5:BranchEq X Y P 比较X与Y,若相等则程序跳转到P处执行,否则继续执行下一条指令。指令6:Jump P 程序跳转到P处执行。指令7:Set X Y 将内存Y单元的值设为X。,10,程序与指令,输入3个数A, B和C,求A+B+C的结果Input A; 输入第1个数据到存储单元A中Input B; 输入第2个数据到存储单元B中

5、Input C; 输入第3个数据到存储单元C中Add A B D; 将A、B相加并将结果存在D中Add C D D; 将C、D相加并将结果存在D中Output D; 输出D的内容,11,程序与指令,输入2个数A和B,求A*B的结果1Input A; 输入第1个数据到存储单元A中2Input B; 输入第2个数据到存储单元B中3Set 0 X; 将X设为0,此处X用以统计A累加的次数4Set 0 Z; 将Z设为0,此处Z用以存放A*B的结果5BranchEq X B 9; 判别X与B是否相等;若相等说明A 已累加了B次,程序跳转到第9条指令,输出结果6Add Z A Z; Z = Z + A7A

6、dd 1 X X; X = X + 18Jump 5; 程序跳转到第5条指令,继续循环执行第6条、7条指令9Output Z; 输出Z的值,该值等于A*B,12,程序设计语言的功能,数据表达:表达所要处理的数据流程控制:表达数据处理的流程,13,数据表达,数据表达:一般将数据抽象为若干类型数据类型:对某些具有共同特点的数据集合的总称代表的数据(数据类型的定义域)在这些数据上做些什么(即操作或称运算)例如:整数类型包含的数据:,-2,-1,0,1,2, 作用在整数上的运算:+ 、 - 、 * 、 /等,14,Number, Data,数据表达,C语言提供的数据类型基本数据类型:程序设计语言事先定

7、义好,供程序员直接使用,如整型、实型(浮点型)、字符型等。构造类型:由程序员构造,如数组、结构、文件、指针等。各种数据类型的常量与变量形式常量(常数)与变量,15,流程控制,结构化程序设计方法将复杂程序划分为若干个相互独立的模块模块:一条语句(Statement)、一段程序或一个函数(子程序)等单入口、单出口,16,流程控制,任何程序都可以将模块通过3种基本的控制结构进行组合来实现,顺序结构,循环结构,分支结构,17,流程控制,语句级控制:3种基本的控制结构顺序控制结构:自然顺序执行分支控制结构(选择结构):根据不同的条件来选择所要执行的模块循环控制结构:重复执行某个模块 单位级控制:函数的定

8、义与调用处理复杂问题时, 将程序分为若干个相对独立的子程序(函数),18,程序设计语言的语法,用程序设计语言所写的程序必须符合相应语言的语法 源程序(源代码)是一个字符序列,这些字符序列按顺序组成了一系列“单词”,“单词”的组合就形成了语言有意义的语法单位,一些简单语法单位的组合又形成了更复杂的语法单位,最后一系列语法单位组合成程序。,19,程序设计语言的语法,C语言的主要“单词”(1)标识符: C语言的标识符规定由字母、数字以及下划线组成,且第一个字符必须是字母或下划线。(2)保留字(关键字): 它们是C语言规定的、赋予它们以特定含义、有专门用途的标识符。(3)自定义标识符: 包括在程序中定

9、义的变量名、数据类型名、函数名以及符号常量名。有意义的英文单词(4)常量: 常量是有数据类型的,如,123、12.34(5)运算符。代表对各种数据类型实际数据对象的运算。如,+(加)、-(减)、*(乘)、/(除)、%(求余)、(大于),20,程序设计语言的语法,C语言的主要语法单位(1)表达式: 运算符与运算对象组合就形成了表达试。如,2 + 3 * 4(2)变量定义: 变量也有数据类型,所以在定义变量时要说明相应变量的类型。如: int i;(3)语句: 语句是程序最基本的执行单位,程序的功能就是通过对一系列语句的执行来实现的。(4)函数定义与调用,21,程序设计语言的语法,语句:表达式语句

10、:表达式加分号“;” 分支语句:实现分支控制过程 if (a b) x = a;else x = b;循环语句:实现循环控制的过程 sum = 0; /* 初始化sum和i */i = 1; while (i = 100) /* while循环语句 */ sum = sum + i; i = i + 1;复合语句:用一对“ ”,将若干语句顺序组合在一起就形成了一个程序段。,22,程序设计语言的语法,函数定义与调用: 函数是完成特定任务的独立模块,函数的使用最主要涉及到函数的定义与调用。输入输出:C语言没有输入输出语句,用库函数 printf、scanf等实现。,23,程序的编译与编程环境,程序

11、的编译 编译器 程序 计算机直接能理解的指令序列编译器:对源程序进行词法分析、语法与语义分析,生成可执行的代码。直接指出程序中的语法错误 编程环境包括编辑程序(Edit)、编译(Compile)、调试(Debug)等过程。掌握程序设计语言:根据语言的语法,用语言表达数据、实现程序的控制,并会使用编程环境。,24,C 语言上机过程,源程序 test.cpp test.obj 可执行代码 test.exe,编译,连接,运行,25,1.3 C语言的发展历史与特点,历史 1972年:贝尔实验室的Dennis Ritchie在B语言的基础上设计并实现了C语言。1978年:B.W.Kernighan和D.

12、Ritchie(简称K & R)合著的The C Programming Language是各种C语言版本的基础,称之为旧标准C语言。1983年:美国国家标准化协会(ANSI)制定了新的C语言标准,称ANSI C。,26,C语言的特点,1C语言是一种结构化语言2C语言语句简洁、紧凑,使用方便、灵活32个关键字,9种控制语句,程序书写形式自由。3C语言程序易于移植C语言将与硬件有关的因素从语言主体中分离出来,通过库函数或其他实用程序实现它们。 4C语言有强大的处理能力5生成的目标代码质量高,运行效率高,27,C语言的特点,6数据类型检查不严格,表达式出现二义性,不具备数据越界自动检查功能,运算符

13、的优先级与结合性对初学者难于掌握。C 语言中大小写字母代表不同含义,28,1.4 实现问题求解的过程,问题:求1100间所有偶数的和。1问题分析与算法设计 求在一定范围内(1100)、满足一定条件(偶数)的若干整数的和,求累加和。 思路:设置一个变量(sum),其初值为0,然后在1100的数中(i)寻找偶数,将它们一个一个累加到sum中。一步累加:sum = sum + i; 重复累加,用循环语句实现,在循环过程中:(1) 判别 i 是不是偶数:用分支控制语句来实现。(2) 对循环次数进行控制:通过 i 值的变化,29,问题分析与算法设计,思路 确定算法算法:一组明确的解决问题的步骤,它产生结

14、果并可在有限的时间内终止。算法的描述:自然语言伪代码流程图:算法的图形表示法,30,31,实现问题求解的过程,2编辑程序生成程序的源文件,C语言源文件的后缀为 .c / .cpp#include int main(void)int i, sum = 0; for(i = 1; i = 100; i+) if (i%2 = 0) sum = sum + i; printf(%d, sum); return 0;,32,实现问题求解的过程,3程序编译连接编辑程序后,用该语言的编译程序对其进行编译,以生成二进制代码表示的目标程序(.obj),与编程环境提供的库函数进行连接(Link)形成可执行的程序

15、(.exe)。编译程序指出语法错误 语法错误VS逻辑错误,33,实现问题求解的过程,4运行与调试经过编辑、编译、连接,生成执行文件后,就可以在编程环境或操作系统环境中运行该程序。如果程序运行所产生的结果不是你想要的结果,这是程序的语义错误(逻辑错误)。调试:在程序中查找错误并修改错误的过程。调试的方法设置断点单步跟踪调试是一个需要耐心和经验的工作,也是程序设计最基本的技能之一。,34,C语言程序的调试、运行步骤,35,本章要点,什么是程序?程序设计语言包含哪些功能?程序设计语言在语法上包含哪些内容?结构化程序设计有哪些基本的控制结构?C语言有哪些特点?C语言程序的基本框架如何?形成一个可运行的C语言程序主要步骤?如何用流程图描述简单的算法?,36,

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

当前位置:首页 > 高等教育 > 大学课件

本站链接:文库   一言   我酷   合作


客服QQ:2549714901微博号:道客多多官方知乎号:道客多多

经营许可证编号: 粤ICP备2021046453号世界地图

道客多多©版权所有2020-2025营业执照举报