Java数组乱序

本文深入探讨了Java中实现数组元素随机乱序的算法原理,通过使用随机数生成器来选择数组中的不同元素进行交换,确保每个元素都有机会出现在数组的任意位置,从而达到完全随机的效果。

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

java的数组乱序,把自己的理解写出来,有错误希望指出。
通过随机数做下标来跟后面的数作交换。 总的来说就是就是把取过的往后移,没取过的往前拿,同时不断缩小随机数的取值范围。每次交换的都是没取过的值
也可以通过一个新数组来存储每次随机下标取到的值,来达到乱序的目的,因为每次取到的值都是不同的。具体可以自己写代码实现看下

public static void test() {
		Random rd =new Random();
		String [] str= {"指","鹿","为","马"};//乱序前的数组
		for (int i = 0; i < str.length; i++) {
			int c = rd.nextInt(str.length - i);//接收每次产生的随机数
			System.out.print(c+" ,");//打印随机数
			//交换数组内容
			String tem = str[str.length - i - 1];
			str[str.length-1-i] =str[c];
			str[c] = tem;
		}
		System.out.println();
		System.out.println(Arrays.toString(str));
	}

随机下标,且每次循环后取值范围都减一,以此来达到不会取到倒数第i个及之后的值

int c = rd.nextInt(str.length - i);

随机下标取中的值每次于倒数第i个值做交换

String tem = str[str.length - i - 1];
			str[str.length-1-i] =str[c];
			str[c] = tem;

运行效果图
一次乱序
过程解释图
过程解释
八次乱序结果图
乱序效果
编程大白,第一次写博客。写的不好请指教。
…苦笑脸

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值