深入分析:如何随机打乱一个数组

分析1: 怎么算随机打乱一个数组

只要能保证处理后的每个数所处的位置都是由随机数决定的, 那么就可以说数组被打乱了.

方案一(简单方便)

  1. 对于一个长度为n的数组arr, 生成一个[0,n-1] 的整数随机数r, 将arr[r]与数组中最后一个数arr[n-1]进行交换.
  2. 执行后忽略掉最后一个数, 将前面n-1个数看作是一个新的数组, 重复上个步骤, 直到最后数组长度n变成1.

步骤1从数组中随机选择一个数放到最后一个位置, 也就是说arr[r]被打乱了放到了最后, 之后前面的n-1个数可以看作新的数组, 直到最后数组长度变成1就可以了.
如此整个数组中的所有数的位置均是由随机数决定的, 我们将整个数组随机打乱了.

生成的随机数范围应该是当前数组大小, 数组大小是不断减小的, 因此生成的随机数也是不断减小的, 例如一个长度为5的数组, 只需要生成范围[0,4],[0,3],[0,2],[0,1]的4个随机数即可以打乱一组数据.

如此, 大小为n的数组, 需要n-1个随机数, 最多n-1次交换即可随机打乱一组数据, 且没有开辟额外空间.

代码示例(容易理解的代码)

java.util.Random random = new java.util.Random();

void disorder(int[] arr) {
   
   // 存放生成的随机数
   int rdm;
   // 用于数组交换
   int tmp;
   
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

逆光影者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值