算法与程序设计(教育科学出版社)_第1页
算法与程序设计(教育科学出版社)_第2页
算法与程序设计(教育科学出版社)_第3页
算法与程序设计(教育科学出版社)_第4页
算法与程序设计(教育科学出版社)_第5页
已阅读5页,还剩44页未读 继续免费阅读

下载本文档

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

文档简介

1、算法与程序设计第一章 如何用计算机解决问题算法与程序设计1.1 计算机解决问题的过程从一个生产方案问题了解用计算机解决问题的步骤:P3开始分析问题设计算法编写程序运行程序验证结果问题解决算法与程序设计1、具体问题:相传我国汉代有位大将军叫韩信,他在点兵时让士兵分别从13、15、17报数,然后报告各次报数的余数,这样他就能推算出总共有多少士兵。假设余数分别为2、3、2探究的问题探究过程设所求的数为X,则X应该满足:X整除3余2X整除5余3X整除7余21、令X为1。2、如果X整除3余2,X整除5余3,X整除7余2,则记下这个X的值。3、令X=X+1(为算下一个做准备)4、如果求出了X,则结束程序,

2、否则跳转执行第2步。5、输出答案。2、分析问题:算法与程序设计算法与程序设计3、设计算法:算法与程序设计4、编写程序Dim n As Integer N = 1Do If (N Mod 3=2) And (N Mod 5=3) And (N Mod 7=2) Then Print N Exit Do End If N=N+1Loop算法与程序设计Dim a As Integer, b As Integer, c As Integer, d As Integer, e As Integer, f As Integer, n As Integern = Text1.Texta = Text2.Te

3、xtb = Text3.Textc = Text4.Textd = Text5.Texte = Text6.Textf = Text7.TextFor i = 1 To n If i Mod a = b And i Mod c = d And i Mod e = f Then Text8.Text = i End IfNext i算法与程序设计Private Sub About_Click()MsgBox 我的第一个VB程序!End SubPrivate Sub Command1_Click()YSF.Caption = +Text3.Text = Val(Text1.Text) + Val(

4、Text2.Text)End SubPrivate Sub Command2_Click()YSF.Caption = -Text3.Text = Val(Text1.Text) - Val(Text2.Text)End SubPrivate Sub Command3_Click()YSF.Caption = *Text3.Text = Val(Text1.Text) * Val(Text2.Text)End SubPrivate Sub Command4_Click()If Text2.Text = 0 ThenMsgBox 除数不能为0ElseYSF.Caption = /Text3.Te

5、xt = Val(Text1.Text) / Val(Text2.Text)End IfEnd SubPrivate Sub Command5_Click()Text1.Text = Text2.Text = Text3.Text = End Sub算法与程序设计5、调试程序、得到结果1)、新建工程;2)、在窗体添加按钮控件;3)、给按钮添加单击事件过程;4)、在单击事件过程内输入编写好的程序;5)、运行程序调试结果。6、在计算机上执行该指令序列5、通过编辑、编译和连接产生计算机能够识别的指令序列4、选用一种编程语言根据算法编写程序4、验证计算结果3、生成解题算法3、用笔、纸和算盘、计算器等工

6、具进行计算2、寻找解题的途径和方法2、寻找解题的途径和方法1、理解和分析所要解决的问题1、理解和分析所面临的问题计算机解题步骤人工解题步骤相同点:无论何种解题方式,在解决某一实际问题时,都应该正确的理解问题的题意,从看似复杂的问题中整理出一个头绪,然后通过算法(即解决问题的一个一个步骤)描述出某一问题的解决过程,进行一定量的计算,最后都必须验证计算结果。 不同点:当计算量较大时,人工解题就有点力不从心了,而计算机每秒上亿次的计算速度却不在话下,并且只要算法正确,编程语句无误的话,使用计算机编写的解题程序可以反复使用。例如:sum=1+2+3+4+5+(n-1)+n这样的问题。 算法与程序设计1

7、.2 算法描述与设计1、算法的概念算法是在有限步骤内求解某一问题所使用的一组定义明确的规则。即,用计算机求解某一问题的方法,是能被机械地执行的动作或指令的有穷集合。算法的特征:1)、有0或多个输入。解题算法中可以没有数据输入,也可以同时输入多个需 要算法处理的数据。 2)、确定性。解题方法中的任何一个操作步骤都是清晰无误的,不会使人产生 歧义或者误解。 3)、有穷性。任何一种提出的解题方法都是在有限的操作步骤内可以完成的, 哪怕是失败的解题方法。 4)、有1个或多个输出。一个算法执行结束之后必须有数据处理结果输出,哪怕 是输出错误的数据结果,没有输出的算法使毫无意义的。 5)、能行性。解题方法

8、中的任何一个操作步骤在现有计算机软硬件条件下和逻 辑思维中都能够实施实现。 算法与程序设计辗转相除法 又名欧几里德算法(Euclidean algorithm)是求两个正整数之最大公约数的算法。它是已知最古老的算法, 其可追溯至前300年。它首次出现于欧几里德的几何原本(第VII卷,命题i和ii)中,而在中国则可以追溯至东汉出现的九章算术。它并不需要把二数作质因子分解。 1. a b,令r为所得余数(0rb),若 r = 0,b 即为最大公约数;算法结束 。 2. 互换:置 ab,br,并返回第一步。 例如:求112和64的最大公约数.算法如下: (1).112除以64,余数为_; (2)_除

9、以_余数为_; (3)_除以_余数为_. 答:112和64的最大公约数为_.两数的最大公约数乘以其最小公倍数=两数相乘例如:求112和64的最小公倍数 (1).利用辗转相除法求得它们的最大公约数为_; (2).利用表达式求得最小公倍数: 答: 112和64的最小公倍数为_.练习:求164和64的最大公约数求256和24的最大公约数练习:求164和64的最小公倍数求256和24的最小公倍数算法与程序设计2、算法的描述表示算法的语言有自然语言、流程图、伪代码等。1)、用自然语言描述算法;2)、用流程图描述算法:掌握流程图的基本图形及其功能。3)、用伪代码描述算法。注意对比三种算法描述方式的优劣。1

10、).输入m和n的值;2).r=m除以n的余数;3).如果r=0,则输出n值; 否则令m=n,n=r返回第2步;4).结束.开始输入正整数m和nr=m除以n的余数r=0m=n, n=r输出n的值结束是否输入m和n值r m Mod ndo while r0m=nn=rr=m mod nloop输出n值算法与程序设计优点缺点自然语言不需专门训练,通俗易懂P7流程图描述清晰简洁,容易表达选择结构;利于不同环境的程序设计.P8无法被计算机直接接受并进行操作伪代码书写方便,格式紧凑,易于理解,便于向计算机程序设计语言过渡.P8种类繁多,语句不容易规范.P8三种算法描述方式的优劣算法与程序设计使用自然语言描

11、述算法的方法虽然比较容易掌握,但是存在着很大的缺陷。例如,当算法中含有多分支或循环操作时很难表述清楚。另外,使用自然语言描述算法还很容易造成歧义(称之为二义性),譬如有这样一句话“武松打死老虎”,我们既可以理解为“武松/打死老虎”,又可以理解为“武松/打/死老虎”。自然语言中的语气和停顿不同,就可能使他人对相同的一句话产生不同的理解。又如“你输他赢”这句话,使用不同的语气说,可以产生3种截然不同的意思,同学们不妨试试看。 无论是使用自然语言还是使用流程图描述算法,仅仅是表述了编程者解决问题的一种思路,都无法被计算机直接接受并进行操作。 伪代码通常采用自然语言、数学公式和符号来描述算法的操作步骤

12、,同时采用计算机高级语言(如C、Pascal、VB、C+、Java等)的控制结构来描述算法步骤的执行顺序。 算法与程序设计在运用计算机程序解决问题的过程中,算法设计有着举足轻重的地位和作用,算法是程序设计的核心,是程序设计的灵魂.算法的好坏,直接影响着程序的通用性和有效性,影响着问题解决的效率.程序的编制依赖于算法的设计。程序的效率主要取决于算法的效率。算法的地位:算法与程序设计1.3、程序与程序设计语言1)、程序是一组机器操作的指令或语句的序列,是算法的一种描述。2)、程序的基本结构:P16顺序结构:各语句依次按照顺序执行。选择结构:通过检验条件是否成立来决定做还是不做的控件结构。循环结构:

13、在一定条件下需要重复执行的控件结构。任何复杂的算法都可以用顺序结构、选择结构、循环结构三种基本结构组合而成的程序表示。算法与程序设计S1S2SnCS1S2CS1顺序结构选择结构循环结构算法与程序设计4)、程序设计:即是编写程序的过程。一个高质量的程序,应具备以下条件:(1)、建立正确的灵堂模型和确定有效的计算方法;(2)、运行结果必须正确,且在精度和其他各方面均满足要求;(3)、程序本身具有良好的结构,逻辑清楚,易读易懂。(4)、程序运行时间尽可能短,同时尽可能合理地使用内存;(5)、便于检查、修正、移植和维护。5)、程序设计语言的产生与发展(P18)(1)、机器语言:由“0”和“1”组成的二

14、进制代码,是能够被计算机直接接受和执行的计算机语言。 优缺点:(2)、汇编语言:采用类似英语缩写略词且带有助记性的符号形式代替二进制 机器代码的计算机语言。是符号化了的机器语言。用能反映 指令功能的助记符表达的计算机语言。 优缺点:(3)、高级语言:相对于汇编语言而言,它并不是特指某一种具体的语言,而是包括了很多编程语言,如VB、C、C+,VC、Java、Pascal等。算法与程序设计语言种类优势不足机器语言能被计算机直接接受和执行程序设计任务繁重,效率低下,与自然语言存在巨大鸿沟,程序员不易培养。汇编语言比机器语言更易理解必须有语言翻译器支持,效率低,汇编源程序较冗长、复杂,容易出错。高级语

15、言更接近自然语言,移植性好。要语言翻译器支持。各种程序设计语言的比较算法与程序设计程序的编辑和翻译1、理解什么是源代码、源文件、程序的编辑?2、高级语言的翻译程序有两种类型:编译程序和解释程序。编译程序:把用高级程序设计语言书写的源程序,翻译成等价的计算机汇编语言或机器语言书写的目标程序的翻译程序。解释程序是高级语言翻译程序的一种,它将源语言(如BASIC)书写的源程序作为输入,解释一句后就提交计算机执行一句,并不形成目标程序。VB主要功能和特点1. 具有面向对象的可视化设计工具;2. 事件驱动的编程机制;3. 提供了易学易用的应用程序集成开发环境;4. 结构化的程序设计语言;5. 支持多种数

16、据库系统的访问;6. Active技术;7. VB 6.0在开发环境上、网络功能等的增强;8. 完备的help联机帮助功能。Visual Basic程序的书写规则任何计算机语言在使用时都有一些约定,书写程序时要遵循这些约定。1VB代码中英文字母不区分大小写。但是在代码窗口向计算机内输入代码时,VB将把程序中用到的关键字的首字母自动转换成大写,其余转换成小写,如果关键字由多个英文单词组成,VB将把每个英文单词首字母转换成大写,其余转换成小写。2程序书写方法。程序书写时,一般一行只写一个语句.如果一行要放几个语句,各语句之间可以用冒号分开。如果语句太长窗口一行放不下,可以续行,续行的方法是在行后使

17、用续行符,续行符是由一个空格加一个下划字符”_”组成,但一个行最多写255个字符。3注释语句。注释语句的作用是对程序或者程序段进行说明。注释语句使用单撇号时,可以放在被注释语句的后边注释语句使用REM或者单撇号开头。例如: Rem 求解方程,或者: 求解方程。Visual Basic 6.0的集成开发环境 菜单栏工具栏代码窗口工具箱窗体窗口立即窗口监视窗口工程窗口属性窗口布局窗口1. 主窗口 应用程序窗口,由标题栏、菜单栏和工具栏组成。2. 窗体(form)窗口 设计VB程序的界面。3. 代码(code)窗口 编辑窗体、标准模块中的代码。4. 属性(properties)窗口 所有窗体或控件的

18、属性设置。5. 工程资源管理器(project expror)窗口 保存一个应用程序所有的文件。6. 工具箱(toolbox)窗口 显示各种控件的制作工具,供用户在窗体上设计。7. 窗体布局窗口8. 立即窗口2.窗体(Form)设计窗口 窗体设计窗口是屏幕中央的主窗口,它可以作为自定义窗口用来设计应用程序的界面。用户可以在窗体中添加控件、图形和图片来创建所希望的外观。每个窗口必须有一个的窗体名字,建立窗体时缺省名为Form1,Form2, . . .。应注意窗体名即Name属性和窗体文件名的区别 窗体设计窗口窗体名窗体文件名3.代码(code)窗口 在设计模式中,通过双击窗体或窗体上任何对象或

19、通过“工程资源管理器”窗口中的“查看代码”按钮来打开代码编辑器窗口。代码编辑器是输入应用程序代码的编辑器。 4. 属性(properties)窗口 属性是指对象的特征,如大小、标题或颜色等数据。在Visual Basic6.0设计模式中,属性窗口列出了当前选定窗体或控件的属性的值,用户可以对这些属性值进行设置。 工程是指用于创建一个应用程序的文件的集合。工程资源管理器列出了当前工程中的窗体和模块 5. 工程资源管理器(project explorer)窗口 工具箱提供一组工具,用于设计时在窗体中放置控件生成应用程序的用户接口。系统启动后缺省的General工具箱就会出现在屏幕左边,上面有常用“

20、部件” 6. 工具箱(ToolBox)窗口 窗体布局窗口显示在屏幕右下角。用户可使用表示屏幕的小图像来布置应用程序中各窗体的位置。这个窗口在多窗体应用程序中很有用,因为这可以指定每个窗体相对于主窗体的位置。 7窗体布局窗口程序的基本结构顺序结构是最简单的程序结构,它是由若干个依次执行的处理步骤组成的。如图,A语句和B语句是依次执行的,只有在执行完A语句后,才能接着执行B语句。 顺序结构题目:输入两个数,然后交换这两个数,再输出它们交换后的结果。(1)分析问题。 要交换两个数,要利用几个变量来保存数据?顺序结构(2)分析程序的执行步骤,画出流程图。第一步:输入两个变量A、B的值。第二步:利用第三

21、个变量C来进行交换,交换的过程如下: C=A A=B B=C第三步:输出交换后A、B的值。顺序结构(3)讲解程序的编写。Private Sub command1_Click()A=InputBox(输入第一个数A:)B=InputBox(输入第二个数B:)C=AA=BB=CPrint 交换后A=;A, 交换后B=;BEnd Sub顺序结构顺序结构的特点:1. 执行过程是按顺序从第一条语句执行到最后一条语句。2. 在程序运行的过程中,顺序结构程序中的任何一条语句都要运行一次,而且也只能运行一次。顺序结构在处理实际问题时,只有顺序结构是不够的,经常会遇到一些条件的判断,流程根据条件是否成立有不同的

22、流向。如下图所示,程序根据给定的条件P是否成立而选择执行A操作或B操作这种先根据条件做出判断,再决定执行哪一种操作的结构称为分支结构,也称为选择结构。选择结构应用举例:判断输入的一个正整数,是偶数还是奇数。题目:输入一个正整数,判断它是偶数还是奇数。(1)分析问题。提示要判断一个正整数是偶数还是奇数,判断的条件是什么? 选择结构(2)分析程序的执行步骤,画出流程图。 第一步:输入一个正整数N; 第二步:判断N是否能被2整除,即判断条件N mod 2=0是否成立; 第三步:若判断条件成立,则输出该正整数是偶数,否则输出该正整数是奇数选择结构(3)讲解程序的编写。Private Sub command1_Click()N=InputBox(输入一个正整数:)If (N mod 2=0) ThenPrint N; 是偶数。ElsePrint N;是奇数。End IfEnd Sub选择结构小结分支结构的特点。 分支结构是根据不同的条件判断来决定程序执行走向的结构。 在程序运行的过程中,在分支结构内,无论P条件是否成立,只能执行A操作或B操作之一,不可能既执行A操作又执行B操作,也不可能A操作和B操作都不执行。选择结构有时在解决一些问题时,经常需要重复执行一些操作,如计算123+100的和

温馨提示

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

评论

0/150

提交评论