蓄水池算法

//蓄水池算法
public class CollectionA{
	 //一个简单的随机函数,决定一件事情做还是不做
	public static int rand(int max)
	{
		 return (int)(Math.random()*max)+1;
	}
	//以k/N的概率进袋子
    public static int[]getKNumsRand(int k,int max)
    {
    	 if(max<1||k<1)
    	 {
    	 	 return null;
    	 }
    	 int[]res=new int[Math.min(k,max)];
    	 for(int i=0;i!=res.length;i++)
    	 {
    	 	  res[i]=i+1; //前k个数直接进袋子
    	 }
    	 for(int i=k+1;i<max+1;i++)
    	 {
    	 	 if(rand(i)<=k) //决定i进不进袋子
    	 	 {
                    res[rand(k)-1]=i; //i随机替掉袋子中的一个
    	 	 }
    	 }
    	 return res;
    }
    //打印数组的内容
    public static void printArr(int[]arr)
    {
    	  for(int i=0;i<arr.length;i++)
    	  {
    	  	 System.out.print(arr[i]+" ");
    	  }
    	  System.out.println();
    }
	 public static void main(String[]args)
	 {
           int[]arr=getKNumsRand(10,10000);
           printArr(arr);
	   
	 }
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值