VB 源码 字符排列组合
VB第三章 顺序结构
返回以e为底,x为指数的幂。 Exp(1)=2.71828182845905
Int(x)
Fix(x)
均为数值类型
均为数值类型
返回不超过x的最大整数
Int(3.5)=3;Int(-3.5)=-4
Round(x)
均为数值类型
Rnd([x])
均为数值类型
若 x 为正数,返回整数部分; Fix (3.5)=3;Fix (-3.5ቤተ መጻሕፍቲ ባይዱ=-3 若x为负,返回数大于或等于x 的第一个负整数。 返回 x 经过四舍五入以后的结 Round(3.5)=4;Round(-3.5)= -4 果。 1. 缺省参数时,随机返回一个0到1之间的小数(包含0不包含1); 2. x<0,每次使用相同随机种子得到相同结果; 3. x>0,产生下一个随机数; 4. x=0,产生最近生成的随机数; 在使用Rnd之前,最好先使用Randomize语句初始化随机数生成器以避 免使用相同种子产生相同随机数列。
3.货币型数据
货币数据类型是为表示钱款而设置的,精确到十数点后4位(小数 点前有15位),在小数点后4位以后的数字将被舍去。它与浮点数的区 别是:浮点数中的小数点是“浮动”的,即小数点可以出现在数的任 何位置,而货币类型数据的小数点是固定的。
4.日期型数据
日期型数据是用来表示日期的,它由年月日及时间(可缺省)按 照一定的排列组成,由一对#号作为定界符。如:#8/24/2001 1:20 PM# 表示2001年8月24日下午1时20分。
1.字符串型数据
字符串是一个由ASCII字符组成的字符序列,在Visual Basic程序中需要用双引号把组成字符串的字符包括起来 例: “南华大学” “Visual Basic”
VB编程序的基本结构
Case 9, 10
Msgbox ("Greater than 8“)
Case Else
Msgbox ("Not between 1 and 10“)
End Select
例:编写程序,当输入X的值后用 Selct Case语句 计算输出Y的值。
Private Sub Button1_Click(ByVal _ sender As System.Object, ByVal e As _ System.EventArgs) Handles _ Button1.Click
InputBox的功能是等待并提示用户为程序运行 输入指定的数据,简称“输入对话框”。
MsgBox的功能是进行提示,用以确认某种程 序的操作,简称“消息框”。
本书目录
6
1. InputBox (输入对话框函数)
输入对话框一般由标题、提示信息、“确定” 按钮、“取消”按钮和一个供用户输入的文本框组 成。当用户将输入信息输入到文本框,并单击“确 定”按钮后,函数返回用户输入的字符串数据。当 单击“取消”按钮时,返回一个空字符串。
语法格式:变量名 = 表达式
功能: 计算赋值号“=”右边表达式的值,然后赋给赋
值号“=”左边的变量。
给变量赋值和设定属性是VB编程中常见的两个任务
如以下语句,
n=n+1
'计数累加
Label1.Text = "欢迎使用VB "
以下语句形式很常用:
• dim sum% , x%
sum=100 : x=5
Select语句举例
Dim Number% Number = Val(InputBox("输入整数"))
vb排列递归,要求输入随机n个数,输出m个数的组合
VB排列递归算法是一种用于处理组合问题的经典算法。
它可以帮助我们在给定一组数的情况下,找出其中任意个数的排列组合。
在使用中,我们可以输入随机n个数,然后利用VB排列递归算法输出m个数的组合。
今天,我们就来详细介绍一下VB排列递归算法的原理和操作步骤。
一、VB排列递归算法的原理1.1 递归算法递归算法是一种常见的解决问题的方法,它是指在函数的定义中使用函数本身的方法。
在VB排列递归算法中,递归的核心思想是将大问题分解为小问题,然后通过递归调用来解决小问题。
1.2 排列组合在数学中,排列和组合是常见的概念。
排列是指从给定的元素中按照一定顺序选取一定数量的元素,而组合是指从给定的元素中选取一定数量的元素,顺序无关紧要。
VB排列递归算法可以帮助我们高效地求解排列和组合的问题。
二、VB排列递归算法的操作步骤现在,我们来介绍一下使用VB排列递归算法求解组合问题的具体操作步骤。
2.1 输入随机n个数我们需要输入一组随机的n个数,这些数可以是整数、小数或者是字符串,根据实际需求而定。
2.2 设置输出m个数的组合接下来,我们需要设置输出m个数的组合,即从输入的n个数中选取m个数进行组合。
2.3 编写VB排列递归算法在VB编程环境中,我们需要编写排列递归算法的具体代码。
这部分代码主要涉及递归函数的定义和递归调用的实现,通过递归的方式来实现排列组合的求解。
2.4 执行VB排列递归算法一切准备就绪后,我们可以执行VB排列递归算法,得到输出m 个数的组合结果。
这些组合结果可以是打印输出、保存到文件或者在界面中展示,根据实际需求进行选择。
三、VB排列递归算法的应用实例现在,我们通过一个具体的示例来演示VB排列递归算法的应用过程。
3.1 示例说明假设我们有一组数字{1, 2, 3, 4, 5},我们需要从中选取3个数字进行组合,那么该怎么做呢?接下来,我们就通过VB排列递归算法来解决这个问题。
3.2 操作步骤我们需要输入数字{1, 2, 3, 4, 5},然后设置输出3个数字的组合。
vba递归 排列组合
vba递归排列组合在VBA中,递归排列组合可以通过以下步骤实现:1. 定义一个函数,接收两个参数:一个是待排列的元素列表,另一个是当前已选择的元素列表。
2. 如果待排列的元素列表为空,说明已经选择了所有元素,此时将当前已选择的元素列表添加到结果列表中。
3. 如果待排列的元素列表不为空,遍历其每个元素,将其从待排列的元素列表中移除,然后将其添加到已选择的元素列表中,再调用该函数进行递归。
4. 最后返回结果列表。
以下是具体的VBA代码实现:vbaFunction Permutation(arr() As Variant, cur() As Variant) As CollectionDim i As Long, j As Long, n As LongDim result As New CollectionDim temp() As Variantn = UBound(arr) - LBound(arr) + 1temp = arr: ReDim Preserve temp(UBound(temp) + 1)If UBound(cur) < n - 1 ThenFor i = LBound(arr) To UBound(arr)If Not IsInArray(arr(i), cur) Thentemp(UBound(temp)) = arr(i)Permutation = Permutation(temp, cur)ReDim Preserve Permutation(UBound(Permutation) + 1)End IfNext iElseresult.Add cur()End IfReturn resultEnd FunctionFunction IsInArray(value As Variant, arr() As Variant) As BooleanDim i As LongFor i = LBound(arr) To UBound(arr)If arr(i) = value ThenIsInArray = TrueExit FunctionEnd IfNext iIsInArray = FalseEnd Function使用示例:vbaSub Test()Dim arr() As VariantDim perm() As VariantDim result As CollectionDim i As Longarr = Array(1, 2, 3)result = Permutation(arr, perm)For i = LBound(result) To UBound(result) Debug.Print Join(result(i), ", ")Next iEnd Sub这个示例将会输出数组{1, 2, 3}的所有排列组合。
VB编码规范
VB编码规范IDE设置必须打开设置选项的‚要求变量声明‛,‚对齐控件到网格‛,‚自动缩进‛开关。
Tab的宽度统一为4个空格,网格单位一律设为:width 50 height 50。
命名工程EXE工程直接命名,如果是通用组件工程,直接命名,如果是项目或产品工程,则使用项目或产品缩写作为前缀。
如:GFDY….Lib。
工程命名不必缩写,为了表达意思和用途,可以尽可能地长,而且命名格式采用(名词)、(形容词 + 名词)或(名词 + 动作的名词形式)。
如:GFDYStockOperationLib或GFDYStockLib。
注意:在任何时候,不要使用中文命名,包括文件夹,文件名,函数名,变量名。
变量变量命名不推荐采用匈牙利命名法,除非命名会和关键字产生冲突的时候,才采用类型缩写+变量实名的匈牙利命名法。
一般情况下,变量命名应该简单,尽量使用缩写。
如果是一般的值类型,如integer string,则直接使用变量用途命名,尽量使用全名:Dim name As StringDim count As Interger对于一般的临时性变量定义,应该尽可能地简单,如:Dim i As IntegerFor i = 0 to 100…Next I如果是类对象或自定义类型对象,则在单一使用情况下使用类名称或自定义类型名称的简写来命名:Dim em As EnityManager如果非单一使用,则使用类型名称缩写为前缀,即使用匈牙利命名法:Dim emRead As EntityManagerDim emSave As EntityManager注意:所有前缀都全部小写,后面的单词首字母大写)缩写规则如下:如果名称由多个单词组成,则取每个单词的首字母,如EntityManager缩写为em,ProcedureManager缩写为pm。
如果名称由一个单词组成,则对单词进行分段取首字母,如Entity缩写为et。
缩写应该控制在3个字母以内,尽量清晰,对于接口名称,I……中的I前缀不对缩写产生任何影响,如Ientity的名称应视作Entity。
vb、vc编码规范
VB、VC编码规范目录1.VB 部分 (3)1.1.控件前缀 (3)1.2.数据访问对象(DAO)前缀 (5)1.3.菜单前缀 (5)1.4.其它控件前缀 (6)1.5.变量、常量范围前缀 (6)1.6.变量、常量类型前缀 (6)1.7.描述变量和过程名 (7)1.8.用户定义的类型 (7)1.9.代码注释约定 (7)1.10.窗体隐含全局变量 (9)1.11.命名属性、方法和事件 (9)1.12.常数使用 (9)1.13.MsgBox书写要求 (9)1.14.SQL语句书写要求 (10)1.15.源程序编排 (10)1.16.源文件命名 (11)1.17.资源ID (11)2.VC部分 (12)2.1.C++类的定义形式约定表 (12)2.2.头文件的书写顺序约定表 (12)2.3.源文件的书写顺序约定表 (12)2.4.标识符命名约定表 (13)2.5.函数头说明规范 (13)2.6.修改申明 (13)3.窗体和控件的取名:详见命名标准 (14)4.显式声明变量 (14)5.为便于阅读程序,禁止使用VB的“字符串和数字的自动转化功能” (14)6.在程序中禁止使用END语句 (15)7.为增强可读性,不得使用控件值 (15)8.修改代码注释: (15)在原来有错误的代码前先列出,修改人,修改原因,修改日期;注释原代码,写出新代码,写出新代码结束标志 (15)1.VB 部分1.1.控件前缀1.2.数据访问对象(DAO)前缀1.3.菜单前缀菜单控件除了最前面 "mnu" 标记以外,菜单控件的前缀应该被扩展:对每一级嵌套增加一个附加前缀,将最终的菜单的标题放在名称字符串的最后。
下表列出了一些例子。
当使用这种命名约定时,一个特定的菜单组的所有成员一个接一个地列在Visual Basic 的“属性”窗口中。
而且,菜单控件的名字清楚地表示出它们所属的菜单项。
1.4.其它控件前缀对于上面没有列出的控件,应该用唯一的由两个或三个字符组成的前缀使它们标准化,以保持一致性。
VB对数字字符数组的快速排序.查找(转)
VB对数字字符数组的快速排序.查找(转)数值与数组操作'Option Explicit'''数值快速排序(从小到大)'函数:NumSortAZ'参数:Myarray Double数组,L 数组的左边界,R 数组右边界. '返回值:无'例子:Public Sub NumSortAZ(ByRef Myarray, l As Long, R As Long)Dim I As Long, J As Long, A As LongDim TmpX As Variant, TmpA As VariantI = l: J = R: TmpX = Myarray((l + R) / 2)While (I <= J)While (Myarray(I) < TmpX And I < R)I = I + 1WendWhile (TmpX < Myarray(J) And J > l)J = J - 1WendIf (I <= J) ThenTmpA = Myarray(I)Myarray(I) = Myarray(J)Myarray(J) = TmpAI = I + 1: J = J - 1End IfWendIf (l < J) Then Call NumSortAZ(Myarray, l, J)If (I < R) Then Call NumSortAZ(Myarray, I, R)End Sub''数值快速排序(从大到小)'函数:NumSortZA'参数:Myarray Double数组,L 数组的左边界,R 数组右边界. '返回值:无'例子:Public Sub NumSortZA(ByRef Myarray, l As Long, R As Long)Dim I As Long, J As Long, A As LongDim LT As Long, RT As LongDim TmpX As Variant, TmpA As VariantI = l: J = R: TmpX = Myarray((l + R) / 2)While (I <= J)While (Myarray(I) > TmpX And I < R)I = I + 1WendWhile (TmpX > Myarray(J) And J > l)J = J - 1WendIf (I <= J) ThenTmpA = Myarray(I)Myarray(I) = Myarray(J)Myarray(J) = TmpAI = I + 1: J = J - 1End IfWendIf (l < J) Then Call NumSortZA(Myarray, l, J)If (I < R) Then Call NumSortZA(Myarray, I, R)End Sub''字符串快速排序(从大到小)'函数:StrSortZA'参数:sArr String数组,L 数组的左边界,R 数组右边界.'返回值:无'例子:Public Sub StrSortZA(ByRef sArr() As String, First As Long, Last As Long)Dim vSplit As String, vT As StringDim I As Long, J As Long, iRand As LongIf First < Last ThenIf Last - First = 1 ThenIf sArr(First) < sArr(Last) ThenvT = sArr(First): sArr(First) = sArr(Last): sArr(Last) = vTEnd IfElseiRand = Int(First + (Rnd * (Last - First + 1)))vT = sArr(Last): sArr(Last) = sArr(iRand): sArr(iRand) = vTvSplit = sArr(Last)DoI = First: J = LastDo While (I < J) And (sArr(I) >= vSplit)I = I + 1LoopDo While (J > I) And (sArr(J) <= vSplit)J = J - 1LoopIf I < J ThenvT = sArr(I): sArr(I) = sArr(J): sArr(J) = vTEnd IfLoop While I < JvT = sArr(I): sArr(I) = sArr(Last): sArr(Last) =vTIf (I - First) < (Last - I) ThenStrSortZA sArr(), First, I - 1StrSortZA sArr(), I + 1, LastElseStrSortZA sArr(), I + 1, LastStrSortZA sArr(), First, I - 1End IfEnd IfEnd IfEnd Sub''字符串快速排序(从小到大)'函数:StrSortAZ'参数:sArr String数组,First 数组的左边界,Last 数组右边界.'返回值:无'例子:Public Sub StrSortAZ(ByRef sArr() As String, First As Long, Last As Long)Dim vSplit As String, vT As StringDim I As Long, J As Long, iRand As LongIf First < Last ThenIf Last - First = 1 ThenIf sArr(First) > sArr(Last) ThenvT = sArr(First): sArr(First) = sArr(Last): sArr(Last) = vTEnd IfElseiRand = Int(First + (Rnd * (Last - First + 1)))vT = sArr(Last): sArr(Last) = sArr(iRand): sArr(iRand) = vTvSplit = sArr(Last)DoI = First: J = LastDo While (I < J) And (sArr(I) <= vSplit)I = I + 1LoopDo While (J > I) And (sArr(J) >= vSplit)J = J - 1LoopIf I < J ThenvT = sArr(I): sArr(I) = sArr(J): sArr(J) = vTEnd IfLoop While I < JvT = sArr(I): sArr(I) = sArr(Last): sArr(Last) = vTIf (I - First) < (Last - I) ThenStrSortAZ sArr(), First, I - 1StrSortAZ sArr(), I + 1, LastElseStrSortAZ sArr(), I + 1, LastStrSortAZ sArr(), First, I - 1End IfEnd IfEnd IfEnd Sub''有序数的快速查找(A->Z),非递归法'函数:NumFind'参数:Myarray Double数组,L 数组的左边界,R 数组右边界.FNumber 要查找的数据.'返回值:找到,则返回下标,否则,返回-1'例子:Public Function NumFind(ByRef Myarray, FNumber As Variant) As LongDim K As Long, I As LongDim L1 As Long, R1 As LongDim l As Long, R As Longl = LBound(Myarray): R = UBound(Myarray)NextLoop:K = (l + R) Mod 2If K = 1 Then '中点I = (l + R + 1) / 2ElseI = (l + R) / 2End IfIf Myarray(I) <> FNumber Then If Myarray(I) > FNumber ThenL1 = l: R1 = IElseL1 = I: R1 = REnd IfIf (R1 - L1) = 1 Then '第一个和最后一个If Myarray(L1) = FNumber ThenNumFind = L1ElseIf Myarray(R1) = FNumber Then NumFind = R1ElseNumFind = -1 '没有发现End IfElsel = L1: R = R1GoTo NextLoopEnd IfElseNumFind = IEnd IfEnd Function''有序字符串的快速查找,非递归法'函数:StrFind'参数:Myarray String数组,L 数组的左边界,R 数组右边界.Fstr 要查找的字符串.'返回值:找到,则返回下标,否则,返回-1'例子:Public Function StrFind(ByRef Myarray() As String, l As Long, R As Long, Fstr As String) As LongDim K As Long, I As LongDim L1 As Long, R1 As LongNextLoop:K = (l + R) Mod 2If K = 0 ThenIf Myarray(0) = Fstr ThenStrFind = 0ElseStrFind = -1End IfExit FunctionEnd IfIf K = 1 Then '中点I = (l + R + 1) / 2ElseI = (l + R) / 2End IfIf Myarray(I) <> Fstr ThenIf Myarray(I) > Fstr ThenL1 = l: R1 = IElseL1 = I: R1 = REnd IfIf (R1 - L1) = 1 Then '第一个和最后一个If Myarray(L1) = Fstr ThenStrFind = L1ElseIf Myarray(R1) = Fstr ThenStrFind = R1ElseStrFind = -1 '没有发现End IfElsel = L1: R = R1GoTo NextLoopEnd IfElseStrFind = IEnd IfEnd FunctionPrivate Sub Class_Initialize()Dim T As New ClsRevCall T.GetIniValSet T = NothingEnd Sub''数组是否已经初始化.'函数:ArrEmpty'参数:MyArr 数组名称.'返回值:TRUE 已经初始化,FALSE 未初始化.'例子:Public Function ArrEmpty(ByRef MyArr) As Boolean Dim K As LongOn Error Resume NextK = UBound(MyArr)ArrEmpty = (Err.Number = 0)Err.ClearEnd Function'.'数组的某个数组ID是否存在.'函数:ArrBeing'参数:MyArr 数组名称.ID 数组下标.'返回值:TRUE 存在,FALSE 不存在.'例子:Public Function ArrBeing(ByRef MyArr, id As Long) As BooleanDim K As VariantOn Error Resume NextK = MyArr(id)ArrBeing = (Err.Number = 0)Err.ClearEnd Function''计算用户输入的表达式'函数:MathCal'参数:CalStr 一个数学表达式,如:23*45/9'返回值:String,(如果成功,则返回计算结果,错误则返回"0") '例子:Public Function MathCal(CalStr As String) As String Dim Mscr As New ScriptControlDim ReVal As StringOn Error Resume Nextnguage = "VBScript"ReVal = Mscr.Eval(CalStr)If Err.Number = 0 ThenMathCal = ReValElseMathCal = 0End IfSet Mscr = NothingEnd Function''取某年某月的从周第日期'函数:timeMweekDate'参数:sYear 年,sMonth 月,sWeek 从第周开始, eWeek从第周结束'返回值:Date 数组.(0) 开始日期,(1) 结束日期'例子: Dim T() As Date' T = timeMweekDate(2004, 1, 1, 4)' Text1 = T(0) & ":" & T(1)Private Function timeMweekDate(sYear As Long, sMonth As Long, sWeek As Long, eWeek As Long) As Date() Dim StarDate As DateDim EndDate As DateDim NextDate As DateDim TmpDate As DateDim DltDate As DateDim RetuVal(1) As DateDim DateArr(10, 1) As Date '保存各周的开始结束日期.Dim Wid As LongDim A As LongStarDate = sYear & "/" & sMonth & "/1" '今月开始的日期.NextDate = DateAdd("M", 1, StarDate) '下月开始日期.EndDate = DateAdd("D", -1, NextDate) '今月月未日期.DltDate = StarDateWhile DltDate <= EndDateIf DltDate = StarDate Or DltDate = EndDate Or Weekday(DltDate) = 1 ThenDateArr(Wid, 0) = DltDateEnd IfIf DltDate = EndDate Or Weekday(DltDate)= 7 ThenDateArr(Wid, 1) = DltDateWid = Wid + 1End IfDltDate = DateAdd("d", 1, DltDate)WendIf eWeek > Wid Then eWeek = Wid '如果超出本范围,则以月底计算RetuVal(0) = DateArr(sWeek - 1, 0)RetuVal(1) = DateArr(eWeek - 1, 1)timeMweekDate = RetuValEnd Function。
VB_编码规则范文
VB_编码规则范文VB编码规则是为了确保VB代码的一致性、可读性和可维护性而制定的一系列准则。
以下是一些常见且重要的VB编码规则。
命名规则:1.使用有意义的命名:变量、函数和过程等的命名要具有描述性,能清晰地表达其功能和用途。
2. 使用有意义的前缀:使用具有描述性的前缀来标识变量的类型,如使用"int"表示整型变量。
3.避免使用缩写:尽量避免使用缩写或缩写的单词,以提高代码的可读性和可理解性。
4.保持命名一致性:保持命名的一致性,例如使用驼峰命名法或下划线命名法,并在整个代码中保持一致。
代码布局和格式:1.使用适当的缩进:使用适当的缩进,使代码的结构清晰可读。
2.使用空格和空行:在代码之间使用适当的空格和空行,以提高代码的可读性。
3.注释代码:为代码添加注释,解释其功能和用途,以便其他人能够理解和维护代码。
4.使用合适的代码折行:在代码过长时使用适当的折行,使每一行的代码长度适中,提高可读性。
规范和最佳实践:1. 使用明确的错误处理:在代码中使用适当的错误处理机制,如使用Try-Catch语句来捕获异常。
2.避免使用全局变量:尽量避免使用全局变量,减少变量的作用域,提高代码的可维护性。
3.优化性能:合理使用循环、条件语句和函数调用,提高代码的性能。
4.遵循单一职责原则:每个过程和函数都应该有单一的责任,并遵循单一职责原则。
以上只是VB编码规则的一部分,具体的编码规则还需要根据项目的实际情况和团队的约定来制定。
编码规则的遵循可以提高代码的质量,减少错误和Bug,并提高代码的可读性和可维护性,使代码更易于理解和修改。
vb排列递归算法,要求输入随机n个数,输出m个数的组合
在中,你可以使用递归算法生成排列的组合。下面是一个简单的示例代码,用于输入n个数,输出m个数的所有组合:
Module
Sub
'输入随机n个数
DimAsInteger
'输入m,表示要生成m个数的组合
DimAsInteger
'用于存储生成的组合
DimAs
'调用递归函数生成组合
End Sub
SubAsIntegerAsIntegerAsIntegerAsIntegerAsInteger
'如果已经选择了m个数,输出组合并返回
If
End If
'从startIndex开始选择数字
ForAsIntegerTo
'选择当前数字
'递归调用,选择下一个数字
Next
End Sub
SubAsInteger
'输出组合
ForAsInteger
" "
Next
End Sub
End Module
这个例子中,GenerateCombinations是递归函数,它通过选择数字的方式生成所有可能的组合。Print
vb各种排序算法
vb各种排序算法'此文飞本人原创具体出处未知Option ExplicitDim Sums(9999) As Long, Sumb(9999) As Long '生成数据数量可自己设置Private blnSort As Boolean '排序方向Private Declare Function SendMessageFind Lib "User32" Alias "SendMessageA" (ByVal hWnd As Long, ByVal wmsg As Long, ByVal wparam As Integer, ByVal lparam As String) As Long Private Declare Function timeGetTime Lib "winmm.dll" () As LongDim T As LongPrivate Sub Command1_Click()Dim i As Long, z As Long, j As LongList1.ClearDoEventsList1.Visible = FalseFor i = 0 To UBound(Sums)nn:Randomizez = 99999 * Rnd + 9j = SendMessageFind(List1.hWnd, &H18F, 0, z)If j > -1 ThenGoTo nnElseSums(i) = zSumb(i) = zList1.AddItem Sums(i)End IfNextList1.Visible = TrueMe.Caption = "共产生数据:" & UBound(Sums) + 1 & " 项"End SubPrivate Sub Command2_Click()Dim ti As Integer, i As LongList2.ClearDoEventsFor i = 0 To UBound(Sumb)Sums(i) = Sumb(i)NextblnSort = Option1(0).ValueT = timeGetTimeIf Option2(0).Value = True ThenCall mpsort(Sums) '冒泡排序ti = 0End IfIf Option2(1).Value = True ThenCall insort(Sums) '插入排序ti = 1End IfIf Option2(2).Value = True ThenCall QuickSort(LBound(Sums), UBound(Sums)) '快速排序ti = 2End IfIf Option2(3).Value = True ThenCall selctsort(Sums) '选择排序ti = 3End IfIf Option2(4).Value = True ThenCall hirsort(Sums) '希尔排序ti = 4End IfIf Option2(5).Value = True ThenCall duisort(Sums) '堆排序ti = 5End IfIf Option2(6).Value = True ThenCall nsort(Sums) '打乱次序ti = 6End IfLabel1(ti).Caption = timeGetTime - TList2.Visible = FalseDoEventsFor i = 0 To UBound(Sums)List2.AddItem Sums(i)NextList2.Visible = TrueMe.Caption = "成功对:" & UBound(Sums) + 1 & " 项数据进行了排序,用时: " & Label1(ti).Caption & " 毫秒"Exit SubEnd SubPrivate Sub Command3_Click()List1.ClearList2.ClearMe.Caption = "六种排序"End SubPrivate Sub nsort(ByRef arrtosort() As Long)Dim i As Long, j As Long, tmp As LongFor i = LBound(arrtosort) To UBound(arrtosort)j = (UBound(arrtosort) - i) * Rnd + iIf i <> j Thentmp = arrtosort(i)arrtosort(i) = arrtosort(j)arrtosort(j) = tmpEnd IfNext iEnd SubPrivate Sub mpsort(ByRef arrtosort() As Long) '冒泡排序'经过n-1趟子排序完成的,它的时间复杂度为O(n^2)'优点:1.“编程复杂度”很低,很容易写出代码;2.具有稳定性Dim i As Long, j As Long, M As Long, tmp As LongM = UBound(arrtosort) 'm 等于数组上标Do While M '至m等于数组下标j = M - 1M = 0If blnSort ThenFor i = 0 To jIf arrtosort(i) > arrtosort(i + 1) Then '找到后者大于前者地数tmp = arrtosort(i) '两者互换arrtosort(i) = arrtosort(i + 1)arrtosort(i + 1) = tmpM = i '从该位置开始继续查找End IfNext iElseFor i = 0 To jIf arrtosort(i) < arrtosort(i + 1) Thentmp = arrtosort(i)arrtosort(i) = arrtosort(i + 1)arrtosort(i + 1) = tmpM = iEnd IfNext iEnd IfLoopEnd SubPrivate Sub insort(ByRef arrtosort() As Long) '插入排序'插入排序的基本操作就是将一个数据插入到已经排好序的有序数据中,从而得到一个新的、个数加一的有序数据'算法适用于少量数据的排序,时间复杂度为O(n^2)。
vb选择排序和冒泡排序的代码
vb选择排序和冒泡排序的代码在计算机科学和程序设计语言中,选择排序和冒泡排序是两个最基本、最常用的排序算法。
虽然它们不一定是最有效率的排序算法,但它们非常简单易懂,适合初学者使用和理解。
下面我们将分步骤介绍VB选择排序和冒泡排序的代码。
VB选择排序:步骤1:定义一个数组,用于存放需要排序的元素。
Dim arr(10) As Integer步骤2:输入数据。
For i = 1 To 10arr(i) = Val(InputBox("Please enter a number"))Next步骤3:定义一个选择排序的函数。
Sub selectionSort(ByVal arr As Variant)Dim i As IntegerDim j As IntegerDim minIndex As IntegerDim temp As IntegerFor i = 1 To UBound(arr) - 1minIndex = iFor j = i + 1 To UBound(arr)If arr(j) < arr(minIndex) ThenminIndex = jEnd IfNexttemp = arr(i)arr(i) = arr(minIndex)arr(minIndex) = tempNextEnd Sub步骤4:调用选择排序函数。
selectionSort arr步骤5:输出排序后的数据。
For i = 1 To 10Print arr(i)NextVB冒泡排序:步骤1:定义一个数组,用于存放需要排序的元素。
Dim arr(10) As Integer步骤2:输入数据。
For i = 1 To 10arr(i) = Val(InputBox("Please enter a number")) Next步骤3:定义一个冒泡排序的函数。
Sub bubbleSort(ByVal arr As Variant)Dim i As IntegerDim j As IntegerDim temp As IntegerFor i = UBound(arr) To 2 Step -1For j = 1 To i - 1If arr(j) > arr(j + 1) Thentemp = arr(j)arr(j) = arr(j + 1)arr(j + 1) = tempEnd IfNextNextEnd Sub步骤4:调用冒泡排序函数。
vba穷举排列组合
在VBA中,你可以使用递归函数来穷举排列组合。
以下是一个示例代码,它使用递归函数来穷举给定集合的所有排列组合:vba复制代码Function Permutations(arr() As Variant, Optional l As Long = 1, Optional i As Long = 1) As VariantDim result As VariantReDim result(1 To l)Dim temp As Varianttemp = Application.WorksheetFunction.Transpose(arr)For j = 1 To i - 1result(j) = temp(i - j + 1)Next jIf i = UBound(arr) + 1 Thenresult(i) = ""Elseresult = Permutations(arr, l + 1, i + 1)End IfPermutations = resultEnd Function这个函数使用了一个名为Permutations的递归函数,它接受一个数组arr和一个可选的参数l和i。
l 表示当前排列的长度,i表示当前正在考虑的元素索引。
默认情况下,l为1,i为1。
在函数内部,我们首先创建一个名为result的数组,其大小与当前排列的长度相同。
然后,我们将当前正在考虑的元素添加到结果数组中。
接下来,我们检查是否已经考虑了所有元素。
如果是,则将一个空字符串添加到结果数组中。
否则,我们递归调用Permutations函数,以考虑下一个元素。
最后,我们返回结果数组。
要使用此函数,你需要将你的数组传递给函数,并指定排列的长度。
例如,如果你有一个包含三个元素的数组arr,你可以使用以下代码来获取所有长度为2的排列:vba复制代码Dim perms As Variantperms = Permutations(arr, 2)这将返回一个二维数组,其中包含所有长度为2的排列。
VB_编码规则
编码规则VB的语言元素(一)字符集程序由语句构成;语句由表达式、单词构成;表达式和单词由字符组成;程序语言中,字符、词汇、表达式、语句、过程、函数被称为“语法单位”。
语法的形成规则称为“语法规则”。
字符是构成程序设计语言的最小单位。
VB的字符集包括:数字,英文字母和特殊符号。
数字:0 - - - 9英文字母:26个英文字母的大小写a - - - z和A - - - Z特殊字符:! # $ % & @ 八'()* + ,-.八? < = > [ ] _ {} ~ : ;〃space注:在代码窗口输入程序时,除汉字外,其余符号不能以全角或中文方式输入,而只能以英文方式键入作为语言成分的字符。
例如:Print “x*y= ”;x*y(二)词汇集词汇符号是程序设计语言中具有独立意义的最基本结构。
词汇符号包括:运算符、界符、关键字、标识符、各类型常数。
1.运算符和界符算术运算符:+ - * / \ MOD八字符运算符:& +比较运算符:> >= < <= = <>逻辑运算符:NOT AND OR XOR EQV IMP其他界符:!#$% @( ),.'?[]_{ }丨〜:;〃space2.关键字又称保留字,是VB保留下来的作为程序中有固定含义的标识符,不能被重新定义,是语言的组成部分,往往表示系统提供的标准过程、函数、运算符、常量等。
在VB中,约定关键字的首个字母为大写。
VB中的关键字详见表3-18:表3-18 VB的关键字AsBinaryByRefByValDateElseEmptyErrorFalseForFriendGetInputIsLenLetLockMe MidNewNextNothingNullOnOptionOptionalParamArrayPrintPrivatePropertyPublicRe sumeSeekSetStaticStepStringThenTimeToTrueWithEvents3.标识符标识符是程序员为变量、常量、数据类型、过程、函数、类等定义的名字。
VB常用算法6排序
VB常用算法----排序1、选择法排序(1) 利用循环从n个数中选出最小数的下标,结束循环后,将最小数与第一个数交换位置;(2) 除第一个数外,在剩下的n-1个数中再按方法(1)选出次小的数,与第二个数交换位置;(3) 以此类推,最后构成递增序列。
譬如:8 6 9 3 2 7第一轮交换后 2 6 9 3 8 7第二轮交换后 2 3 9 6 8 7第三轮交换后 2 3 6 9 8 7第四轮交换后 2 3 6 7 8 9第五轮无交换 2 3 6 7 8 9程序代码如下:Private Sub xzPaiXu(a() As Double, sheng As Boolean)'a为需要排序的数组,sheng为True则为升序排列,为False,则为降序排列。
Dim i As Integer, j As IntegerDim temp As DoubleDim m As IntegerFor i = LBound(a) To UBound(a) - 1 '进行数组大小-1轮比较m = i '在第i轮比较时,假定第'i个元素为最值元素For j = i + 1 To UBound(a) '在剩下的元素中找出最'值元素的下标并记录在m中If sheng Then '若为升序,则m记录最小元素'下标,否则记录最大元素下标If a(j) < a(m) Then m = jElseIf a(j) > a(m) Then m = jEnd IfNext j '将最值元素与第i个元素交换temp = a(i)a(i) = a(m)a(m) = tempNext iEnd Sub调用该过程示例:Option Base 1Private Sub Command1_Click()Dim b(6) As Doubleb(1) = 8b(2) = 6b(3) = 9b(4) = 3b(5) = 2b(6) = 7Call xzPaiXu(b, True)For i% = 1 To 6Print b(i)NextEnd Sub2、冒泡法排序选择排序法在每一轮排序时寻找最值元素的下标,出了内循环(一轮排序结束时,确定最值下标),再交换最小数的位置;而冒泡法在每一轮排序时将相邻的数比较,当次序不对时就立即..交换..位置,出了内循环,最值数已经冒出。
VB-源码--字符排列组合
效果图编程界面所有源码Option ExplicitPrivate newStr As String, tempNewStr As String, cont As Long Private Sub Command1_Click()Text1.Enabled = FalseRichTextBox1.Enabled = FalseRichTextBox1.Text = ""Dim tempStr As StringtempStr = Trim(Text1.Text)newStr = "": tempNewStr = ""cont = 0If Check1.Value = 0 Then GetStr tempStrIf Check1.Value = 1 Then GetStr2 tempStr, ""RichTextBox1.Text = newStrFrame1.Caption = "总个数:" & contText1.Enabled = TrueRichTextBox1.Enabled = TrueRichTextBox1.FindEnd SubPrivate Sub Text1_Change()RichTextBox1.Text = ""Frame1.Caption = "总个数:"End SubPrivate Function GetStr(ByVal str1 As String) As Stringstr1 = Trim(str1)If str1 = "" Then Exit FunctionDim i As Integer, tempStr As String, tempChr As String, tempLen As Integer Dim mytempStr As StringmytempStr = tempNewStrFor i = 1 To Len(str1)DoEventstempChr = ""tempChr = Mid(str1, i, 1) '取一个字符tempNewStr = tempNewStr & tempChr '单组组合tempStr = Left(str1, i - 1) & Right(str1, Len(str1) - i) '剩余新字符If Len(tempStr) > 1 ThenGetStr tempStrElsenewStr = newStr & tempNewStr & tempStr & IIf((cont + 1) Mod 200 = 0, Chr(13), Chr(9)) '终组组合cont = cont + 1Frame1.Caption = "执行中:" & contEnd IftempNewStr = mytempStrNextEnd FunctionPrivate Function GetStr2(ByVal str1 As String, ByVal str2 As String) As String Dim tempStr As StringDim i As IntegerFor i = 1 To Len(str1)DoEventsIf Len(str2) + 1 = Len(str1) ThennewStr = newStr & str2 & Mid(str1, i, 1) & IIf((cont + 1) Mod 200 = 0, Chr(13), Chr(9))cont = cont + 1Frame1.Caption = "执行中:" & contElseGetStr2 str1, str2 & Mid(str1, i, 1)End IfNextEnd Function(注:可编辑下载,若有不当之处,请指正,谢谢!)。
组合数不重复vb代码
组合数不重复vb代码组合数不重复是一种常见的算法问题,通常用于解决排列组合、概率统计等问题。
在VB语言中,可以通过编写相应代码实现组合数不重复。
具体实现步骤可以如下:1.首先定义数组,用于存储组合数结果。
例如,定义数组Comb(100,100)表示最大组合数为100C100。
2.编写一个函数CalcComb(n,m),其中n表示总数,m表示需要选出的数目。
函数的返回值是组合数。
在函数中,可以使用递归算法,通过计算组合数并将结果存储在数组Comb中。
3.运用此函数可以求解任意两个数的组合数,例如求6个数中选3个数的组合数可以写成Comb(6,3)。
4.为了保证计算的结果不重复,可以使用一个布尔型的数组used,记录每个元素是否被使用过。
在递归调用函数时,将已经使用过的元素标记为true,以保证组合数不重复。
以下为VB语言中的实现代码:Option ExplicitConst MAXINT64 = 18446744073709551615#Private m_Comb() As DoubleDim m_used() As BooleanPrivate m_uN As LongPrivate m_uR As LongPublic Function CalcComb(ByVal n As Long, ByVal r As Long) As DoubleDim i As Long, j As LongIf n < r Or r < 0 Or n < 0 ThenCalcComb = 0Exit FunctionEnd IfIf n + r > m_uN + m_uR ThenCalcComb = MAXINT64Exit FunctionEnd IfIf r > n / 2 Then r = n - rIf r = 0 ThenCalcComb = 1Exit FunctionEnd IfIf m_uN <> n Or m_uR <> r ThenReDim m_Comb(n, r)ReDim m_used(n)m_uN = nm_uR = rEnd IfFor i = 0 To nm_used(i) = FalseNext iCalcComb = DoComb(n, r, 0, 0)End FunctionPrivate Function DoComb(ByVal n As Long, ByVal r As Long, ByVal i As Long, ByVal j As Long) As DoubleIf j = r ThenDoComb = 1For i = 0 To nIf m_used(i) ThenDoComb = DoComb * (i + 1) / (j + 1)j = j + 1End IfNext iElseDoComb = 0For i = i To nIf Not m_used(i) Thenm_used(i) = TrueDoComb = DoComb + DoComb(n, r, i + 1, j + 1) m_used(i) = FalseEnd IfNext iEnd IfEnd Function以上代码实现了组合数不重复,可以供VB语言的开发者使用。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
效果图
编程界面
所有源码
Option Explicit
Private newStr As String, tempNewStr As String, cont As Long Private Sub Command1_Click()
Text1.Enabled = False
RichTextBox1.Enabled = False
RichTextBox1.Text = ""
Dim tempStr As String
tempStr = Trim(Text1.Text)
newStr = "": tempNewStr = ""
cont = 0
If Check1.Value = 0 Then GetStr tempStr
If Check1.Value = 1 Then GetStr2 tempStr, ""
RichTextBox1.Text = newStr
Frame1.Caption = "总个数:" & cont
Text1.Enabled = True
RichTextBox1.Enabled = True
RichTextBox1.Find
End Sub
Private Sub Text1_Change()
RichTextBox1.Text = ""
Frame1.Caption = "总个数:"
End Sub
Private Function GetStr(ByVal str1 As String) As String
str1 = Trim(str1)
If str1 = "" Then Exit Function
Dim i As Integer, tempStr As String, tempChr As String, tempLen As Integer
Dim mytempStr As String
mytempStr = tempNewStr
For i = 1 To Len(str1)
DoEvents
tempChr = ""
tempChr = Mid(str1, i, 1) '取一个字符
tempNewStr = tempNewStr & tempChr '单组组合
tempStr = Left(str1, i - 1) & Right(str1, Len(str1) - i) '剩余新字符
If Len(tempStr) > 1 Then
GetStr tempStr
Else
newStr = newStr & tempNewStr & tempStr & IIf((cont + 1) Mod 200 = 0, Chr(13), Chr(9)) '终组组合
cont = cont + 1
Frame1.Caption = "执行中:" & cont
End If
tempNewStr = mytempStr
Next
End Function
Private Function GetStr2(ByVal str1 As String, ByVal str2 As String) As String
Dim tempStr As String
Dim i As Integer
For i = 1 To Len(str1)
DoEvents
If Len(str2) + 1 = Len(str1) Then
newStr = newStr & str2 & Mid(str1, i, 1) & IIf((cont + 1) Mod 200 = 0, Chr(13), Chr(9))
cont = cont + 1
Frame1.Caption = "执行中:" & cont
Else
GetStr2 str1, str2 & Mid(str1, i, 1)
End If
Next
End Function。