【java】数组随机乱序排列

本文介绍了一种数组随机采样的算法实现,通过每次从数组中随机选择一个元素,然后将数组末尾元素覆盖到该位置并缩小数组长度,直至遍历整个数组。此算法确保每个元素被选中的概率相等,常用于洗牌或随机抽样场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

每次从已知数组随机一个数,然后将数组的最后一个值 赋值给前面随机到的数的位置上,然后将长度-1,再从原数组下标-1的数组中随机。 运算次数就是数组长度
//-----------------------------------------------
public int [] m3(int [] arr) {
int [] arr2 =new int[arr.length];
int count = arr.length;
int cbRandCount = 0;// 索引
int cbPosition = 0;// 位置
int k =0;
do {
runCount++;
Random rand = new Random();
int r = count - cbRandCount;
cbPosition = rand.nextInt( r );
arr2[k++] = arr[cbPosition];
cbRandCount++;
arr[cbPosition] = arr[r - 1];// 将最后一位数值赋值给已经被使用的cbPosition
} while (cbRandCount < count);
System.out.println("m3运算次数 = "+runCount);
return arr2;
}

引用自:https://blog.csdn.net/gywtzh0889/article/details/52886618

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值