cha2算法程序的灵魂
- 格式:ppt
- 大小:2.44 MB
- 文档页数:37
《C语言程序设计》教学大纲课程编号: 030214024课程名称: C语言程序设计课程类型: 专业必修课总学时: 72 讲课学时: 52 实验学时:20学分: 4适用对象: 计算机应用专业一、课程性质、目的和任务C语言是在国际上广泛流行的、很有发展前途的计算机高级语言,C语言功能丰富,表达能力强,使用灵活方便,应用面广,目标程序效率高,可移植性好,既具有高级语言的优点,又有低级语言的许多优点,是计算机应用专业学生的一门必修课程。
本课程主要介绍面向过程程序设计的方法和C语言的基本概念。
学习者在学习过程逐步掌握C语言的面向过程程序设计的功能,从而掌握面向过程程序设计的基本知识和基本技能。
为后续的课程的学习奠定坚实的程序设计基础。
二、课程教学基本要求通过本课程的教学,要培养学生达到以下目标:本课程的教学目标是:通过理论和实践教学,使学生较好地掌握 C语言各方面的知识,掌握基本的程序设计过程和技巧,具备初步的高级语言程序设计能力,并能熟练应用 TURBO C集成环境进行C语言的编写、编译与调试,达到省二级考试要求的能应用C语言解决一般编程问题的水平。
学生通过本课程的学习,将进一步领会现代程序设计的特点和应用,为进一步学习后续的计算机相关课程打下基础。
三、基本内容与课时分配四、课程教学内容及要求第一章C语言概述【教学目标】了解C语言的发展、特点,了解简单的C程序;【教学内容】1、C语言的发展、特点、简单C程序的介绍;2、一般的上机步骤;【课时安排】 2课时【重点】C程序介绍及C程序上机过程;【难点】C语言程序的编译、连接与执行;第二章程序的灵魂—算法【教学目标】使学生能最终用C语言表示一个算法;【教学内容】1、算法的概念;2、简单算法举例;3、算法的特性;4、怎样表示一个算法;5、结构化程序设计方法;【课时安排】 2课时【重点】怎样一步一步的最终用C语言表示一个算法;【难点】几种算法的表示方法第三章数据类型、运算符和表达式【教学目标】使学生掌握各种基本数据类型,掌握好算术表达式、赋值表达式和逗号表达式的用法;【教学内容】1、C的数据结构类型;2、常量与变量;3、算术运算符与算术表达式;4、赋值表达式与逗号表达式;【课时安排】 4课时【重点】各种数据类型的特点及比较;各种表达式的用法;自增自减运算;【难点】自增自减运算;【实验要求】通过上机实践,加深对所学知识的理解;(2课时)第四章顺序程序设计【教学目标】使学生掌握最简单的程序设计;【教学内容】1、C语句概述;2、赋值语句;3、字符数据的输入输出;4、格式输入与输出;5、顺序结构程序设计举例;【课时安排】4课时【重点】赋值语句;字符的输入输出和格式输入输出;【难点】格式输入输出;【实验要求】赋值语句的使用方法;各种类型数据的输入输出的方法;各种格式转换符的使用;(2课时)第五章选择结构程序设计【教学目标】掌握各种表达式的用法;掌握IF语句,SWITCH语句;【教学内容】1、关系运算符和和关系表达式;2、逻辑运算符和逻辑表达式;3、IF 语句;4、SWITCH语句;【课时安排】4课时【重点】IF 语句;SWITCH语句;【难点】IF语句的嵌套;【实验要求】;熟悉掌握IF语句和SWITCH语句;结合程序掌握一些简单的算法;(2课时)第六章循环控制【教学目标】【教学内容】1、GOTO语句;2、WHILE语句;3、DO-WHILE 语句;4、FOR语句;5、循环的嵌套;6、BREAK语句和CONTINUE语句【课时安排】4课时【重点】WHILE 语句、FOR语句,循环的嵌套;【难点】循环的嵌套;【实验要求】掌握用WHILE语句、FOR语句和DO-WHILE语句实现循环的方法;用循环的方法实现一些常用算法(穷举、迭代、递推);(2课时)第七章数组【教学目标】掌握一维数组、二维数组和字符数组的定义、引用和初始化及其应用【教学内容】1、一维数组的定义和引用;2、二维数组的定义和引用;3、字符数组;【课时安排】4课时【重点】一维数组、二维数组和字符数组的定义、引用、输入输出和初始化及其应用;【难点】数组的应用;【实验要求】一维数组、二维数组和字符数组的定义、引用、输入输出和初始化的方法;掌握与数组有关的算法;(2课时)第八章函数【教学目标】学生掌握模块化程序设计的方法;【教学内容】1、函数定义的一般形式;2、函数参数和函数的值;3、函数的调用;4、函数的嵌套调用;5、函数的递归调用;6、局部变量和全局变量;7、变量的存储类别;8、内部函数和外部函数;【课时安排】6课时【重点】函数参数和函数的值;函数的调用;局部变量和全局变量;变量的存储类别;【难点】函数参数和函数的值;局部变量和全局变量;【实验要求】掌握普通函数、递归函数的写法;第九章预处理命令【教学目标】掌握宏定义的方法;掌握文件包含的方法;掌握条件编译的方法;【教学内容】1、宏定义;2、“文件包含”处理;3、条件编译;【课时安排】2课时【重点】宏定义;“文件包含”处理;【难点】宏定义;【实验要求】能够正确定义和使用宏。
2 程序的灵魂—算法 (1)2.1 算法的概念 (1)2.2 简单算法举例 (1)2.3 算法的特性 (4)2.4 怎样表示一个算法 (4)2.4.1 用自然语言表示算法 (4)2.4.2 用流程图表示算法 (4)2.4.3 三种基本结构和改进的流程图 (6)2.4.4 用N-S流程图表示算法 (6)2.4.5 用伪代码表示算法 (7)2.4.6 用计算机语言表示算法 (7)2.5 结构化程序设计方法 (8)2程序的灵魂—算法一个程序应包括:●对数据的描述。
在程序中要指定数据的类型和数据的组织形式,即数据结构(datastructure)。
●对操作的描述。
即操作步骤,也就是算法(algorithm)。
Nikiklaus Wirth提出的公式:数据结构+算法=程序教材认为:程序=算法+数据结构+程序设计方法+语言工具和环境这4个方面是一个程序涉及人员所应具备的知识。
本课程的目的是使同学知道怎样编写一个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;否则,算法结束。
如果计算100!只需将S5:若i≤5改成i≤100即可。