文章分类 | 推荐文章 | 最新文章 | 热点文章 | 最新软件 | 国产软件 | 国外软件 | 汉化补丁 | 设为首页 | 加入收藏
业界资讯 | 图形图像 | 操作系统 | 网络冲浪 | 工具软件 | 办公软件 | 媒体动画 | 精文荟萃 | 认证考试 | 网站建设 | 技术开发 | 专栏
当前位置:abcdown网络学院认证考试全国等级考试计算机等级考试二级VB常用算法:素数
精品广告
推荐TOP10
·全国计算机等级考试二级C++考试大纲
·计算机等级二级C++语言程序设计考纲分析
·考全国计算机等级考试三级如何学C语言
·从一级到四级 全国计算机等级考试全攻略
·07年4月计算机三级网络技术考前模拟一
·全国计算机等级考试四级复习纲要一[1]
·全国计算机等级考试上机考试应试技巧(一)
·计算机等级考试三级网络的经验
·计算机等级考试三级网络技术复习提纲(上)
·网络程序员必备的参考资料
阅读TOP10
·全国计算机等级考试二级C++考试大纲
·全国计算机等级考试四级复习纲要一[4]
·07年昂立大学英语四级新题型标准试题
·全国计算机等级考试公共基础知识考试大纲
·07年4月计算机三级网络技术考前模拟一
·网络工程师通过--写一点经验
·计算机等级考试三级数据库知识考试题
·计算机等级二级C++语言程序设计考纲分析
·考全国计算机等级考试三级如何学C语言
·从一级到四级 全国计算机等级考试全攻略

计算机等级考试二级VB常用算法:素数

日期:2007年5月5日 作者: 查看:[大字体 中字体 小字体]


  1、算法说明

  素数(质数):就是一个大于等于2的整数,并且只能被1和本身整除,而不能被其他整数整除的数。

  判别某数m是否是素数的经典算法是:

  对于m,从I=2,3,4,……,m-1依次判别能否被I整除,只要有一个能整除,m就不是素数,否则m是素数。

以下是引用片段:
  Private Function sushu(ByVal 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 I=n then sushu=True
  End Function


  很显然,实际上,我们可以改进上面

  For i = 2 To n – 1

  为:

  For i = 2 To int(sqr(m))

  这样可以很好的提高效率。

  以上判断是否为素数的代码务必识记!

  应用举例

  求100-200之内素数。

以下是引用片段:
  Private Sub Command1_Click()
  Dim j As Integer
  For j = 100 To 200
  If sushu(j) = True Then
  Print j
  End If
  Next j
  End Sub


  解题技巧

  识记判断素数的算法过程,根据题意,灵活调用!

  实例说明

  编程题

  找出10000以内所有可以表示为两个平方数和的素数。

  思路:

  首先找10000以内的所有素数,对于每个素数判断其是否可以表示为两个平方数之和(即对于任意小于该素数shu的数I,如果I和shu-I均为平方数,则说明其可以表示为两个平方数之和。)

  判断数I是否为平方数的方法:sqr(i)=int(sqr(i))

以下是引用片段:
  Private Sub Command1_Click()
  Dim j As Integer
  Dim m As Long, n As Long
  For j = 2 To 10000
  If sushu(j) = True Then
  If pf(j, m, n) = True Then
  List1.AddItem j & "=" & m & "+" & n
  End If
  End If
  Next j
  End Sub
  Private Function pf(ByVal shu As Long, m As Long, n As Long) As Boolean
  Dim i As Long
  For i = 1 To shu - 1
  If (Sqr(i) = Int(Sqr(i))) And (Sqr(shu - i) = Int(Sqr(shu - i))) Then
  pf = True
  m = i
  n = shu - i
  Exit Function
  End If
  Next
  End Function

  2、实战练习

  1) 补充代码

  下列程序的功能是:查找四位正整数中的超级素数。超级素数的定义为:当一个素数从低位到高位依次去掉一位数后剩下的数仍然是素数,则此数为超级素数。如数2333、233、23、2均为素数,所以2333为超级素数。

以下是引用片段:
  Option Explicit
  Private Sub Command1_Click()
  Dim I As Integer, flg As Boolean
  For I = 1001 To 9999 Step 2
  Call sup_prime(I, flg)
  If flg Then
  Debug.Print I

[1] [2] 下一页 

上一篇:计算机等级考试二级VB常用算法:进制转化

下一篇:计算机等级考试二级VB常用算法:最值


相关软件: 相关文章:
·水浒Q传 召唤兽各属性与资质的计算公式!
·c# MD5加密算法的实例
·Access使用查询--1.1. 用选择查询建立计算字段
·直接电缆连接 利用专用电缆线在两台计算机间互传文件
·计算机硬盘加密的几种方法
·技巧:多种途径访问局域网中的计算机
·操作系统常见问题:如何知道我计算机的IP地址

特别声明:本站除部分特别声明禁止转载的专稿外的其他文章可以自由转载,但请务必注明出处和原始作者。文章版权归文章原始作者所有。对于被本站转载文章的个人和网站,我们表示深深的谢意。如果本站转载的文章有版权问题请联系编辑人员,我们尽快予以更正。
[打印本页] [关闭窗口] 转载请注明来源:http://www.abcdown.net
首页 | 本站声明 | 下载帮助 | 发布软件 |
中文版权所有:ABC学院 浙ICP备05000717号