质数
查找质数的java和perl的代码
星期五, 十二月 5th, 2008 | algorithm-learn, JAVA-and-J2EE | 没有评论
今天看本perl的一个教程的时候看到,查找质数的一个算法,不由自主的就想用java重新了此代码,
感觉效率太低,就优化下,其他更高级的算法方式没有研究,贴出来;记录下
perl代码:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 | #!/usr/bin/perl -w $maxprimes=100; $value=1; $count=0; while($count <$maxprimes){ $value++; $composite=0; OUTER: for($i=2;$i<$value;$i++){ for($j=$i;$j<$value;$j++){ if(($j*$i)==$value){ $composite=1; last OUTER; } } } if(!$composite){ $count++; print "$value is prime count is $count \n";} } |
java代码的两种:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 | package com.liyz.num.test; public class PrimeNum { public static void main(String[] args) { long start=System.currentTimeMillis(); primeMehtodTwo(100); long end=System.currentTimeMillis(); System.out.println("use time is " +(end-start)+" ms"); } //效率太差,取的质数越多,比较的次数也越多,效率也越低 public static void primeMehtodOne( int number){ int num=number; int value=1; int count=0; boolean composite; while (count<num){ value++; composite=false; for(int i=2;i<value;i++){ for(int j=i;j<value;j++){ if((j*i)==value){ composite=true; break; } } } if(!composite){ count++; System.out.println(value+" is prime!"); } } } //感觉好多了,更好的算法没有去研究过 public static void primeMehtodTwo(int number){ int count=0; int fg=1; int num=number; for( int i=2;count<num;i++){ double k=Math.sqrt(i+1); for(int j=2;j<=k;j++){ if((i%j)==0){ fg=0; break; } } if(fg==1){ System.out.println(i+" is prime!"); count++; } fg=1; } } } |
Search
相关文章
热门文章
最新文章
文章分类
- ajax (10)
- algorithm-learn (3)
- Android (6)
- as (3)
- computer (85)
- Database (30)
- disucz (4)
- enterprise (1)
- erlang (2)
- flash (5)
- golang (3)
- html5 (18)
- ios (4)
- JAVA-and-J2EE (186)
- linux (143)
- mac (10)
- movie-music (11)
- pagemaker (36)
- php (50)
- spring-boot (2)
- Synology群晖 (2)
- Uncategorized (6)
- unity (1)
- webgame (15)
- wordpress (33)
- work-other (2)
- 低代码 (1)
- 体味生活 (40)
- 前端 (21)
- 大数据 (8)
- 游戏开发 (9)
- 爱上海 (19)
- 读书 (4)
- 软件 (3)