收藏 分销(赏)

017信息技术vb选修知识点101.pptx

上传人:天**** 文档编号:5433469 上传时间:2024-10-31 格式:PPTX 页数:16 大小:722.99KB
下载 相关 举报
017信息技术vb选修知识点101.pptx_第1页
第1页 / 共16页
017信息技术vb选修知识点101.pptx_第2页
第2页 / 共16页
017信息技术vb选修知识点101.pptx_第3页
第3页 / 共16页
017信息技术vb选修知识点101.pptx_第4页
第4页 / 共16页
017信息技术vb选修知识点101.pptx_第5页
第5页 / 共16页
点击查看更多>>
资源描述

1、实用文案选修知识点(一)计算机解决问题的流程图(二)算法一、算法定义:是解决问题的方法和步骤。算法是程序设计的“灵魂”。算法+数据结构程序。二、算法的描述方法:分自然语言、流程图和伪代码三种。1、自然语言:人们日常生活中的语言(本国语言),用自然语言描述符合我们的习惯,且容易理解。2、流程图:也称程序框图,它是算法的一种图形化表示方法。且描述算法形象、直观,更易理解。3、伪代码:是介于自然语言和计算机程序语言之间的一种算法描述。是专业软件开发人员常用方法。开始、结输入、输出判断连接点处理、运算流程线三、算法的 5 个特征:1、有穷性:执行有限步之后结束,且每一步的执行时间也都是有限的。2、确定

2、性:每一步都有确切的含义。3、可行性:原则上能精确运行,用纸和笔做有限次运算后即可完成。4、输入:有零个或多个输入。5、输出:至少产生一个输出。(三)程序设计基础计算机程序设计语言经历了机器语言、汇编语言、高级语言的发展过程。常用高级语言:BASIC、VB、Pascal、C、C+、Java、Delphi、Fortran、Powerbuilder等。面向对象的程序设计语言,如 vb:其中的对象主要是系统设计好的对象,包括窗体、控件等。控件:是指工具箱中的工具在窗体中画出的能实现一定功能的部件,如标签、文本框、命令按钮等。常用控控件窗体对象的类型Form前缀frmcmdlbltxt名字举例frmf

3、indcmdok件:命令按钮标签CommandLabellblinputtxtClock文本框TextBox若命令按钮(Command)的 Enabled属性设置为 True时按钮有效,设置为 False时按钮无文案大全实用文案对象的三要素:属性、方法、事件属性Name设置对象的名称Font设置控件中字体格式CaptionText决定控件中显示的内容决定窗体中文本框中显示的内容决定控件高度BackColorForeColorTop设置控件背景色设置控件的前景色(即文字颜决定控件与窗体顶部的距离决定控件与窗体左边的距离设置控件的边框风格HeightWidth决定控件宽度LeftVisible设置

4、控件是否可见BorderStyle即标签文字对齐属性:(0)Left Justify时文本左对齐;(1)Right Justify时文本右对齐;设置为(2)Center时文本居中。Alignment对象中属性可以在设计界面时通过属性窗中设置,也可以在运行时通过赋值语句在代码窗口设置:对象名.属性名属性值例:给文本框 Txt123的 Text属性赋值为字符串”20”,代码如下:Txt123.text=“20”注意:如果直接给对象名赋值的话,是赋值给对象的默认属性。例:Txt123=“20”相当于 Txt123.text=“20”都是给文本框 Txt123的 text属性赋值。如果要获取对象的状态

5、或特性,这时就要读取对象的属性值,方法如下:变量名对象名.属性名例:读取文本框“txt123”的“Text”属性的代码如下:a=txt123.text方法常见的方法如下:Print Cls Move Show例:Form1.Print”欢迎使用”格式:对象.方法参数名表事件及事件驱动常见的事件如下:Click、DblClick、KeyPress、Load、MouseUp 等。事件是对象对外部操作的响应,如在程序执行时,单击命令按钮会产生一个 Click事件。如需要命令按钮响应 Click事件,就把完成 Click事件功能的代码写到 Click事件的事件过程中,与事件一一对应。事件过程的形式如下

6、:Private Sub 对象名_事件名()(事件过程代码)End Sub一、常量:指在程序进行过程中不变的量,在 VB中一般分数值常量与字符常量两种数值常量:就是数学中说的常数,分整型常量和实型常量两种整型常量:即整数,指不带小数点的数值如 1、0、-10、+35等都是合法的整数实型常量:即实数,指带小数点的数值。实型常量又分为定点数和浮点数两种。例:定点数:3.14159和-6.8,1.99例:1.234510 可表示为 1.2345E3,字母 E 表示底数 10浮点数就是数学上的科学计数法。浮点数:2E6、1E5、88E3字符串常量:被一对英文双引号括起来的若干个合法的字符称为字符串常量

7、。例如:”China”、”Visual文案大全实用文案Basic”、”18”、”3.1415”等,是指英文双引号中的字符,不包括英文双引号本身。符号常量:如果多次用到同一个常量,则可用一个有意义的名字表示这个常量。二、变量:在程序执行过程中,其值可以改变的量称为变量。变量命名注意要点:1、必须以字母或汉字开头,不能以数字或其他字符开头。2、只能由字母、汉字、数字或下划线组成,不能含有小数点、空格等字符。3、最长不超过 255 个字符4、不能以 VB 保留字作变量名,如语句定义符、函数名(Integer、End、Print、Dim)等。5、VB 不区分变量名中字母大小写。如 HELLO和 Hel

8、lo是同一个变量。三、数据及运算1、常用数据类型:(框选的内容都要熟记)2、常量和变量的命名、声明及赋值(注意:符号常量声明和赋值必须一起完成,变量却必须分 2 句)符号常量的声明和赋值 Const 常量名 As 常量类型=常量值(或 表达式)如:Const pi As Single=3.14159 常量名为 pi注意:常量必须在声明的时候立马赋值,如果没有“=3”部分就是错误的。变量的声明:Dim As 如:Dim a As Integer 定义一个整型变量,变量名为 a变量的赋值 VB中使用“=”给变量赋值,其形式为:变量名=表达式四、运算符1、算术运算符(注意:算术运算符的优先级问题、区

9、分/Mod三个运算符)文案大全实用文案注意:和 mod的运算量如果带小数,要先四舍五入取整,再2、字符串运算符“+”和“&”作用是将运算符两边的字符串连接为一个新的字符串。使用&运算符时应注意前后加空格。注意特例:当数值型和字符型连接时,+把数据都转化成数值型然后相加,返回一个数值型数据。例如:“123”+“45”=“12345”“123”&“45”=“12345”123+“45”=168123&“45”=“12345”3、关系运算符(优先级相同)注意:关系表达式的运算结果为布尔值 True 或 False=等于 大于号 小于号不等于=大于等于号 99,结果为 False。(3)数值型与可转换

10、为数值型的数据,按数值比较。例:29 189,结果为 False。4、逻辑运算符Not(取反)And(与)Or(或)优先级依次降低Not对一个逻辑量进行运算,And 和 Or是对两个逻辑量进行运算,运算结果都为逻辑值 True或 False运算符Not说明 优先级说明举例结果TrueFalseTrue非与或123当操作数为假时,结果为真操作数均为真时,结果才为真Not FalseAndTrue And FalseOr操作数中有一个为真时,结果为真 False Or True5、日期运算符与日期表达式日期表达式是用“+”或“-”将算式表达式、日期型常量、日期型变量、日期函数等连接起来的式子。例如

11、:表达式“#2003/09/01#+30”表达式“#2003/10/20#-#2003/10/10#”的运算结果是“2003-10-1”的运算结果为整数 106、运算符的执行顺序:算术运算符 字符串运算符 关系运算符 逻辑运算符如 a=2:b=3:c=4:d=5 则表达式 a b And 2*a c Or c=d 的值为 True文案大全实用文案7、表达式的写法虽然 VB 中的表达式与代数式中的算式很相似,但两者却是完全不同的概念。要注意区别,如在 VB 中不能使用 等。下表中列出了一些代数式对应的 VB 表达式。代数式VB表达式说明2a b4ab(2*a+b)/(4*a*b)在VB表达式中无

12、法写分式,,乘法运算符*不能省略g*t2/2VB中不能使用上标,指数必须用VB运算符 表示要用VB中的运算符,且不能连续写abca=b And b0 x=0 x0Sgn(x)符号函数Sgn(x)=0-1Sin(x)Cos(x)正弦函数余弦函数Sin(x),x 的单位为弧度Cos(x),x 的单位为弧度Tan(x)正切函数Tan(x),x 的单位为弧度注意:(1)Int(x)是取小于等于x的最大整数。例如:Int(3.12)=3Int(2.1+3)=5Int(-1-2.5)=-4Int(-4.6)=-5(2)Rnd函数产生 0,1)之间的一个随机数,它常与Randomize(以初始化随机数生成器

13、)结合使用,如果要产生 0,A)间的 随机整数,表达式为 Int(Rnd*A)产生 A,B)间的 随机数:产生 A,B 间的 随机整数:Rnd*(B-A)+AInt(Rnd*(B-A+1)+A2、字符串函数(注意的以下字符串函数返回的值 是数值型,还是字符串型。)文案大全实用文案函数功能实例结果6Len(字符串)求字符串的长度(字符个数)Len(2008奥运)Left(2008奥运,4)Left(字符串,n)Mid(字符串,m,n)Mid(字符串,m)Right(字符串,n)String(n,字符串)截取字符串左边n个字符“2008”“08”从字符串第m个字符开始截取n个字符 Mid(2008

14、奥运,3,2)从字符串第m个字符开始截取剩余字符截取字符串右边n个字符Mid(2008奥运,3)Right(2008奥运,2)String(3,89)“08奥运”“奥运”“888”生成指定长度的指定字符的字符串InStr(字符串1,字符串在字符串1中查找字符串2.InStr(2008奥运,奥)52)并返回其出现的位置注意:(1)String函数只返回n个指定的字符串的首字符。(2)Left(字符串,n)和Right(字符串,n)中,当n的值大于字符串的长度时,返回整个字符串。(3)Mid(字符串,m,n)函数中,如果m大于字符串的长度,则返回空串,如果省略n,则返回m开始的全部字符。3、常用转

15、换函数函数功能实例Val(99)+Val(88)Str(5)结果187 5AVal(数值型字符串)Str(数值)将数值型字符串转换为数值将数值转换为字符串Chr(字符代码)Asc(字符)将字符的Asc码转换为对应的字符求字符对应的ASCII码Chr(65)Asc(A)65CInt(表达式)Fix(表达式)将表达式结果作四舍五入处理将表达式结果的小数部分截去CInt(3.6)4Fix(3.8)3注意(1)对于Str(数值)函数,如果其中的数值为正数,则返回的字符串的第一个字符为空格(符号位)。如Str(5)的结果为两个字符长度的字符串 5,如要得到不含符号位的字符串,可使用CStr()函数。(2

16、)CInt(表达式)当表达式的值对应的小数位为.5的时候比较特殊,函数结果为离表达式的值最近的一个偶数。如 CInt(4.5)=4(3)Asc(字符)函数,只求字符中的第一个字符的ASCII码值,如:Asc(AB)=65(4)ASCII码的大小:空格 数值 大写字母 小写字母常用字符的ASCII码值:空格 的ASCII码为:32A 的ASCII码为:650的ASCII码为:48的ASCII码为:97a其他数字和英文字母按序依次类推。(5)字母转换。因大写字母的 ASCII 码比对应的小写字母小 32,所以可通过 Chr 和 Asc 函数互相转换。文案大全实用文案例:a 转 AChr(Asc(a

17、)-32)A 转 a Chr(Asc(A)+32)注意 式子中不能省略4、日期函数(1)Date()、Time()、Now()。这三个函数没有参数,分别返回计算机系统的当前日期、时间、日期与时间。如2011年5月29日,Print Date()或者 Print Date 都会打印出 2011-5-29(2)Year()、Month()、Day()。这三个函数必须有参数,即必须指定一个日期,分别返回指定日期的年、月和日。函数实例结果18Day(#8/18/2008#)Month(#8/18/2008#)Year(#8/18/2008#)820085、定位函数(与 Print语句配合使用的),以控

18、制输出数据的格式,主要包括 Tab、Space等。(l)Tab函数。功能:将被输出的内容放在由参数n所指定的位置(列数)处,在书写时,被输出的内容要放在Tab函数的右面,并用分号分隔。例:Print Tab(15);姓名;Tab(30);成绩(2)Space函数。功能:产生由n个空格所组成的字符串。6、用户交互函数VB 提供 InputBox()和 MsgBox()函数用于人机交互。(1)InputBox()格式:InputBox(提示,标题,默认值,X坐标,Y坐标)功能:在程序中调用InputBox函数,将产生一个提示用户输入内容的输入框,等待用户输入信息,并返回字符串类型的数据。用户要想得

19、到InputBox()函数的返回值,就必须将函数的结果赋值给指定的变量。格式为:变量=InputBox(提示,标题,默认值)注意:每执行一次InputBox()函数,用户只能输入一个数据。输入框的样式是固定的,我们可以改变的是输入框的“提示”和“标题”的内容。例如:r=InputBox(请输入r,输入圆半径)2.MsgBox()格式为:MsgBox(提示信息,按钮,标题)功能:用于在程序运行过程中产生一个消息框,可以看作是输出对话框,该函数的返回值为数值型数据。格式:MsgBox(提示信息,按钮,标题)例如:p=MsgBox(你输入的密码不正确,是否继续?,vbYesNo,错误提示)文案大全实

20、用文案当用户单击消息框中的一个按钮后,消息框即从屏幕上消失。在上面的语句中,将函数的返回值赋给变量P,在程序中可引用P作相应的处理。六、常用语句1、赋值语句格式 1:Let变量=表达式功能:将右边表达式的结果赋给左边变量。通常情况,Let可以省略。=为赋值号。它与数学中的=是不同的。特别要跟方程式区分开。如:X=5即把数值5赋值给变量XY=5 Mod 2+7N=N+1X=Y即先计算表达式5 Mod 2+7 的值,再将值8赋值给变量Y即将N的值加1后后再赋给N即将变量Y的值赋值给变量X也可以在一行内给多个变量赋值,两条语句之间用冒号:隔开,如:s=0:a=l:b=2格式2:对象名.属性名=表达式

21、如:Text1.Text=你好!如果省略属性名,则直接赋值给对象的默认属性。即把字符串 你好!赋给Text l 的Text属性。注意:赋值语句一般都独立成行,如果有类似赋值的语句出现在一些结构中,大家要会辨别。例如跟在以下关键字之后 If x=5 While x=5 Until x=5 Print x=5以上结构中的 x=5 不再是赋值语句,因为 =在这里是个关系运算符,判断左右是否相等,所以x=5 是一个关系表达式,其值应该是个逻辑型,不是True就是False。2、Print语旬格式:对象名.Print 表达式列表功能:Print方法具有计算和输出双重功能。对于表达式,它先计算其值,然后再

22、在指定的对象上输出文本,对于常量、变量则直接输出其值。对象可以是窗体、图片框、打印机等。对象名可以省略,省略时表示在当前窗体上输出数据。说明:(1)表达式列表可以是一个或多个表达式,之间用英文的;或,隔开。如果用逗号分隔,则按标准输出格式输出各数据,此时以14个字符位置为一个区段,逗号后的表达式在下一个区段输出;如果之间用分号分隔,则按紧凑格式输出数据。例:Print 1;2;3;4+3输出结果为:1 2 3 7Print l,2,3,4+3输出结果为:1237(2)如果Print语句末尾没有逗号或分号,表示该Print输出完结果后自动换行,后面再执行Print时将在下一行的起始位置输出数据;

23、如果在Print语句末尾使用逗号,则在同一行上跳到下一个输出区段输出下一个Print所输出的内容。如果在Print语句的末尾加上一个分号,表示下一个Print输出的内文案大全实用文案容将按紧凑格式紧跟在前一个Print所输出的内容后面;(3)当一个Print语句的后面无任何表达式时,则输出一空行或换行。注意:与Tab()函数结合使用,掌握各种图形的输出。3、注释语句为了提高程序的可读性,通常需要在程序的适当位置加上必要的注释。在VB中添加注释语句的方法为在字符 后加注释内容或采用 Rem注释内容 两种形式。格式1:注释内容用 写的注释语句既可以单独写一行,也可以跟在其他语句后。格式2:Rem

24、注释内容用Rem写的注释语句必须单独写一行。4、结束语旬格式:End功能:强制程序结束运行。Private Sub Command1_Click()EndEnd Sub该过程用于结束程序,即单击命令按钮Commandl 时,结束程序的运行。(四)程序设计的三大基本结构一、顺序结构代码按照由上到下的顺序一行一行地执行。程序执行过程中没有分支、没有重复。二、分支结构(选择结构)程序在运行时会根据不同的条件决定程序的走向。实现选择结构的语句有 If语句和 Select语句。1、If语句分为单分支、双分支 和多分支三类。(1)单分支 if结构:(注意:行 if和 块 if 的区别只在书写格式上。)行

25、if语句:IF Then 语句 A块 if语句:IF Then语句 AEnd if(2)双分支 if结构:行 if语句:IF Then 语句 A Else 语句 B块 if语句:IF Then语句 AELSE语句 BEND IF(3)多分支 If 语句 If Then文案大全实用文案 ElseIf Then Else End If2、Select Case 语句Select Case Case 表达式列表 1语句组 1注意:要会区分选择结构和循环结构的流程图。如上图:甲为循环结构,有向上回到条件框的箭头。乙为选择结构(双分支)。Case 表达式列表 2语句组 2Case ELSE语句组 N+1

26、End SelectSelect/Case语句的执行过程是:先求测试表达式的值,然后顺序测试该值符合哪一个Case子句的情况,如果找到了,则直接执行该Case子句下面的语句块,然后执行End Select的后续语句;如果没找到,则执行Case Else下面的语句块,然后执行End Select的后续语句。说明:(1)测试表达式可以是数值型或字符串型表达式。(2)表达式列表形式有以下4种。一个表达式或用逗号隔开的若干表达式,例如2,4,6,8。表达式1 To 表达式2,例如60 To 80。注意,表达式1 应该小于 表达式2 Is关系运算符表达式,例如Is 80。表达式,例如 x+3。三、循环结

27、构1、For-Next循环(适合于解决循环次数事先能够确定的问题。)For循环变量一般形式是:For 循环变量=初值 To 终值 Step 步长值 循环体 Next 循环变量说明:(1)循环变量,必须为数值型。循环初值、循环终值也是数值型或数值表达式。(2)循环的有效区间是由循环初值、循环终值所限定的闭区间。(3)步长值是循环变量的增量,是一个数值表达式。若步长值为正,则初值就应小于终值,否则循环体一次都不执行;若步长值为负,则初值应大于终值,否则循环体一次都不执行。如果步长值是1,Step 1可略去不写。但若步长值为0,会造成死循环,这是要避免的,可用Ctrl+Break 结束程序。(4)循

28、环体是For语句和Next语句之间的语句序列,也是需要重复执行的语句组。文案大全实用文案(5)Next后的循环变量与For语句中的循环变量必须相同。(6)循环的次数=(循环终值-循环初值)步长值+1For/Next循环语句的执行过程:(1)系统将初值赋给循环变量,并自动记下终值和步长。(2)检查循环变量的值是否越过终值。如越过就结束循环,执行Next后面的语句;否则执行一次循环体。(3)执行Next语句:将循环变量增加一个步长值再赋给循环变量,转到第2步继续执行循环。2、DoLoop循环(对于不能预先确定次数,但需要执行多次的情况,可以使用 Do/Loop循环。)格式一:Do While 条件

29、表达式循环体Loop先判断条件是否为真,若条件为真,执行循环体,条件为假时退出循环。因此可能一次都不执行循环。格式二:Do循环体 Loop While 条件表达式先执行一次循环体,再判断条件是否为真,若条件为真,执行循环体,条件为假时退出循环。因此至少执行一次循环体。格式三:Do循环体 Loop Until 条件表达式先执行一次循环体,再判断条件是否为假,若条件为假,执行循环体,条件为真时退出循环。因此至少执行一次循环体。格式四:Do Until 条件表达式 循环体Loop先判断条件是否为假,若条件为假,执行循环体,条件为真时退出循环。因此可能一次都不执行循环。注意:If语句 和 Do语句中都

30、有的条件表达式,一般是一个关系表达式或逻辑表达式,其值不是True就是 False。但如果是数值型的表达式的话,会进行强制转换,即数字 0 转换成 False,非 0 转换成 True。(五)算法与问题解决一、解析法解析法又称公式法。解析法就是在分析具体问题的基础上,抽取出一个数学模型,这个数学模型能用若干个解析表达式表示出来。求解了这些表达式,问题也就得以解决。如:求解一元二次方程a*x2+b*x+c=0的实根dim x1 as double,x2 as doubledim a AS Double,b AS Double,c AS Doubleif b*b-4*a*c=0 then分析:b

31、b2 4acX=2ax1=(-b+sqr(b*b-4*a*c)/(2*a)文案大全实用文案x2=(-b-sqr(b*b-4*a*c)/(2*a)text1.text=str(x1)x1=(-b+sqr(b*b-4*a*c)/(2*a)x2=(-b-sqr(b2-4*a*c)/(2*a)text2.text=str(x2)elseprint“方程无解”end if二、穷举法穷举法是将求解对象一一列举出来,然后逐一加以分析、处理,并验证结果是否满足给定的条件,穷举完所有对象,问题将最终得以解决。穷举法也叫枚举法、列举法。穷举法关键是如何列举所有可能的情况,不能遗漏,也不能重复。注意取值范围,减少计

32、算机工作量。适用编程问题:水仙花问题、鸡兔同笼问题、百钱百鸡问题、素数问题。如:已知公鸡每只3元,母鸡每只5元,每3只小鸡1元。用100元钱买100只鸡,应各买多少只鸡?Dim a As Integer,b As Integer,c As IntegerDim a As Integer,b As IntegerDim c As IntegerFor a=0 to 33For b=0 to 20For c=0 to 100公鸡数母鸡数小鸡数For a=0 to 33For b=0 to 20c=100-a-b公鸡数母鸡数小鸡数If a+b+c=100 and a*3+b*5+c/3=100 th

33、enPrint a;b;cIf a*3+b*5+c/3=100 thenPrint a;b;cend ifNext cNext bNext aend ifNext bNext a三、数组及其应用数组是一组相同类型的变量集合。数组用一个统一的名字代表逻辑上相关的一批数据,每个元素靠下标变量来区分。有一个下标的数组称为一维数组。数组中的数据,逻辑上是相互关联的。1、使用数组要先声明数组的大小和数据类型。声明数组的格式如下:Dim 数组名(最大下标常量)As 数据类型例1:Dim s(9)As Integer表示:名称为s的一维数组中包含10个元素,下标从O到9。用来存放整型数据。也可以指定下标的起

34、始值。例2:Dim x(2 to 10)As Single这个数组含有9个元素,下标从2到10,数据类型属于单精度实型。还可以说明多维数组。例3:Dim D(4,2 To 6,3 To 9)As long说明了一个3维数组,一共5*5*7个数组成员,数据类型属于长整型。2、应注意的问题:(1)在同一个程序中,任何数组只能声明一次。例如:Dim s(5)As Integer文案大全实用文案Dim s(10)As Integer这样,运行时会报错:当前范围内的声明重复。(2)下标必须是常量且为整数(若不是整数,程序运行时自动4舍5入为整数)。(3)同一个程序中,数组名不能与变量名相同。例如:Dim

35、 s As IntegerDim s(10)As Integer这样,运行时会报错:变量与数组不能同名。(4)数组必须先声明后使用否则运行时会报错:子程序或函数未定义。(5)数组使用时,下标不能超出声明的范围。例如:Dim s(10)As IntegerPrint s(11)这样运行时会报错:下标越界。(6)数组声明时和变量一样,要注意类型。例如:Dim s(10)As IntegerS(3)=40000这样运行时会报错:溢出。3、数组的应用数组的赋值、计算、输出通常都与 ForNext 循环结合使用。For 语句中的循环变量作为数组元素的下标,通过循环变量的不断改变,达到对每个数组元素依次进

36、行处理的目的。例子:利用数组实现:输出 10 个1,100的随机数,并输出它们的和与平均值。Dim a(9)As IntegerDim s As Integer数组的定义Randomize将 RND函数随机化For i=0 To 9a(i)=Int(100-1+1)*Rnd)+1Print a(i)s=s+a(i)Next iPrint 和为:;sPrint 平均值为:;s/10四、顺序查找顺序查找是查找算法中简单、易行的算法。进行查找时一般从数据的第一个元素开始,按照数据的顺序查找指定的关键值。如果被查数据和该关键值相匹配,则表示找到;如果所有数据与关键值都不匹配,则表示被查数据中不存在该关

37、键值,查找失败。顺序查找的数据不要求是有序的。五、二分法查找(二分法查找也叫折半查找)二分法查找要求被查数据是有序的查找思路:对于有序数列(从小到大排),设定下界 low(最小元素下标)和上界 high(最大元素下标),当满足条件 lowhigh,则说明找不到。Dim a(9)As IntegerDim mid As Integera(0)=12:a(1)=20:a(2)=27:a(3)=36:a(4)=45:a(5)=50:a(6)=55:a(7)=60:a(8)=79:a(9)=105文案大全实用文案low=0:high=9Do While low highmid=(low+high)2I

38、f a(mid)=55 ThenPrint 找到了Exit Do注意:mid 是中点位置,而 a(mid)是中点位置的值ElseIf a(mid)high Then print 没有 55!六、冒泡排序排序的种类有交换排序、选择排序、快速排序等。“冒泡法排序”也叫“起泡法排序”,是一种比较简单、易懂的交换排序方法。它通过将相邻元素进行比较和交换,逐步将一个无序序列排列为一个有序序列。简单说:就是对相邻数据两两比较,将符合条件的数据冒上来(沉下去),然后用同样的方法再冒泡处理余下的数据,直至全部数据完成排序。(1)标准的从后往前的升序Dim a(9)As IntegerFor i=0 To 9a

39、(i)=Int(100-1+1)*Rnd)+1Print a(i);定义数组给数组的每个元素赋值1,100的随机数并输出Next iFor j=1 To 9For i=9 To j step-1If a(i)a(i+1)Thent=a(i+1)a(i+1)=a(i)a(i)=t将数组中元素从小到大冒泡排序从 a(0)开始比较、交换(大的往后换)外循环控制排序的趟数内循环控制每一趟排序比较的成员和次数End IfNext iNext jFor k=0 To 9Print a(k);Next k显示排序后的数组元素七、递归法1、自定义函数:编程者自己编写的函数。自定义函数定义格式:Function

40、 ()As函数名=返回值End Function自定义函数的调用有三种格式:格式 1:变量=函数名称(参数)格式 2:Call 函数名称(参数)格式 3:函数名称 参数2、递归法 如果一个函数在定义时,直接或间接地调用了自己,这种算法称为递归法。例如函数 A 自己调用了自己。另外如果函数 A 调用了函数 B,函数 B 反过来再调用函数 A 的算法,这也是递归算法。用递归写出的算法往往十分简洁。递归法一般需要自定义函数或过程来实现。例 1:用递归函数求 n!注意 给函数名 s 赋的值,就是该函数的返回结果值。Function s(n As Integer)自定义递归函数的过程分析:5!=5*4!

41、4!=4*3!3!=3*2!2!=2*1!1!=1If n=1 then s=1 Else s=n*s(n-1)End FunctionPrivate Sub Command1_Click()Dim n As Integern!=n*(n-1)!n=Val(InputBox(请输入 N 的值)如果用 s(n)来表示 n!,当 n=1 时,s(n)=?当 n1时,s(n)=?Print s(n)End Sub 调用递归函数例2:求两个自然数,它们的和是667,最小公倍数与最大公约数之比是60:1。分析:设两个自然数中较小的一个为m,显然m=1是不满足条件的,m的取值范围应是2333,那么另外一个

42、就是667-m。处理方法:对m从2到333检查,当bei=yue*60时,输出m与667-m。主程序:Private Sub Form_Click()Dim m As Integer,yue As Integer,bei As IntegerFor m=2 To 333文案大全实用文案yue=gys(m,667-m)bei=gbs(m,667-m)If bei=yue*60 Then Print m,667-mnext mEnd Sub自定义函数gys()求最大公约数Function gys(a As Integer,b As Integer)As Integer Function gbs(a

43、 As Integer,b As Integer)As long自定义函数gbs()求最小公倍数Dim i As IntegerDim i As longFor i=a To 1 Step-1i=bIf(a Mod i=0)And(b Mod i=0)ThenDo While i Mod a 0gys=iExit FunctionEndIfi=i+bLoopgbs=iNext iEnd FunctionEnd Function(六)程序设计思想和方法一、结构化程序设计的思想和方法特点:先整体后局部,先抽象后具体。思想:把一个大的程序按照功能划分为若干个模块,每个小的模块完成一个确定的功能,在这

44、些模块之间按层次关系进行组织,互相协作完成整个程序要完成的功能。方法:自顶向下,先设计第一层(顶层),然后步步深入,逐层细分,逐步求精。二、面向对象程序设计的思想突出特征是:继承性、封装性、多态性。因为实际设计中,用户的需求和软硬件是不断变化的,所以结构化程序设计按功能划分设计的模块必然也是易变的和不稳定的,所以可重用性差。面向对象程序设计以数据为中心,而它相对功能而言,具有较强的稳定性,模块可重用性也比较高。(七)程序中的作图1、画线命令 Line格式:对象名.Line(起点坐标)-(终点坐标),线的颜色格式:对象名.Circle(圆心坐标),半径,颜色例:Form1.Line(-1,-1)-(1,1),vbred2、画圆命令 Circle:3、画点命令 PSet:例:Form1.circle(0,0),3,vbred格式:对象名.PSet(点坐标),颜色例:Form1.Pset(0,0),vbred4、改变坐标系 Scale格式:对象名.Scale(对象左上角坐标)-(对象右下角坐标)例:Form1.Scale(-1.5,-1.5)-(1.5,1.5)文案大全

展开阅读全文
部分上传会员的收益排行 01、路***(¥15400+),02、曲****(¥15300+),
03、wei****016(¥13200+),04、大***流(¥12600+),
05、Fis****915(¥4200+),06、h****i(¥4100+),
07、Q**(¥3400+),08、自******点(¥2400+),
09、h*****x(¥1400+),10、c****e(¥1100+),
11、be*****ha(¥800+),12、13********8(¥800+)。
相似文档                                   自信AI助手自信AI助手
搜索标签

当前位置:首页 > 包罗万象 > 大杂烩

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        获赠5币

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4008-655-100  投诉/维权电话:4009-655-100

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :gzh.png    weibo.png    LOFTER.png 

客服