一个整数拆分成N个整数之和或者微信红包随机数或者拼多多砍价随机数

     今天突然想到一个问题,微信红包的金额怎么随机出来,或者拼多多那个砍价,怎么随机出来,他们都有两个共同点,一个是固定的金额总数,一个就是参与的人数,只要这么多人参与了,这些人获取的数的总和.肯定是那个金额.

     后面想了一下,这个问题,可不可以先理解为一个整数a,拆分为n个整数之和,如果能拆分,那小数点那个就好处理了.直接上我的demo,可能写得不够好,但是基本功能还是实现了,如果有更好的办法,希望告诉我一下.

package com.xd.cps;

import java.util.Arrays;
import java.util.Random;

public class Test {
    public static void main(String[] args)throws Exception{   
        // 这里随机生成100次试试看看结果.
    	for(int i=0;i<100;i++){
        	System.out.println(Arrays.toString(randomStr(6,10)));
        	System.out.println("----------------");
    	}
    }

    /**
     * @param L 一个整数
     * @param n 分成几个整数
     * @return 数组集合
     */
    public static int[] random(int L, int n){
    	int[] result = new int[n];
    	// 这里简单判断,可以实际修改。
    	if(L/n<1){
    		return result;
    	}
    	int sum = 0; // 已生成的随机数总和
    	for(int i=0; i<n-1; i++){
    		int temp = L - sum;
    		int random = getRandom(temp,i,n);
    		System.out.println( "整数L=" + L + " 已生成的随机数总和sum=" + sum +  " 剩余temp=" + temp + " 生成的随机数random=" + random );
    		result[i] = random;
    		sum += random;
    	}
    	result[n-1] = L - sum;
        return result;
    }
    
    /**
     * 这个是个简单的方式生成小数点的数据.
     * @param L
     * @param n
     * @return
     */
    public static double[] randomStr(int L, int n){
    	double[] result = new double[n];
    	int Multiple = 100; //你要几位小数点
    	L = L*Multiple;
    	// 这里简单判断,可以实际修改。
    	if(L/n<1){
    		return result;
    	}
    	int sum = 0; // 已生成的随机数总和
    	for(int i=0; i<n-1; i++){
    		int temp = L - sum;
    		int random = getRandom(temp,i,n);
    		System.out.println( "整数L=" + L + " 已生成的随机数总和sum=" + sum +  " 剩余temp=" + temp + " 生成的随机数random=" + random);
    		sum += random;
    		result[i] = random*1.0/Multiple;
    	}
    	result[n-1] = (L - sum)*1.0/Multiple;
        return result;
    }
    
    /**
     * 获取一个随机数
     * @param temp 剩余总数
     * @param i 第几次循环了
     * @param n 总循环  这两个变量主要是判断最后那几个数据不能小于1.
     * @return
     */
    private static int getRandom(int temp,int i, int n){
    	Random rand = new Random();
    	int random = rand.nextInt(temp-1)+1;
    	// 这个判断 规则可以再修改一下,主要是为了均匀分配整数.
    	while((temp-random)<=n-i-1){
    		return getRandom(temp,i,n);
    	}
    	return random;
    }
}

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值