注册 登录
编程论坛 J2EE论坛

一个随机数算法

xlwt2113 发布于 2005-09-22 11:22, 1016 次点击
这几天做程序遇到一个问题。要求每次读数据库的数据时,显示在页面上的时候必须每次的顺序都不相同。也就是说每条记录都是随机取出来的,并且要求把所有数据全部显示出来。于是写了这样一个算法。但是感觉不是很好,数据量小的时候没什么影响,当数据量大的时候系统速度就会慢的要死了!:( 以下是程序代码: 要求:指定显示一定数目的数字,如显示1到12这些数字,要求数字随机排列并全部显示出来。每次运行程序后这些数字的顺序都不相同!

import java.lang.*; import java.util.*;

public class MakeRandomNum { public void getRandom()throws Exception { String [] a=new String[12]; Random rndTemp = new Random(); int flag=1; String rnum=new String("w");//先付一个初始值 for(int i=0;i<12;i++) { do { flag=1; Float num=new Float(rndTemp.nextFloat()*12+1); rnum=num.toString(); rnum=rnum.substring(0,rnum.indexOf(".")); for(int j=0;j<i;j++) { if(a[j].equals(rnum)) { flag=0; // System.out.print("t"); } } }while(flag==0); a[i]=rnum; System.out.println(a[i]); } } public static void main(String args[]) { try{ MakeRandomNum my=new MakeRandomNum(); my.getRandom(); }catch(Exception e) { System.out.print(e); } } }

运行结果:不知道怎么贴图,只有运行结果大家自己运行程序的时候自己看把!呵呵

可能算法不是很优化,在数字为千个以内速度很快,试了个50000的,运行了好几分钟!差点死机! :( 大家来一起看看有没有更好的算法啊?!

2 回复
#2
xlwt21132005-09-22 11:23
刚才发错地方了,弄到javascript那个栏目里面了,呵呵
#3
zishan2005-09-23 17:24

你的程序我稍微改了一点 import java.lang.*; import java.util.*;

public class MakeRandomNum { public void getRandom()throws Exception { String [] a=new String[12]; Random rndTemp = new Random(); int flag=1; String rnum=""; for(int i=0;i<12;i++) { if(flag==1){ Float num=new Float(rndTemp.nextFloat()*12+1); rnum=num.toString(); rnum=rnum.substring(0,rnum.indexOf(".")); } if(flag==0); a[i] = rnum; System.out.println(a[i]); } } public static void main(String args[]) { try{ MakeRandomNum my=new MakeRandomNum(); my.getRandom(); }catch(Exception e){ System.out.print(e); } } } 你看看这里还有没有其他的漏洞

1