类彩票选号算法

转载自: http://blog.csdn.net/lovingprince/article/details/2627759

       彩票选号,例如36选7,从36个数字中随机选取7个,这在算法上如何实现呢? 
       最简单的想法就是,每次都从1~36随机选取一个数,一共选7次,不就可以了吗? 但这样会有一个问题——重复,彩票选号是不能重复的。
      下面介绍一种算法:抽牌算法,来实现这种不允许重复的选号,同时不会出现这种效率上的问题。抽牌算法的核心思想如下: 以36选7为例, 一副牌,一共36张,抽出其中一张牌,放到一边,再从剩下的牌中抽出第二张,放到一边……以此类推,直到抽完了7张牌为止。 很显然,这样抽牌是绝对不会重复的。而其核心就是抽出的牌要放到一边。 用算法如何实现呢? 其实很简单,只要能模拟实现把抽出的牌放到一边这个概念就可以了,而模拟实现的方法是非常简单的:把一个数组模拟成一个牌盒,用数组里存的数模拟牌,而抽出的牌放到一边的动作,只需进行一次数组交换,把它放到数组的末尾即可。
      以36选7为例 初始化数组,其结构为[1, 2 ..... 35, 36]。第一轮,从1~36序号中选取随机序号,抽取到序号7,把序号7和序号36的值交换,7放到数组的末尾,数组结构变成[1...6, 36, 8......34, 35, 7];第二轮,从1~35序号中选取随机序号,抽取到7(这时位置7所存的数就是36了),把36和35交换,数组结构就变成了[1..6, 35, 8...34, 36, 7];第三轮,从1~34序号中选取随机序号,抽取到5,把5和34交换,数组结构变成了[1...4, 34, 6, 35, 8....5, 36, 7] ... 每一次,都把抽出的“牌”放到数组的最后,然后再抽牌时,就不抽最后那张牌,这样就实现了抽出的牌放到一边这样一个概念。
public class Test {

	public static void main(String[] args) {
		// TODO Auto-generated method stub
		int[] array = new int[36];
		initArray(array);
		System.out.println(Arrays.toString(array));
		for (int i = 0; i < 7; i++) {
			int random = (int) (Math.random() * (36 - 1 - i));
			swap(array, random, 36 - 1 - i);
		}
		System.out.println(Arrays.toString(array));
	}

	public static void swap(int[] array, int index_i, int index_j) {
		if (array[index_i] == array[index_j])
			return;
		array[index_i] ^= array[index_j];
		array[index_j] ^= array[index_i];
		array[index_i] ^= array[index_j];
	}

	public static void initArray(int[] array) {
		for (int i = 0, size = array.length; i < size; i++) {
			array[i] = i + 1;
		}
	}

}
好的,让我来解答你的问题。 首先,冷却算法是一种基于概率的优化算法,可以用来解决许多问题,包括彩票选号。在本例中,我们将使用Java来模拟双色球彩票选号过程。 以下是基于冷却算法的双色球选号程序的实现步骤: 1. 定义双色球的号码范围和选号规则。双色球中,红球的号码范围是1-33,蓝球的号码范围是1-16。每次选号需要选择6个红球和1个蓝球。 2. 初始化当前候选的号码组合。我们可以使用随机数来生成一组初始的号码组合。在这个过程中,我们需要确保每个号码都是唯一的。 3. 计算当前号码组合的得分。在双色球中,得分是根据选中的号码与中奖号码的匹配程度来计算的。我们可以设定一个简单的得分规则,例如每个红球匹配得分为1,每个蓝球匹配得分为2。 4. 定义冷却函数。冷却函数用于模拟降温过程,从而使得候选的号码组合逐渐趋向最优解。我们可以使用指数函数作为冷却函数,其中初始温度和降温速率是需要调整的参数。 5. 在每个温度下,随机生成新的号码组合,并计算其得分。如果新的号码组合得分比当前号码组合高,则接受新的号码组合。否则,以一定概率接受新的号码组合。这个概率是由当前温度和新旧号码组合得分差距来决定的,可以使用Boltzmann分布来计算。 6. 不断降温直到温度达到设定的极小值。在这个过程中,我们记录下每个温度下的最优解,以及对应的得分。最终输出得分最高的号码组合即可。 这就是基于冷却算法的双色球选号程序的实现过程。希望对你有所帮助!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值