算法目的:对一个正整数分解质因数

一、算法分析:

1、建立整数列表,保存求到的因数。

2、声明整数i=2,用以递增取模;整数m,用于临时保存n

3、建立while循环,i小于等于整数m时,判断m%i,如果等于0,可以被整除,则令 m = m/i 将 i添加到 整数列表;如果m%i不等于0,i++

4、判断整数列表长度,如果长度为1,则认定n是质数;否则为合数并打印列表

5.加入n的开方值比较,如果i 递增到n的开方值但整数列表的大小仍为0,则认为此数是质数

二、运算结果抢先看

三、基础程序

package fundamental;

import java.util.ArrayList;
import java.util.List; public class Seperate { public static void main(String[] args) {
getZ(102039);
}
/*
对n分解质因数,首先找到最小质因数k,如果k==n,直接打印退出。
n<>k,继续k+1对n进行分解
*/
public static void getZ(int n){
List<Integer> l = new ArrayList<Integer>();
int i = 2,m = n;
long start = System.currentTimeMillis();
while(i<=m){ // i<=m 与 i<=n 在运算合数时,效率差很多
if(m%i==0){
m=m/i;
l.add(i);
}else i++;
}
long end = System.currentTimeMillis();
// 0x7fffffff 是 质数,所以i值会累加到 0x7fffffff,比较耗时。但不会超过9秒,因为i值最多累加到0x7fffffff
// 运算时长与n值大小无关,与最大因数有关。
// 最大因数越大,运算越慢,反之越快。
System.out.println("用时:"+(end-start)+"毫秒"); if(l.size()==1) System.out.println(n+"是质数");
else System.out.println(l.toString());
}
}

四、优化算法

加入开方值比较,减少时间复杂度

package fundamental;

import java.util.ArrayList;
import java.util.List; public class Seperate { public static void main(String[] args) {
getZ(0x7fffffff);
}
/*
对n分解质因数,首先找到最小质因数k,如果k==n,直接打印退出。
n<>k,继续k+1对n进行分解
*/
public static void getZ(int n){
List<Integer> l = new ArrayList<Integer>();
int i = 2,m = n;
long start = System.currentTimeMillis();
// sqrt 用以减少比较时间
int sqrt = (int) Math.sqrt(n);
while(i<=m ){ // i<=m 与 i<=n 在运算合数时,效率差很多
if(m%i==0){
m=m/i;
l.add(i); }else i++; /*
以下一行是优化算法:
如果 i 超过 sqrt 还没有因数存在,则认为是质数,跳出循环
因为 n 如果是两个质数的乘积,i值需要递增到sqrt才能判断出n是否为质数
*/
      if(i>sqrt) {
          if(l.size()==0) System.out.println(n+"是质数");
          else l.add(m);
          break;
       }
}
long end = System.currentTimeMillis(); // 0x7fffffff 是 质数,所以i值会累加到 0x7fffffff,比较耗时。但不会超过9秒,因为i值最多累加到0x7fffffff
// 运算时长与n值大小无关,与最大因数有关。
// 最大因数越大,运算越慢,反之越快。
System.out.println("用时:"+(end-start)+"毫秒"); if(l.size()==0) System.out.println(n+"是质数");
else System.out.println(l.toString());
}
}

最新文章

  1. Android基础
  2. python脚本执行Scapy出现IPv6警告WARNING解决办法
  3. [XAF] How to represent an enumeration property via a drop-down box with check boxes
  4. JVM知识点
  5. 一些有意思的APP
  6. [转]基于 Quercus 的手游项目终于上线了
  7. CUDA中修饰符的解释
  8. 查询SQL SERVER数据库日志工具
  9. Android FragmentActivity+viewpager的使用
  10. 解读Hashtable
  11. SRM 508(2-1000pt)
  12. VCS仿真生成fsdb文件(Verilog)
  13. ZigZag-LeetCode
  14. 如何灵活利用免费开源图标字体-IcoMoon篇
  15. Golang源码探索(一) 编译和调试源码
  16. hackerrank Diameter Minimization
  17. idea打jar包并部署java web项目
  18. nodejs进程线程优化性能
  19. python三目运算符
  20. h5文件(.h5和.hdf5)

热门文章

  1. Http简单思维导图
  2. web管理kvm ,安装webvirtmgr
  3. ES6模块化
  4. Linux Redis集群搭建与集群客户端实现
  5. 网页设计——6.html其他标签
  6. sendGrid 纯文本的换行问题
  7. 在Ubuntu14.04下安装Docker CE(1) - repository篇
  8. js二级事件模型的处理细节
  9. JSON数据解析及gson.jar包
  10. [Maven实战](7)坐标