第四部分三种基本结构程序设计方案课件_第1页
第四部分三种基本结构程序设计方案课件_第2页
第四部分三种基本结构程序设计方案课件_第3页
第四部分三种基本结构程序设计方案课件_第4页
第四部分三种基本结构程序设计方案课件_第5页
已阅读5页,还剩64页未读 继续免费阅读

下载本文档

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

文档简介

1、第四部分三种基本结构程序设计方案第四部分三种基本结构程序设计方案4.1 算法及算法的表示 4. 1.1 算法概述 什么是算法: 广义地讲:算法是为完成一项任务所应当遵循的一步一步的规则的、精确的、无歧义的描述,它的总步数是有限的。 狭义地讲:算法是解决一个问题采取的方法和步骤的描述。下面通过两个简单的例子加以说明:例4.1 输入三个数,然后输出其中最大的数。 将三个数依次输入到变量、B、C中,设变量MAX存放最大数。其算法如下: 4.1 算法及算法的表示 4. 1.1 算法概述例4.1 例4.2 输入10个数,打印输出其中最大的数。算法设计如下:(1)输入1个数,存入变量A中,将记录数据个数的

2、变量N赋值为1,即N=1(2)将A存入表示最大值的变量Max中,即Max=A(3)再输入一个值给A,如果AMax 则 Max=A, 否则Max不变(4)让记录数据个数的变量增加1,即N=N+1(5)判断N是否小于10,若成立则转到第(3)步执行,否则转到第(6)步。(6)打印输出max1) 输入A、B、C。2) A与B中大的一个放入MAX中。3) 把C与MAX中大的一个放入MAX中。4) 输出MAX,MAX即为最大数。例4.2 输入10个数,打印输出其中最大的数。1) 输入A4.1.2 算法的特性 有穷性确定性有0个或多个输入有一个或多个输出有效性4.1.2 算法的特性 有穷性4.1.3 算法

3、的表示 一、自然语言与伪代码表示算法自然语言:就是指人们日常使用的语言,可以是汉语、英语或其它语言。伪代码:是用介于自然语言和计算机语言之间的文字和符号(包括数学符号)来描述算法。 例如:例4.1可用如下的伪代码表示Begin(算法开始) 输入 A,B,C IF AB 则 AMax 否则 BMax IF CMax 则 CMaxPrint MaxEnd (算法结束)4.1.3 算法的表示 二 用传统流程图表示算法处理框起止框I/O框判断框流程线连接点1、传统流程图中的基本符号二 用传统流程图表示算法处理框起止框I/O框判断框流程线连接2、三种基本结构的表示(1)顺序结构条件语句1语句2YN语句1

4、语句2(2)选择结构2、三种基本结构的表示条件语句1语句2YN语句1语句2(2)条件( a )条件语句组(3)循环结构a) 当型循环b) 直到循环YNYN( b )语句组条件( a )条件语句组(3)循环结构a) 当型循环b) 直三种基本结构的特点:(1)只有一个入口(2)只有一个出口(3)不存在死语句(4)不存在死循环例: 例4.2输入10个数,打印输出其中的最大的数的流程图三种基本结构的特点:(1)只有一个入口例: 例4.2输入10从10个数中选出最大的数的流程图NMaxMax =A输入A开始再输入给AN=N+1打印Max结束YNNY从10个数中选出最大的数的流程图NMa4.1.4 用NS

5、流程图表示算法 将全部算法写在一个矩形框内,在矩形内还可包含其它从属于它的框三种基本结构的NS图表示:语句A语句B语句A语句B条件YN1、顺序结构2、选择结构4.1.4 用NS流程图表示算法 将全部算法写在一个矩语句组(3)循环结构a) 当型循环b) 直到循环当条件成立语句组直到当条件成立例: 画出从10个数中选出最大的数的NS 流程图( a )( b )语句组(3)循环结构a) 当型循环b) 直到循环当条件成立语传统流程图NMaxMax =A输入A开始再输入给AN=N+1打印Max结束YNNY输入A当NMaxYN输入A传统流程图NMaxMax =A输入A开Private Sub Form_C

6、lick() Dim a%, max%, i% a = Val(InputBox(A=?) max = a For i = 1 To 10 a = Val(InputBox(A=?) If a max Then max = a Next i Print Max=; maxEnd Sub 最后需要说明的是:上面介绍的算法表示是给人看的,即是为帮助程序开发人员阅读、编写程序而设计的一种辅助工具,程序则必须符一计算机语言的语法规则。 下面是例4.2的计算机 程序,即为用计算机语言表示算法:Private Sub Form_Click() 4.1.6 结构化程序设计方法(补充)(一)、用计算机解决问题

7、的过程提出、分析问题确定算法模型设计算法编写程序调试程序分析输出结果正确合理结束不正确4.1.6 结构化程序设计方法(补充)(一)、用计算机解决(二)、结构化程序设计思想自顶向下、逐步细化、模块化自顶向下:先从全局、整体设计逐步细化:将一个问题分解成几个较小的问题解决模块化: 将一个大任务分解成若干个较小的部分, 每 个部分承担一定功能,称为“功能模块”例:给100个整数,打印输出其中的素数(二)、结构化程序设计思想自顶向下、逐步细化、模块化自顶向下S1NS流程图输入100个数存入X1,x2,x100打印x1.x100中不等于0的数让x1,x2,x100中的非素变为0S3S2输入xi当i=10

8、0i=i+1i=1S1细化xi0当i=100i=i+1i=1YN打印xiS3细化S1NS流程图输入100个数存入X1,x2,x100打S1NS流程图输入100个数存入X1,x2,x100打印x1.x100中不等于0的数让x1,x100中的非素变为0S3S2S2细化判断xi是否是素数,若不是则将xi=0当i=100i=i+1i=1S21r=0rxi/2S21细化S1NS流程图输入100个数存入X1,x2,x100打输入100个数存入X1,x2,x100打印x1.x100中不等于0的数让x1,x100中的非素变为0细化后的流程图输入xi当i=100i=i+1i=1当ixi/2i=i+1xi0当i=

9、100i=1YN打印xii=i+1输入100个数存入X1,x2,x100打印x1.x14.2 顺序结构4.2.1 赋值语句 形式: 变量名表达式 对象.属性表达式 功能: 将表达式的值赋值给变量名或指定对象的属性。 一般用于给变量赋值或对控件设定属性值. 例: sRate!=0.1 Text1.Text 欢迎使用Visual Basic 6.0”说明: 1 执行过程:先求表达式的值,然后将值赋值给左边的变量。 2 右边的表达式可以是变量、常量、函数调用等特殊的表达式。 3 不要将“”理解为数学上的等号: A=A+1 是表示将A单元的值加后以放回到A单元。4.2 顺序结构4.2.1 赋值语句 执

10、行过程如右图4赋值符号“=”左边一定只能是变量名或对象的属性引用,不能是常量、符号常量、表达式。 下面的赋值语句都是错的:5=X 左边是常量。Abs(X)=20 左边是函数调用,即是表达式。 5. 赋值符号“=”两边的数据类型一般要求应一致。 执行过程如右图4赋值符号“=”左边一定只能是变量名或对象的4.2.2 数据的输出Print方法 Print方法的一般格式: 对象名.Print,|;说明: 对象名. 可以是窗体名、图片框名,也可是立即窗口“Debug”。若省略对象,则表示在当前窗体上输出。在2.3节窗体对象的方法中对Print方法做了详细的介绍。用Print方法在图片框和立即窗口对象中输

11、出与在窗体对象中输出完全相同。 4.2.2 数据的输出Print方法 Print方法的4.2.3 用户交互函数和过程 1. InputBox函数变量名=InputBox$(, , ) 其中:提示 提示信息,标题 标题区显示,缺省输入区缺省值。例如,要在屏幕上显示如下的对话框:4.2.3 用户交互函数和过程 例如:有下列语句如下: Dim x% x= Val(InputBox(“请输入一个数”, “输入框”, 100) 语句执行后打开如下对话框。缺省值标题题提示 例如:有下列语句如下:缺省值标题题提示2. MsgBox函数和MsgBox过程 函数形式:变量% = MsgBox(提示,按钮图标+

12、缺省按钮+模式,标题) 过程形式: MsgBox 提示,按钮图标 +缺省按钮+ 模式,标题图标标题提示信息命令按钮2. MsgBox函数和MsgBox过程图标标题提示信息命令说明: “标题”和“提示”与InputBox函数中对应的参数相同; “按钮图标 +缺省按钮+模式”是整型表达式,决定信息框按钮数目、出现在信息框上的图标类型及操作模式(见表4.1) 若程序中需要返回值,则使用函数,否则可调用过程。 说明:按钮及图标值如下:根据用户所选按钮,函数返回17的整数值,其含义如下表:(表4.2)按钮及图标值如下:根据用户所选按钮,函数返回17的整数值,4.2.4 注释语句 其语法格式为:Rem 或

13、 说明:1. 指要包括的任何注释文本。在Rem关键字和注释内容之间要加一个空格。可以用一个英文单引号“”来代替Rem关键字。2. 如果在其他语句行后面使用Rem关键字,必需用冒号(:)与语句隔开。若用英文单引号“”,则在其他语句行后面不必加冒号(:)。例如:Const PI=3.1415925 符号常量PIS=PI*r*r : Rem计算圆的面积4.2.4 注释语句 其语法格式为:4.3 选择结构 1. IfThen语句(单分支结构) If Then 语句块 End If 或 If Then 例:已知两个数x和y,比较它们的大小, 使得x大于y. If xy Then t=x : x=y: y

14、=t End If 或 If xy Then t=x: x=y: y=t4.3 选择结构例:已知两个数x和y,比较它们的大小,2. IfThenElse语句(双分支结构) If Then Else End If If Then Else 例如:输出x,y两个中值较大的一个值。IF XY Then Print XElse Print YEnd If也可以写成如下的单行形式: IF XY Then Print X Else Print Y 双分支选择结构执行过程 例4.3 设计一个求解一元二次方程的程序 2. IfThenElse语句(双分支结构)例如:输出x3. IfThenElseIf语句(多

15、分支结构) 形式: If Then ElseIf Then Else 语句块 n+1 End If 例4.4:输入一学生成绩,评定其等级。方法是:90100分为“优秀”,8089分为“良好”,7079分为“中等”,6069分为“及格”,60分以为“不合格”执行过程3. IfThenElseIf语句(多分支结构) 使用IF语句实现的程序段如下:If x=90 thenPrint 优秀ElseIf x=80 ThenPrint 良好ElseIf x=70 ThenPrint 中等ElseIf x=60 ThenPrint 及格ElsePrint 不及格End If使用IF语句实现的程序段如下:4.

16、3.2 Select Case语句(情况语句)形式:Select Case 变量或表达式Case 表达式列表1语句块1Case 表达式列表2语句块2Case Else语句块n+1End Select:与同类型的下面四种形式之一: 表达式 例: A +5 一组枚举表达式(用逗号分隔) 2, 4, 6, 8 表达式1 To 表达式2 60 to 100 Is 关系运算符表达式 Is 60数值型或字符串表达式4.3.2 Select Case语句(情况语句)数值型或例如:将例4.3 使用select case.语句来实现的程序段如下:Select Case x Case 90 to 100 Prin

17、t 优秀 Case 80 to 89 Print 良好 Case 70 to 79 Print 中等 Case 60 to 69 Print 及格 Case Else Print 不及格End Select例如:将例4.3 使用select case.语句来实现补充例题:设计一个由计算机来当小学低年级学生算术老师的VB应用程序,要求给出一系列的两个110数的四则运算的算术题,学生输入该题的答案,计算机根据学生的答案判断正确与否,并给出成绩,单击结束命令按钮,退出应用程序。 分析:产生110操作数,可通过Int(10* Rnd + 1) 实现 补充例题:设计一个由计算机来当小学低年级学生算术老师

18、的VB应4.3.3 选择结构的嵌套 在IF语句的Then分支和Else分支中可以完整地嵌套另一IF语句或Select Case语句,同样Select Case语句每一个Case分支中都可嵌套另一IF语句或另一Select Case语句。下面是两种正确的嵌套形式:(1)IF Then . IF Then Else . End If . Else . IF Then . Else . End If . End IF(2)IF Then .Select Case Case IF Then Else . End If Case. . End Select .End IF4.3.3 选择结构的嵌套 注意

19、:只要在一个分支内嵌套,不出现交叉,满足结构规则,其嵌套的形式将有很多种,嵌套层次也可以任意多。对于多层IF嵌套结构中,要特别注意IF与Else的配对关系,一个Else必须与IF配结,配对的原则是:在写含有多层嵌套的程序时,建议使用缩进对齐方式,这样容易阅读和维护。例4.5 设计一个用户身份验证程序,运行界面如下图所示。 注意:只要在一个分支内嵌套,不出现交叉,满足结构规4.4 循环结构1. For循环语句 (一般用于循环次数已知)形式 For 循环变量初值 to 终值 Step 步长 语句块Exit For 语句块 Next 循环变量循环体 0 初值终值 =1 时,可省略终值=0 死循环 步

20、长4.4 循环结构循环体 0 初值终值 =1 时,可省循环次数例: For I=2 To 13 Step 3 Print I , Next I Print “I=“, I 循环执行次数 输出I的值分别为: 2 5 8 11 出了循环输出为: I=14循环次数例: For I=2 To 13 Step例4.6 编程计算:S=1+2+3+100Dim S%, I%S=0 累加前变量S为0For I=1 to 100 S=S+INext IPrint S=,S 当N=100N=N+1打印SS=0,N=1S=S+N例4-5的算法流程图Dim S%, I%当N=100N=N+1打印SS=0,N形式1:(

21、当型循环) Do While|Until 语句块 Exit Do 语句块 Loop4.4.2 DoLoop循环语句 形式1:(当型循环) 形式2:(直到循环)Do 语句块 Exit Do 语句块Loop While|Until 形式2:(直到循环)条 件语句块语句块TFExit Do条 件语句块语句块TFExit Do Do UntilLoop执行过程 DoLoop Until执行过程 条 件语句块语句块TFExit Do条 件语句块语句块T说明:(1)当使用While构成循环时,当条件为“真”,则反复执行循环体,当条件为“假”,则退出循环。(2)当使用Until 构成循环时,当条件为“假”,

22、则反复执行循环体,直到条件成立,即为“真”时,则退出循环。(3)在循环体内一般应有一个专门用来改变条件表达式中变量的语句,以使随着循环的执行,条件趋于不成立(或成立),最后达到退出循环。 (4)语句Exit Do的作用是退出它所在的循环结构,它只能用在DO/Loop结构中,并且常常是同选择结构一起出现在循环结构中,用来实现当满足某一条件时提前退出循环。 说明:(3)在循环体内一般应有一个专门用来改变条件表达式中变4.4.3 WhileWend语句使用格式如下:While Wend 说明:该语句的功能与Do While .Loop实现的循环完全相同。例:用doLoop语句改写前面的例题4.54.

23、4.3 WhileWend语句例:用doLoop语例4.8 求两个整数的最大公约数、最小公倍数Dim n%,m%,nm%,r%m=Val(InputBox(m=)n=Val(InputBox(n=)nm=n*mIf mn Then t=m: m=n: n=t r=m mod n Do While (r 0) m=n n=r r= m mod n LoopPrint 最大公约数=, n Print 最小公倍数=, nm/n 算法使用转碾除法,流程图如右,实现的程序代码如下:例4.8 求两个整数的最大公约数、最小公倍数Dim n%, 4.4.4 循环的嵌套多重循环结构 如果在一个循环内完整地包含另

24、一个循环结构,则称为多重循环,或循环嵌套,嵌套的层数可以根据需要而定,嵌套一层称为二重循环,嵌套二层称为三重循环。 上面介绍的几种循环控制结构可以相互嵌套,下面是几种常见的二重嵌套形式: 4.4.4 循环的嵌套多重循环结构(1)For I=. . For J=. . Next J . Next I(2)For I=. . Do While/Until . . Loop . Next I(3)Do While. . For J=. . Next J . Loop(4)Do While/Until. . Do While/Until . . Loop . Loop(1)For I=.(2)For

25、I=.(3)Do 例如:打印九九乘法表. For i = 1 To 9 For j = 1 To 9 se = i & & j & = & i * j Picture1.Print Tab(j - 1) * 9 + 1); se; Next j Picture1.Print Next i例如:打印九九乘法表.对于循环的嵌套,要注意以下事项:(1) 内循环变量与外循环变量不能同名;(2) 外循环必须完全包含内循环,不能交叉; (3) 不能从循环体外转向循环体内,也不能从外循环转向内循环. 正 确错 误 For i =1 To 10 For j=1 To 20 Next i Next j For

26、i =1 To 10 For i=1 To 20 Next i Next i For i =1 To 10 For j=1 To 20 Next j Next i For i =1 To 10 Next i For i =1 To 10 Next i 对于循环的嵌套,要注意以下事项: For 4.4.5 几种循环语句比较 4.4.5 几种循环语句比较 4.4.6 循环结构与选择结构的嵌套 在循环结构中可以完整嵌套选择结构即整个选择结构都属于循环体。在选择结构中嵌套循环结构时,则要求整个循环结构必须完整地嵌套在一个分支内,一个循环结构不允许出现在两个或两个以上的分支内。 4.4.6 循环结构与选

27、择结构的嵌套 在循环(1)For I= IF Then End IF Next I(6) IF Then For I= End IF Next I(5)Select Case For I= Case Case Next I End Select(3)For I= IF Then Next I End IF(2)IF Then For I= Next I End IF(4)For I= Select Case Case Case End Select Next I(1)For I=(6) IF Then (5)S4.5 其它控制语句 4.5.1 Goto 语句 形式: Go To 标号|行号 作

28、用是无条件地转移到标号或行号指定的那行语句. 标号是一个字符序列,行号是一个数字序列。 4.5 其它控制语句 4.5.2 Exit 语句 Exit 语句用于退出 Do.Loop、For.Next、Function或Sub代码块。 对应的使用格式为:Exit Do、Exit For、Exit Function、Exit Sub。分别表示退出DO循环、For循环、函数过程、子过程。例如: 下面的例子是使用 Exit 语句退出 For.Next 循环、Do.Loop 循环及子过程。4.5.2 Exit 语句 Exit 语句用于退出 Do.Private Sub Form_Click()Dim I%,

29、 Num% Do While True 建立无穷循环。 For I = 1 To 100 循环 100 次。 Num = Int(Rnd * 100) 生成一个099的随机数。 Select Case Num Case 10: Exit For 退出 For.Next 循环。 Case 50: Exit Do 退出 Do.Loop 循环。 Case 64: Exit Sub 退出子过程。 End Select Next I LoopEnd SubPrivate Sub Form_Click()4.5.3 End 语句 形式: End 功能:结束一个程序的运行。 在Visual Basic中还有

30、多种形式的End语句,用于结束一个程序块或过程。 其形式有: End If End Select End Type End With End Sub End Function等它们与对应的语句配对使用。 4.5.3 End 语句 4.5.4 暂停语句 Stop语句用来暂停程序的执行,相当于在事件代码中设置断点。语法格式为: Stop说明:1. Stop语句的主要作用是把解释程序置为中断(Break)模式,以便对程序进行检查和调试。可以在程序的任何地方放置Stop语句,当执行Stop语句时,系统将自动打开立即窗口。2. 与End语句不同。 4.5.4 暂停语句 4.5.5 With.End Wi

31、th 语句 形式: With 对象名 语句块 End With 说明:With 语句可以对某个对象执行一系列的语句,而不用重复指出对象的名称。 例如,要改变一个对象的多个属性,可以在 With 控制结构中加上属性的赋值语句,这时候只是引用对象一次而不是在每个属性赋值时都要引用它。下面的例子显示了如何使用 With 语句来给同一个对象的几个属性赋值。4.5.5 With.End With 语句 例如,需要对同一对象设置几个属性。途径之一是使用多条语句。Private Sub Form_Load()Command1.Caption = 退出(E&xit)Command1.Top = 500Comm

32、and1.Left = 4500Command1.Enabled = TrueEnd Sub使用With.End With 语句,上面程序的代码如下。Private Sub Form_Load()With Command1.Caption = 退出(E&xit) .Top = 500.Left = 4500.Enabled = TrueEnd WithEnd Sub 例如,需要对同一对象设置几个属性。途径之一是使用多条语句。4.6 应用程序举例4.6.1 素数与哥德巴赫猜想 例4.10 判断一个给定的整数是否为素数。 算法思路:素数指除了能被1和自身外,不能被其他整数整除的自然数。判断整数N是

33、不是素数的基本方法是:将N分别除以2,3,N-1,若都不能整除,则N为素数。因为N=Sqr(N)*Sqr(N),所以,当N能被大于等于Sqr(N)的整数整除时,一定存在一个小于等于Sqr(N)的整数,使N能被它整除,因此只要判断N能否被2,3,Sqr(N)整除即可。 算法流程图如下:4.6 应用程序举例4.6.1 素数与哥德巴赫猜想 例4.1Dim N %, I%, K%N = Val(InputBox(N=?)K= Int(Sqr(N)For I = 2 To K If N Mod I = 0 Then Exit ForNext IIf IK Then Print N; 是素数Else Pr

34、int N; 不是素数End If Dim N %, I%, K% 例4.11 编一程序验证哥德巴赫猜想:一个大于等于6的偶数可以表示为两个素数之和。例如: 6=3+3 8=3+5 10= 3+7 算法设计:设N为大于等于6的任一偶数,将其分解为N1和N2两个数,使用N1+N2=N,分别判断N1和N2是否为素数,若都是,则为一组解。若N1不是素数,就不必再检查N2是否素数。先从N1=3开始,直到N1=N/2为止。算法流程图如图4-29所示。将程序代码写到窗体的单击事件中。实现上面算法的程序代码如下: 例4.11 编一程序验证哥德巴赫猜想:一个大于Private Sub Form_Click() Dim N%, N1%, N2%, I%, K1%, K2% N=Val(InputBox(输入大于6的偶数) For N1 = 3 To N 2 Step 2 K1 = Int(Sqr(N1) For I = 2 To K1 判断N1是否是素数 If N1 Mod I = 0 Then Exi

温馨提示

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

评论

0/150

提交评论