程序设计基础(C语言)陈有英答疑邮箱:cyyanswer@126.com计算机及程序设计概述计算机和计算机程序3计算机的基本工作原理输入数据输入设备存储器控制器运算器输出设备输出数据4计算机硬件和计算机软件计算机硬件主机外部设备计算机软件裸机要使计算机解决各种实际问题,必须有软件的支持,计算机软件着重研究如何管理计算机和使用计算机的问题,没有软件支持的计算机就是一堆废铁5指令与程序指令指令就是计算机执行某种操作的命令,是硬件能理解并能执行的语言,是机器语言的一个语句,是程序员进行程序设计的最小语言单位。指令的组成指令由操作码和操作数构成Mov3,reg1Mov5,reg2Addreg1,reg2End6指令与程序程序程序(program)是为实现特定目标或解决特定问题而用计算机语言编写的、可以连续执行并能够完成一定任务的指令序列的集合。程序的开发描述问题(算法)程序设计语言计算机软件7程序设计语言机器语言二进制指令与计算机硬件的设计密切相关汇编语言汇编语言与机器语言的指令具有一一对应的关系,指令的操作码和操作数地址全部用指定的符号表示汇编语言依然依赖于计算机系统结构,只能为特定的机器所识别,是面向机器的语言8程序设计语言高级语言与具体的计算机指令系统无关的计算机语言高级语言的分类面向过程的语言C、Pascal面向对象的语言C++、Java、.Net面向特定应用的语言SQL9为什么学习c语言?C语言是目前实际程序设计工作中使用最广泛的语言之一它包含了程序设计需要理解和使用的基本程序机理和主要机制掌握这些机制就可以理解程序与程序设计的主要问题。目前有许多软件系统是用C编写的,或基本上是用C编写的学习程序设计的同时也能掌握一种实用的程序设计工具C语言是一种很灵活的语言既可以在较高层次上做,也可以在较低级的层次上做很多新型的语言都是衍生自C语言有些本身就是C语言的扩充和发展程序设计是计算机领域的基础课程C语言适合作为计算机领域许多后续课程的教学语言10授课重点侧重学习一个具体问题的算法化的过程学习应该掌握的基本编程技巧以及C编程的风格和艺术讨论怎样编写出一个好的程序?简单、实用的原则11本课程的组织第一部分基础第二部分简单程序设计第三部分高级程序设计算法概念、编程原理、编程风格、基本数据类型定义、算术运算符及表达式顺序结构、选择结构、循环结构、数组的定义及应用、程序设计过程函数、变量的存储类别、指针、结构体与共用体、文件12程序设计什么是程序设计?使用某种程序语言编写程序的过程,就是用计算机语言对所要解决的问题中的数据以及处理问题的方法和步骤所做的完整而准确的描述的过程怎样进行程序设计?分析问题确定算法编制程序调试程序13程序设计一个完整的程序数据结构、算法、编程语言和程序设计方法对数据的描述(数据流)指定数据的类型和数据的结构对操作的描述(控制流)指定操作的步骤,既算法程序=数据结构+算法14算法什么是算法(Algorithm)?就是为了解决一个特定的问题而采取的确定的、有限的、按照一定次序进行的、缺一不可的执行步骤注意为了有效地利用计算机解决实际问题,在设计算法时不仅要保证计算机执行算法的正确性,还要考虑算法的质量,选择适合于具体问题的算法15算法通常计算机算法分为两大类:数值运算算法和非数值运算算法数值运算是指对问题求数值解有确定的数学模型非数值运算是指事务处理过程种类繁多,很难提供统一规范的算法更多的是需要用户设计其算法的16算法例1:猴子吃桃问题。有一堆桃子不知数目,猴子第一天吃掉一半,又多吃了一个,第二天照此方法,吃掉剩下桃子的一半又多一个,天天如此,到第11天早上,猴子发现只剩一只桃子了,问这堆桃子原来有多少个?数学模型:ai=2*(ai+1+1)i=9,8,7,…1;Step1:peach1=1;i=10;Step2:peach0=2*(peach1+1);Step3:peach1=peach0;Step4:i=i-1;Step5:若i=1,继续循环执行Step2;Step6:输出peach0的值。17算法输入三个数,然后输出最大的数算法的两个要素基本功能操作数据运算和传输控制结构顺序、选择和循环三种基本控制流程算法可以写成:(1)输入A,B,C;(2)若AB,则A-MAX;若AB,则B-MAX。(3)若CMAX,则C-MAX。(4)输出MAX,MAX是最大数。18算法的特性有穷性应含有有限的操作步骤,不能是无限的。有穷性指在“合理的限度之内”唯一性每一个步骤都是确定的,只有一个涵义,不可以为二义性有零个或多个输入在执行算法时需要从外界获取必要的信息有一个或多个输出算法执行的目的就是为了求解,“解”就是输出的信息没有输出的算法是没有意义的正确性每一个步骤应当被有效的执行,并得到确定的结果19算法的表示流程图端点:表示程序的转向,常用来表示程序的开始和结束。处理:操作的功能判断:单入口多出口,表明判断的条件流线:表示程序的执行方向和顺序。输入/输出:表示数据的名称、类型和用途等。20算法的表示流程图开始输入A,B,CAB?TNMAX=AMAX=BCMAX?NTMAX=C输出MAX结束21算法的表示N-S图是适合结构化程序设计方法的图形工具N-S流程图无法表示非结构化的程序TN当〈条件〉满足a1=1i=9当i=1时,循环a0=2*(a1+1)a1=a0i=i-1输出a022算法的表示UML面向对象的分析与设计工具适合于描述复杂系统元素之间的关系,不关注具体算法23程序设计基本步骤确定数学模型实际问题的准确描述算法描述解决问题的具体步骤编写程序将已设计好的算法表达出来程序测试保证程序的正确性24结构化的程序设计方法程序的三种基本结构问题的提出结构化程序设计必须采用的结构顺序结构、选择结构和循环结构被称为程序设计的三种基本结构算法的实现过程是由一系列操作组成的,这些操作之间的执行次序就是程序的控制结构总体结构流程都是自上而下顺序执行的。25结构化的程序设计方法程序的三种基本结构顺序结构,顺序结构表示程序中的各操作是按照它们出现的先后顺序执行的选择结构,表示程序的处理出现了分支,它需要根据某一特定的条件选择其中的一个分支执行循环结构,程序反复执行某个或某些操作,直到某条件为假(或为真)时才可终止循环26结构化的程序设计方法结构化程序设计方法公认的面向过程编程应遵循的基本方法和原则结构化程序设计特征采用模块化结构自顶而下的设计方法便于对问题的分解和模块的划分程序由三种基本控制结构组成有限制地使用转移语句采用结构化程序设计语言书写程序结构化程序设计语言书写程序注意书写风格27其他程序设计方法面向对象程序设计方法结构化程序设计方法作为一种面向过程的程序设计方法,将解决问题的重点放在了描述实现过程的细节上,尽量保证程序的客观性,避免人对于程序设计的干扰。面向对象方法的基本原则是尽可能地模拟现实世界中人类的思维方式,使开发软件的方法和过程尽可能地接近人类解决问题的方法和过程。并行程序设计基于组件的程序设计28什么是C语言?1973年由美国贝尔实验室设计发布的目前是计算机程序设计语言的主流语种是世界上最为广泛使用的语言之一C语言的流行归功于两个主要因素使用正确的C语言指令几乎可以完成任何任务是可移植的C编译系统的广泛采用C语言是一种能够让软件工程师与计算机进行有效对话的介于汇编语言和高级语言之间的编程语言29什么是C语言?C语言标准1978年,正式出版的《TheCProgrammingLanguage》书中介绍的c语言,称为标准c语言1983年,美国国家标准化协会(ANSI)根据各种c语言版本对c的扩充和发展,颁布了c语言的新标准ANSIcANSIc比标准c有了很大的扩充和发展1987年,美国国家标准化协会又颁布新标准,称为87ANSIC1990年,国际标准化组织ISO接受了87ANSIC作为ISOC的标准目前功能最完善、性能最优良的C新版本目前流行的C编译系统都是以它为基础的30什么是C语言?C语言的特点适合开发系统软件结构化的程序设计语言丰富的数据类型和数据结构运算符多样化可移植性好语句简洁紧凑编程风格灵活,语法限制少,使用灵活具有预处理功能面向对象程序设计的基础31编写一个加法运算程序#include〈stdio.h〉main(){inta,b;/*定义两个整形变量*/a=1;b=5;/*给两个变量赋值*/printf(“%d+%d=%d\n”,a,b,a+b);/*打印a和b之和*/}C语言严格区分大、小写英文字母。C语言程序习惯上使用小写英文字母,而大写英文字母通常作为常量的宏定义和其他特殊的用途。什么是C语言?32#include〈stdio.h〉main(){inta,b;/*定义两个整形变量*/a=1;b=5;/*给两个变量赋值*/printf(“%d+%d=%d\n”,a,b,a+b);/*打印a和b之和*/}C语言严格区分大、小写英文字母。什么是C语言?C语言程序是由一个个的语句组成。每个语句都具有规定的语法格式和特定的功能。编写一个加法运算程序33#include〈stdio.h〉main(){inta,b;/*定义两个整形变量*/a=1;b=5;/*给两个变量赋值*/printf(“%d+%d=%d\n”,a,b,a+b);/*打印a和b之和*/}C语言严格区分大、小写英文字母。什么是C语言?C语言程序是由一个个的语句组成。C语言程序使用“;”作为语句的终止符和分隔符。可以任意书写,即一行中可以书写多个语句,一个语句也可以占用任意多行,语句之间必须用“;”分隔。初学时建议在一行内书写一条语句。编写一个加法运算程序34#include〈stdio.h〉main(){inta,b;/*定义两个整形变量*/a=1;b=5;/*给两个变量赋值*/printf(“%d+%d=%d\n”,a,b,a+b);/*打印a和b之和*/}C语言严格区分大、小写英文字母。什么是C语言?C语言程序是由一个个的语句组成。C语言程序使用“;”作为语句的终止符和分隔符。C语言程序中用大括号对“{}”表示程序的结构层次范围。一个完整的程序模块要用一对花括号括起来,用以表示模块的范围。为了清晰地表现出程序的结构,建议使用右缩进锯齿型程序书写格式。编写一个加法运算程序35#include〈stdio.h〉main(){inta,b;/*定义两个整形变量*/a=1;b=5;/*给两个变量赋值*/printf(“%d+%d=%d\n”,a,b,a+b);/*打印a和b之和*/}C语言严格区分大、小写英文字母。什么是C语言?C语言程序是由一个个的语句组成。C语言程序使用“;”作为语句的终止符和分隔符。C语言程序中用大括号对“{}”表示程序的结构层次范围。C语言程序可以使用注释。注释部分的格式是:/*注释内容*/注释部分不参与程序的执行,对程序的运行结果没有影响,只是用来提示或助记。编写一个加法运算程序36什么是C语言?C程序结构组成C程序为函数模块结构,整个程序都是由一个或多个函数组成函数是由函数说明和函数体两部分组成一个C程序总是从main()函数开始执行被调用的函数可以是系统提供的库函数,也可以是用户根据需要自己编制设计的函数(用户自定义函数)一个C程序可以由一个文件组成,也可以由若干个文件组成分析下面程序:#includestdio.hmain(){inta=1,b=5,c;c=add(a,b);printf(“c=%d\n”,c);}intadd(intx,inty){return(x+y);}37C程序源程序文件1源程序文件i源程序文件n预编译命令函