c语言设计总结_第1页
c语言设计总结_第2页
c语言设计总结_第3页
c语言设计总结_第4页
c语言设计总结_第5页
已阅读5页,还剩29页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、C语言程序设计语言程序设计C Language ProgrammingC语言程序设计课程概况语言程序设计课程概况英文名:英文名: C Language Programming 开课单位:计算机学院计算机基础课部开课单位:计算机学院计算机基础课部课程编码:课程编码:103001学时:学时:64学时,其中授课学时,其中授课40学时,上机学时,上机+机考机考24学时。学时。学分:学分:4学分学分授课对象:管理学院授课对象:管理学院05信管、信管、05电商班电商班教材:教材:C及及C+程序设计程序设计 钮焱、许新民主编钮焱、许新民主编 科学出版社科学出版社实验指导书:实验指导书:C及及C+程序设计实验

2、教程程序设计实验教程 徐振平、李振立主编徐振平、李振立主编 科学出版社科学出版社 教学参考书:教学参考书:C程序设计程序设计谭浩强主编谭浩强主编 清华大学出版社清华大学出版社课程的重点与难点课程的重点与难点1、数据类型、数据的存储,数据的输入输出格式。先掌握常用、数据类型、数据的存储,数据的输入输出格式。先掌握常用数据类型;数据类型;2、常量、符号常量、变量的表示与定义;运算符及表达式,包、常量、符号常量、变量的表示与定义;运算符及表达式,包括算术运算、赋值运算、关系运算、逻辑运算、逗号运算、括算术运算、赋值运算、关系运算、逻辑运算、逗号运算、强制类型运算、条件,求字节运算、位运算等运算符的运

3、算强制类型运算、条件,求字节运算、位运算等运算符的运算级别、结合原则。级别、结合原则。3、程序的三种基本结构:顺序结构、分支选择结构、循环结构;、程序的三种基本结构:顺序结构、分支选择结构、循环结构;算法分析和编程方法;算法分析和编程方法;4、函数定义、函数调用、函数声明、参数传递,值传送与地址、函数定义、函数调用、函数声明、参数传递,值传送与地址传送,函数的嵌套调用与递归调用,局部变量与全局变量,传送,函数的嵌套调用与递归调用,局部变量与全局变量,变量的存储类别与作用域等。变量的存储类别与作用域等。5、一维数组、二维数组、字符数组与字符串,数组作为函数的、一维数组、二维数组、字符数组与字符串

4、,数组作为函数的参数,数组与指针。参数,数组与指针。课程的重点与难点课程的重点与难点6、指针与地址,变量的指针和指向变量的指针变量,数组的指、指针与地址,变量的指针和指向变量的指针变量,数组的指针与指向数组的指针变量,字符串的指针与指向字符串的指针与指向数组的指针变量,字符串的指针与指向字符串的指针变量,指针与函数,指针数组,指针的指针。针变量,指针与函数,指针数组,指针的指针。7、 结构体与共用体类型的说明、结构体和共用体变量的定义结构体与共用体类型的说明、结构体和共用体变量的定义及初始化方法,类型定义及初始化方法,类型定义typedef的作用;结构体与共用体的作用;结构体与共用体变量成员的

5、引用方法;数组、结构体、共用体等构造类型数变量成员的引用方法;数组、结构体、共用体等构造类型数据的使用方法;存储动态分配和释放;链表的基本概念和基据的使用方法;存储动态分配和释放;链表的基本概念和基本操作。本操作。8、文件类型指针,文件的打开与关闭,文件的读写,文件的基、文件类型指针,文件的打开与关闭,文件的读写,文件的基本处理函数。本处理函数。第一章第一章 程序设计概论程序设计概论本章主要介绍程序设计基本技术及本章主要介绍程序设计基本技术及C语言语言一、一、 程序设计语言程序设计语言二、二、 程序设计的基本过程程序设计的基本过程三、三、 算法及算法描述算法及算法描述四、四、 结构化程序设计结

6、构化程序设计五、五、 数制与编码数制与编码六、六、 C语言的起源及其特点语言的起源及其特点七、七、 C语言程序的基本构架及执行过程语言程序的基本构架及执行过程八、八、 C语言的基本字符集和保留字(关键字)语言的基本字符集和保留字(关键字)九、九、 C语言的上机环境简介语言的上机环境简介一、一、 程序设计语言程序设计语言1、程序:指处理事情的先后次序。在计算机语言中,程序定义、程序:指处理事情的先后次序。在计算机语言中,程序定义为完成特定任务的计算机指令的集合。为完成特定任务的计算机指令的集合。2、程序类型:、程序类型:原程序:用户编写的程序称为源程序。原程序:用户编写的程序称为源程序。目标程序

7、:源程序通过翻译形成目标程序(目标程序:源程序通过翻译形成目标程序(.OBJ文件)。文件)。运行程序:将目标程序与函数库连接后,形成运行程序(运行程序:将目标程序与函数库连接后,形成运行程序(.EXE文件)。文件)。程序设计:指用户通过编写源程序,翻译源程序为目标程序,程序设计:指用户通过编写源程序,翻译源程序为目标程序,连接目标程序与函数库,形成运行程序并整理设计文档的全连接目标程序与函数库,形成运行程序并整理设计文档的全过程。过程。计算机指令:是指挥计算机完成某一操作的命令,它由操作码计算机指令:是指挥计算机完成某一操作的命令,它由操作码和操作数组成。计算机指令的执行过程可分为和操作数组成

8、。计算机指令的执行过程可分为4个基本操作:个基本操作:取指令、分析指令、执行指令、停止操作。取指令、分析指令、执行指令、停止操作。一、一、 程序设计语言程序设计语言3、程序设计语言:是计算机能够接受,能够理解的全部指令的、程序设计语言:是计算机能够接受,能够理解的全部指令的集合。分为机器语言、汇编语言、高级语言、专用语言(指集合。分为机器语言、汇编语言、高级语言、专用语言(指非过程化的高级语言)和面向对象程序设计语言等几类。非过程化的高级语言)和面向对象程序设计语言等几类。 机器语言机器语言:是机器指令的集合,用机器语言编写的程序计算机能是机器指令的集合,用机器语言编写的程序计算机能够直接执行

9、,执行速度快,效率高。它的缺点是可读性差,够直接执行,执行速度快,效率高。它的缺点是可读性差,难于编程,容易出错,程序的检查和调试都很困难。机器指难于编程,容易出错,程序的检查和调试都很困难。机器指令的操作码和操作数都是由令的操作码和操作数都是由 “0”、“1”二进制代码组成的二进制代码组成的序列。序列。 汇编语言:是一种用助记符表示的程序设计语言。用户编写汇汇编语言:是一种用助记符表示的程序设计语言。用户编写汇编语言源程序,由汇编程序对源程序进行汇编,翻译成目标编语言源程序,由汇编程序对源程序进行汇编,翻译成目标程序。程序。机器语言和汇编语言都属于低级语言,都是面向机器的语言。机器语言和汇编

10、语言都属于低级语言,都是面向机器的语言。高级语言高级语言:是接近于自然语言或数学语言的程序设计语言。它彻是接近于自然语言或数学语言的程序设计语言。它彻底摆脱了依赖于机器硬件的指令系统,使用自然语言中的英底摆脱了依赖于机器硬件的指令系统,使用自然语言中的英语单词和数字符号编写程序,它有专门的词汇规则、语法规语单词和数字符号编写程序,它有专门的词汇规则、语法规则,是面向应用的计算机语言。则,是面向应用的计算机语言。二、程序设计过程二、程序设计过程1、确定问题要求、确定问题要求2、建立数学模型、建立数学模型3、算法设计、算法设计4、编写源程序、编写源程序5、编译调试程序、编译调试程序6、运行程序、运

11、行程序7、分析输出结果、分析输出结果8、整理文档、整理文档三、算法及算法描述三、算法及算法描述1、算法:是为解决某一特定问题而进行一步一步操作过程的精、算法:是为解决某一特定问题而进行一步一步操作过程的精确描述,是有限步、可执行、有确定结果的操作序列。确描述,是有限步、可执行、有确定结果的操作序列。2、算法的特征:、算法的特征:(1)有穷性:每一个算法分成有限个操作步骤,每一步在有限)有穷性:每一个算法分成有限个操作步骤,每一步在有限的时间内完成。的时间内完成。(2)确定性:算法的每一步都有明确的含义,不含歧义,每一)确定性:算法的每一步都有明确的含义,不含歧义,每一步命令只能产生唯一的一组动

12、作。步命令只能产生唯一的一组动作。(3)有效性:算法的每一步都能有效地执行,并输出确定的结)有效性:算法的每一步都能有效地执行,并输出确定的结果。只要有一个不可执行的操作,该算法无效。果。只要有一个不可执行的操作,该算法无效。(4)有零个或多个输入:可以没有输入,有一)有零个或多个输入:可以没有输入,有一 个输入,也可个输入,也可以有多个输入。以有多个输入。(5)有一个或多个输出:至少有一个输出,没有输出的算法是)有一个或多个输出:至少有一个输出,没有输出的算法是没有意义的。没有意义的。 三、算法及算法描述三、算法及算法描述3、三种基本结构、三种基本结构(1) 顺序结构:是最基本、最简单的程序

13、结构,在此结构内各语顺序结构:是最基本、最简单的程序结构,在此结构内各语句块是按照它们出现的先后次序依次执行的。句块是按照它们出现的先后次序依次执行的。(2) 分支选择结构:首先根据给定的条件判断条件是否为真,条分支选择结构:首先根据给定的条件判断条件是否为真,条件为真,选择满足条件的路径(语句块)执行,条件为假,件为真,选择满足条件的路径(语句块)执行,条件为假,选择不满足条件的路径(语句块)执行。选择不满足条件的路径(语句块)执行。(3) 循环结构:是一种重复处理的程序结构。当满足(或不满足)循环结构:是一种重复处理的程序结构。当满足(或不满足)某个指定的条件时反复执行语句块(循环体),否

14、则跳出循某个指定的条件时反复执行语句块(循环体),否则跳出循环,执行循环体外的下一条语句。环,执行循环体外的下一条语句。 三、算法及算法描述三、算法及算法描述4、算法的描述方法、算法的描述方法(1)自然语言:指人们日常使用的语言加以简化来描述算法,)自然语言:指人们日常使用的语言加以简化来描述算法,自然语言通俗易懂,人们易于接受,但自然语言描述冗长、自然语言通俗易懂,人们易于接受,但自然语言描述冗长、不严谨,有时有很大的随意性和歧义性。不严谨,有时有很大的随意性和歧义性。 (2)传统流程图:是用不同几何形状的线框、流线和文字说明)传统流程图:是用不同几何形状的线框、流线和文字说明来描述算法。传

15、统流程图的常用符号及其意义见表来描述算法。传统流程图的常用符号及其意义见表1.1所示。所示。 (3)N-S流程图:又称结构化流程图,流程图:又称结构化流程图,N-S流程图由一系列矩流程图由一系列矩形框顺序排列而成,各个矩形框只能顺序执行,每一个矩形形框顺序排列而成,各个矩形框只能顺序执行,每一个矩形框表示一个基本结构。矩形框内的分割线将矩形框分割成不框表示一个基本结构。矩形框内的分割线将矩形框分割成不同的部分,形成三种基本结构:顺序结构、分支结构、循环同的部分,形成三种基本结构:顺序结构、分支结构、循环结构,表结构,表1.2所示为所示为N-S流程图的基本结构框。流程图的基本结构框。 (4)伪代

16、码:是一种过程设计语言()伪代码:是一种过程设计语言(PDL),它没有严格的语),它没有严格的语法规则,形式接近高级语言,用类似于法规则,形式接近高级语言,用类似于PASCAL语言或语言或C语语言描述算法。言描述算法。三、算法及算法描述三、算法及算法描述三、算法及算法描述三、算法及算法描述三、算法及算法描述三、算法及算法描述四、结构化程序设计四、结构化程序设计1、结构化程序的基本特点:、结构化程序的基本特点:(1) 只有一个入口。只有一个入口。(2) 只有一个出口。只有一个出口。(3) 每一个处理框都有一条从入口到出口的路径通过每一个处理框都有一条从入口到出口的路径通过(4) 不包含死循环。不

17、包含死循环。 2、程序结构:使用单一入口和单一出口的三种基本结构即顺序、程序结构:使用单一入口和单一出口的三种基本结构即顺序结构、选择结构、循环结构组成程序的算法。结构、选择结构、循环结构组成程序的算法。3、程序设计方法:编写程序采用工程化、规范化、模块化、结、程序设计方法:编写程序采用工程化、规范化、模块化、结构化的设计方法,其设计思想是构化的设计方法,其设计思想是“自顶向下,逐步求精自顶向下,逐步求精”。4、完成编程后,应该、完成编程后,应该“自底向上,逐步求证自底向上,逐步求证”,检查每条语句,检查每条语句是否正确,检查每个程序结构的逻辑是否正确,检查每个模是否正确,检查每个程序结构的逻

18、辑是否正确,检查每个模块的功能是否正确,直到检查整个程序是否达到问题的要求,块的功能是否正确,直到检查整个程序是否达到问题的要求,通过编辑、编译、连接、运行、调试检查程序是否达到精度通过编辑、编译、连接、运行、调试检查程序是否达到精度要求。要求。五、五、 数制与编码(略)数制与编码(略)1、十进制数的再认识、十进制数的再认识2、二进制、二进制3、八进制、八进制4、十六进制、十六进制5、二进制、八进制、十六进制之间的转换、二进制、八进制、十六进制之间的转换6、二进制、八进制、十六进制转换为十进制、二进制、八进制、十六进制转换为十进制7、十进制转换为二进制、八进制、十六进制、十进制转换为二进制、八

19、进制、十六进制8、二进制数的算术和逻辑运算、二进制数的算术和逻辑运算9、原码、反码、补码、原码、反码、补码10、计算机字符编码方案、计算机字符编码方案六、六、 C语言的起源及其特点语言的起源及其特点1语言的诞生与发展语言的诞生与发展(1)在)在C语言诞生以前,系统软件主要是用汇编语言编写的。语言诞生以前,系统软件主要是用汇编语言编写的。由于汇编语言程序依赖于计算机硬件,其可读性和可移植性由于汇编语言程序依赖于计算机硬件,其可读性和可移植性都很差;但一般的高级语言又难以实现对计算机硬件的直接都很差;但一般的高级语言又难以实现对计算机硬件的直接操作(这正是汇编语言的优势),于是人们盼望有一种兼有操

20、作(这正是汇编语言的优势),于是人们盼望有一种兼有汇编语言和高级语言特性的新语言。汇编语言和高级语言特性的新语言。(2)语言是贝尔实验室于)语言是贝尔实验室于70年代初研制出来的,后来又被多年代初研制出来的,后来又被多次改进,并出现了多种版本。次改进,并出现了多种版本。80年代初,美国国家标准化协年代初,美国国家标准化协会(会(ANSI),根据语言问世以来各种版本对语言的发),根据语言问世以来各种版本对语言的发展和扩充,制定了展和扩充,制定了ANSI C标准(标准(1989年再次做了修订)。年再次做了修订)。六、六、 C语言的起源及其特点语言的起源及其特点2C语言的特点语言的特点(1)语言简洁

21、、紧凑,使用方便、灵活。)语言简洁、紧凑,使用方便、灵活。(2)运算符极其丰富,表达能力强。)运算符极其丰富,表达能力强。(3)数据结构丰富,结构化程度高)数据结构丰富,结构化程度高(4)具有汇编语言和高级语言的优势)具有汇编语言和高级语言的优势(5)生成的目标代码质量高,程序执行效率高。)生成的目标代码质量高,程序执行效率高。(6)可以直接操纵硬件,比汇编程度的可移植性好。)可以直接操纵硬件,比汇编程度的可移植性好。七、语言程序的构架七、语言程序的构架1、语言程序的构架、语言程序的构架 一个完整的语言程序,是由一个一个完整的语言程序,是由一个main()函数(又称主函数)函数(又称主函数)和

22、若干个其它函数结合而成的,或仅由一个和若干个其它函数结合而成的,或仅由一个main()函数构成。函数构成。例例1.22 仅由仅由main()函数构成的语言程序。函数构成的语言程序。#include main() printf( This is a C program.n); 程序运行结果:程序运行结果: This is a C program. 七、语言程序的构架七、语言程序的构架1. 函数是语言程序的基本单位。函数是语言程序的基本单位。main()函数的作用,相当于其它高级语言中的主程序;其它函函数的作用,相当于其它高级语言中的主程序;其它函数的作用,相当于子程序。数的作用,相当于子程序。2

23、. C语言程序总是从语言程序总是从main()函数开始执行。函数开始执行。一个语言程序,总是从一个语言程序,总是从main()函数开始执行,而不论其在程函数开始执行,而不论其在程序中的位置。当主函数执行完毕时,亦即程序执行完毕。序中的位置。当主函数执行完毕时,亦即程序执行完毕。 习惯上,将主函数习惯上,将主函数main()放在最前头。放在最前头。七、语言程序的构架七、语言程序的构架2、 函数的一般结构函数的一般结构 任何函数(包括主函数任何函数(包括主函数main())都是由函数说明和函数体两)都是由函数说明和函数体两部分组成。其一般结构如下:部分组成。其一般结构如下: 函数返回值的类型函数返

24、回值的类型 函数名函数名(函数参数表函数参数表) 说明语句部分;说明语句部分; 执行语句部分;执行语句部分; 七、语言程序的构架七、语言程序的构架源程序书写格式源程序书写格式1.所有语句都必须以分号所有语句都必须以分号;结束,函数的最后一个语句也不例外。结束,函数的最后一个语句也不例外。2.程序行的书写格式自由程序行的书写格式自由既允许既允许1行内写几条语句,也允许行内写几条语句,也允许1条语句分写在几行上。条语句分写在几行上。3.允许使用注释。允许使用注释。C语言的注释格式为:语言的注释格式为: /* */。(1)“ /* ”和和“ */ ” 必须成对使用,且必须成对使用,且“ / ”和和“

25、 * ”、以及、以及“*”和和“/”之间不能有空格,否则都出错。之间不能有空格,否则都出错。例如,例如,main() int num1,num2; printf(Input the first integer number: ); scanf(%d, &num1); printf(Input the second integer number: ); scanf(%d, &num2); printf(max=%dn, max(num1, num2); 如果某条语句很长,一般需要将其分写在几行上。如果某条语句很长,一般需要将其分写在几行上。七、语言程序的构架七、语言程序的构架技巧

26、:为避免遗漏必须配对使用的符号,例如注释符号、函数技巧:为避免遗漏必须配对使用的符号,例如注释符号、函数体的起止标识符(花括号)、圆括号等等,在输入时,可连体的起止标识符(花括号)、圆括号等等,在输入时,可连续输入这些起止标识符,然后再在其中进行插入来完成内容续输入这些起止标识符,然后再在其中进行插入来完成内容的编辑。在起止标识符嵌套时,以及相距较远时,这样做更的编辑。在起止标识符嵌套时,以及相距较远时,这样做更有必要。有必要。 (2)注释的位置,可以单占一行,也可以跟在语句的后面。)注释的位置,可以单占一行,也可以跟在语句的后面。 (3)如果一行写不下,可另起一行继续写。)如果一行写不下,可

27、另起一行继续写。 (4)注释中允许使用汉字。在非中文操作系统下,看到的)注释中允许使用汉字。在非中文操作系统下,看到的是一串乱码,但不影响程序运行。是一串乱码,但不影响程序运行。 (5)使用)使用/可以在一行内注释。例如可以在一行内注释。例如: printf(max=%d,c); / 输出输出c的值的值 八、八、 基本字符集和保留字基本字符集和保留字1、 C语言基本字符集语言基本字符集C语言与其他程序设计语言一样,有一整套带有严格规定的符语言与其他程序设计语言一样,有一整套带有严格规定的符号体系来描述号体系来描述C语言的词法、语法、语义、语用。语言的词法、语法、语义、语用。C语言的语言的基本字

28、符集是编写源程序时准用字符的集合,基本字符集是编写源程序时准用字符的集合,C语言编译程语言编译程序能够识别集合中的字符。序能够识别集合中的字符。C语言编写源程序时使用的基本语言编写源程序时使用的基本字符包括:字符包括:(1) 大写字母大写字母A B C D Z,小写字母,小写字母a b c d e z(2) 数字数字0 1 2 3 4 5 6 7 8 9 (3) 图形符号图形符号 ! # % & ?| * + - _ / “ ( ) ,. : ;?;?(4) 转义符号:转义符号: 换行换行 n 水平制表位水平制表位t 退格退格b 换页换页 f 回车回车r 垂直制表位垂直制表位v 反反斜

29、线斜线 单引号单引号 双引号双引号” 8进制数进制数ddd 16进制数进制数xhh 八、八、 基本字符集和保留字基本字符集和保留字保留字又称关键字,是由编译程序预定义具有固定含义的单词,保留字又称关键字,是由编译程序预定义具有固定含义的单词,保留字有特定的含义的专门的用途,用户不能用保留字作为保留字有特定的含义的专门的用途,用户不能用保留字作为常量、变量、类型或函数的名字。常量、变量、类型或函数的名字。ANSI C标准中定义的标准中定义的32个保留字,在个保留字,在Turbo C中在存储类型说明中增加了中在存储类型说明中增加了7个保留个保留字,具体见表字,具体见表1.7。九、九、 上机环境简介

30、上机环境简介1、Turbo C集成开发环境集成开发环境(1) 进入命令行方式:进入命令行方式: “开始开始” “运行运行” 打开打开“运行运行”对话框对话框输入输入“cmd” 进行命令行方式,显示提示符进行命令行方式,显示提示符(2) 在在E盘建立盘建立TC子目录,将光盘或子目录,将光盘或U盘中盘中Turbo C的所有文件的所有文件包括包括INCLUDE、LIB两个子目录都复制在到两个子目录都复制在到TC子目录中,子目录中,运行运行TC程序:程序:E:TCTC ;打开;打开Turbo C 集成开发环境集成开发环境”Options” ”Directories” ; 设置以下路径设置以下路径Inc

31、lude directories: E: TCINCLUDELibrary directories: E: TCLIBOutput directories: E: TCTURBO C directories: E: TCPick file name:Cirrent Pick file:九、九、 上机环境简介上机环境简介3、保存配置、保存配置 ”Options”Save Options”Config File:C:TC TCCONFIG.TC”完成设置后,保存配置文件后,运行以下小程序完成设置后,保存配置文件后,运行以下小程序“Hello.c”用以下操作用以下操作运行程序:运行程序: RUNRUN ;运行正确后可以查看输出屏幕;运行正确后可以查看输出屏幕 RUNUser Screen ;程序显示;程序显示“Hello!”表示设置正确。表示设置正确。4、源程序的装载和保存、源程序的装载和保存 在网络在网络E盘上建立盘上建立K12子目录,在该子目录下以学号建立学生子目录,子目录,在该子目录下以

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论