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;
运行效果图
过程解释图
八次乱序结果图
编程大白,第一次写博客。写的不好请指教。
…苦笑脸