Java 中的打亂陣列

Siddharth Swami 2023年1月30日 2021年10月2日
  1. 在 Java 中使用 random() 方法打亂陣列
  2. 在 Java 中使用 shuffle() 方法隨機打亂陣列
Java 中的打亂陣列

陣列是 Java 中的基本資料結構之一。Java 配備了許多函式和方法來處理和處理陣列。

本教程演示瞭如何在 Java 中混洗陣列。

在 Java 中使用 random() 方法打亂陣列

我們可以使用 Fisher-Yates shuffle array 方法隨機地對給定陣列進行打亂。此方法旨在從給定陣列的最後一個元素開始,並不斷與陣列中隨機選擇的元素交換它。

我們使用隨機類中的 Random() 函式來隨機選擇陣列的索引。我們將從 java.util 庫中匯入兩個類,RandomArrays

例如,

import java.util.Random;
import java.util.Arrays;
public class ShuffleExample
{
   
    static void rand( int array[], int a)
    {
        // Creating object for Random class
        Random rd = new Random();
         
        // Starting from the last element and swapping one by one.
        for (int i = a-1; i > 0; i--) {
             
            // Pick a random index from 0 to i
            int j = rd.nextInt(i+1);
             
            // Swap array[i] with the element at random index
            int temp = array[i];
            array[i] = array[j];
            array[j] = temp;
        }
        // Printing the random generated array
        System.out.println(Arrays.toString(array));
    }
     
    public static void main(String[] args)
    {
         
         int[] ar = {1, 2, 3, 4, 5, 6, 7, 8};
         int b = ar.length;
         rand (ar, b);
    }
}

輸出:

[5, 4, 6, 2, 8, 1, 7, 3]

在 Java 中使用 shuffle() 方法隨機打亂陣列

Collection 類的 shuffle() 函式接受使用者給出的列表並隨機打亂它。此功能易於使用,並且比以前的方法花費的時間更少。此外,它為我們減少了程式碼行。

我們取一個陣列並首先將其轉換為一個列表。然後,我們使用 shuffle() 函式來打亂這個列表。最後,我們將這個列表改回一個陣列並列印出來。

請參考下面的程式碼。

import java.util.*;
public class ShuffleExample2{
    public static void main(String[] args){
        Integer[] array={1,3,5,7,9};
        List<Integer> list =Arrays.asList(array);
        
        Collections.shuffle(list);
        list.toArray(array);
        System.out.println(Arrays.toString(array));
    }
}

輸出:

[7, 9, 3, 1, 5]

在上面的陣列中,我們可以看到我們的打亂陣列。它每次都返回一個新的打亂後的陣列。

相關文章 - Java Array