一步一步写算法(洗牌算法)[建议收藏]

一步一步写算法(洗牌算法)

大家好,又见面了,我是全栈君,今天给大家准备了Idea注册码。

全栈程序员社区此处内容已经被作者隐藏,请输入验证码查看内容
验证码:
请关注本站微信公众号,回复“验证码”,获取验证码。在微信里搜索“全栈程序员社区”或者“www_javaforall_cn”或者微信扫描右侧二维码都可以关注本站微信公众号。

【 声明:版权所有所有,欢迎转载。不用于商业用途。

 联系我们:feixiaoxing @163.com】

    扑克洗牌是我们的生命更喜欢玩游戏。

么我们有没有什么办法自己设计一个扑克牌洗牌的方法呢?在c执行库其中有一个随机函数rand,它能够生成0~32767之间的随意数。那么有没有可能利用这么一个函数对我们扑克牌进行随即洗牌呢?

    在这里我抛砖引玉一下,谈一谈自己眼下已经看到的两个算法。欢迎朋友们谈一谈其它的方法。

    (1)全局洗牌法

    过程例如以下所看到的:

    a)首先生成一个数组,大小为54,初始化为1~54

    b)依照索引1到54。逐步对每一张索引牌进行洗牌,首先生成一个余数 value = rand %54,那么我们的索引牌就和这个余数牌进行交换处理

    c)等多索引到54结束后。一副牌就洗好了

    代码例如以下所看到的:

void get_rand_number(int array[], int length)
{
	int index;
	int value;
	int median;

	if(NULL == array || 0 == length)
		return ;

	/* 每次发牌的时候随意分配待交换的数据 */
	for(index = 0; index < length; index ++){
		value = rand() % length;

		median = array[index];
		array[index] = array[value];
		array[value] = median;
	}
}

    
(2)局部洗牌法

    上面的算法很easy,可是有一个问题,我们发现每次洗牌之后原来洗好的牌都会进行二次操作,个人认为有点说只是去,所以最好还是加以改进:

    a)相同,首先我们生成一个大小为54的数组,数组排列为1~54

    b)索引牌从1開始。到54结束。这一次索引牌仅仅和剩下还没有洗的牌进行交换, value = index + rand() %(54 – index)

    c)等到全部的索引牌都洗好之后,一副牌就弄好了

    代码例如以下所看到的:

void get_rand_number(int array[], int length)
{
	int index;
	int value;
	int median;
	
	if(NULL == array || 0 == length)
		return ;
	
	/* 发牌的时候对于已经分配的数据不再改动 */
	for(index = 0; index < length; index ++){
		value = index + rand() % (length - index);
		
		median = array[index];
		array[index] = array[value];
		array[value] = median;
	}
}

注意: 这两种算法都不是我想出来的。欢迎算法初次接触我的作者,我会加入在文章迹象。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/117838.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 图集谷-写真集-爬虫-1.0[通俗易懂]

    图集谷-写真集-爬虫-1.0[通俗易懂]图集谷写真集爬虫

    2022年7月27日
    1
  • Python numpy函数:dtype数组元素类型

    Python numpy函数:dtype数组元素类型数组元素的类型通过dtype属性获得。而且,每一种数据类型都有几种字符串表达形式,我们可以使用typeDict字典来查询某种字符串所代表的数据类型,比如“d”和“double”都是float64数据类型:

    2022年6月8日
    33
  • python的数据处理_基于python的数据处理

    python的数据处理_基于python的数据处理源起:1.我要做交叉验证,需要每个训练集和测试集都保持相同的样本分布比例,直接用sklearn提供的KFold并不能满足这个需求。2.将生成的交叉验证数据集保存成CSV文件,而不是直接用sklearn训练分类模型。3.在编码过程中有一的误区需要注意:这个sklearn官方给出的文档>>>importnumpyasnp>>>fromsklearn.mo…

    2022年9月14日
    0
  • cholesky分解_java toarray方法

    cholesky分解_java toarray方法接着LU分解继续往下,就会发展出很多相关但是并不完全一样的矩阵分解,最后对于对称正定矩阵,我们则可以给出非常有用的cholesky分解。这些分解的来源就在于矩阵本身存在的特殊的结构。对于矩阵A,如果没有任何的特殊结构,那么可以给出A=L*U分解,其中L是下三角矩阵且对角线全部为1,U是上三角矩阵但是对角线的值任意,将U正规化成对角线为1的矩阵,产生分解A=L*D*U,D为对角矩阵。如果A为对…

    2022年10月24日
    0
  • 最新手机号段 归属地数据库(20191210,共439265条,包括最新的号段)

    最新手机号段 归属地数据库(20191210,共439265条,包括最新的号段)最新手机号段归属地数据库最新手机号段归属地数据库最新手机号段归属地数据库1、提供三大运营商及虚拟运营商的号段数据库,共439265条数据,最后更新时间:2019-12-10最新手机归属地数据库,号码归属地数据库,txt格式、sql、exel三种格式。自己买的,花了60元。包括最新的165、166、172、173、175、176、177、178、198、199。这里是txt格式,其…

    2022年7月22日
    14

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号