3.3枚举算法及程序实现(2)课件.ppt
- 【下载声明】
1. 本站全部试题类文档,若标题没写含答案,则无答案;标题注明含答案的文档,主观题也可能无答案。请谨慎下单,一旦售出,不予退换。
2. 本站全部PPT文档均不含视频和音频,PPT中出现的音频或视频标识(或文字)仅表示流程,实际无音频或视频文件。请谨慎下单,一旦售出,不予退换。
3. 本页资料《3.3枚举算法及程序实现(2)课件.ppt》由用户(三亚风情)主动上传,其收益全归该用户。163文库仅提供信息存储空间,仅对该用户上传内容的表现方式做保护处理,对上传内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知163文库(点击联系客服),我们立即给予删除!
4. 请根据预览情况,自愿下载本文。本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
5. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007及以上版本和PDF阅读器,压缩文件请下载最新的WinRAR软件解压。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 3.3 枚举 算法 程序 实现 课件
- 资源描述:
-
1、1双重循环:某些枚举算法的问题比较复杂,需双重循环:某些枚举算法的问题比较复杂,需要通过复杂的双重循环来实现。双重循环就是循环的嵌要通过复杂的双重循环来实现。双重循环就是循环的嵌套,在一层循环结构内部又是另一层循环,其结构如下套,在一层循环结构内部又是另一层循环,其结构如下所示:所示:For i语句块语句块 For j 语句块语句块Next jNext i33枚举算法及程序实现枚举算法及程序实现(2)此结构由两个此结构由两个For循环构成,外循环是循环变量为循环构成,外循环是循环变量为i的的循环,内循环是循环变量为循环,内循环是循环变量为j的循环,这两个循环之间的关的循环,这两个循环之间的关系
2、是嵌套关系,循环变量为系是嵌套关系,循环变量为i的循环将循环变量为的循环将循环变量为j的循环的循环包含在内,在循环执行时,外循环变量包含在内,在循环执行时,外循环变量i每变化一次,都要每变化一次,都要执行一次完整的内循环。执行一次完整的内循环。在枚举算法中,有很多时候用到循环的嵌套来解决问在枚举算法中,有很多时候用到循环的嵌套来解决问题。题。2循环嵌套:循环嵌套的层数没有具体限定,选考时循环嵌套:循环嵌套的层数没有具体限定,选考时的多重循环结构一般只要求到双重循环。多重循环在使用的多重循环结构一般只要求到双重循环。多重循环在使用时,每个循环必须只有一个唯一的变量名作为循环变量;时,每个循环必须
3、只有一个唯一的变量名作为循环变量;在在Next语句结束循环时,必须内循环先结束,不得出现互语句结束循环时,必须内循环先结束,不得出现互相交叉。相交叉。3编写枚举算法的程序要注意两个要点编写枚举算法的程序要注意两个要点:For循环的范围要尽可能的小,这决定可能解的范循环的范围要尽可能的小,这决定可能解的范围是否已经尽可能的小;围是否已经尽可能的小;条件表达式必须要正确无误,这决定哪些解才是真条件表达式必须要正确无误,这决定哪些解才是真正的解。正的解。4素数问题素数问题素数的概念素数的概念 素数素数(质数质数)就是一个大于等于就是一个大于等于2的整数,并且只能被的整数,并且只能被1和本身整除,而不
4、能被其他整数整除的数。和本身整除,而不能被其他整数整除的数。 算法说明算法说明判别某数判别某数n是否是素数的经典算法是,对于是否是素数的经典算法是,对于n,从,从i2,3,4,n1依次判别能否被依次判别能否被i整除,只要有一个能整整除,只要有一个能整除,除,n就不是素数,否则就不是素数,否则n是素数。是素数。代码实现代码实现Function sushu(n As Long) As Boolean 定义素数函数定义素数函数Dim i As Long For i 2 To n 1 If (n Mod i) 0 Then Exit For Next i If in then sushuTrue En
5、d Function 5最大公约数问题最大公约数问题最大公约数:就是几个数共同最大的约数。最大公约数:就是几个数共同最大的约数。算法说明:用辗转相除法求两自然数算法说明:用辗转相除法求两自然数m、n的最大公的最大公约数,再由最大公约数求出最小公倍数。约数,再由最大公约数求出最小公倍数。首先,对于已知两数首先,对于已知两数m、n,比较并使得,比较并使得mn;m除以除以n得余数得余数r;若若r0,则,则n为求得的最大公约数,算法结束;否则为求得的最大公约数,算法结束;否则执行步骤;执行步骤;使使mn,nr再重复执行。再重复执行。代码实现:代码实现:Function gcd(m As Long, n
6、 As Long) As Long Dim temp As Long If m 7 Then si*jNext jNext i则语句则语句si*j的执行次数是的执行次数是 ()A15B4C5D20C C 2某工厂购入某工厂购入100千克原材料,每千克原材料,每4千克原材料可以生产千克原材料可以生产一件一件 A产品,每产品,每5千克原材料可以生产一件千克原材料可以生产一件 B产品。下产品。下列列VB程序的功能是:计算恰好用尽这些原材料时,生程序的功能是:计算恰好用尽这些原材料时,生产产 A产品产品 和和B产品数量的各种可能,并在列表框中输产品数量的各种可能,并在列表框中输出。出。Private
7、Sub Command1_Click()Dim x As Integer, y As Integerx、y分别为分别为 A、B产品的数量产品的数量For x0 To 25 For y0 To 20If ThenList1.AddItem“A产品产品”Str(x)“件,件, ” “B产品产品”Str(y)“ 件件”End If Next xEnd Sub请在划线处填入合适代码。请在划线处填入合适代码。(1)划线处应填入划线处应填入_。(2)划线处应填入划线处应填入_。(x*4+y*5)=100 Next y3一个十进制数的二进制表示中,如果数字一个十进制数的二进制表示中,如果数字“1”的个数多于
展开阅读全文