c#隨機打亂數組


方法1:使用Sort

思路:隨機生成-1或者0,使得排序到目標元素有50%幾率和下一個元素發生交換

public static void Sort1(List<string> arr)
{
    arr.Sort((x, y) => { return new Random().Next(-1, 1); });
}

 

方法2:隨機下標交換

思路:遍歷的每個元素都有可能和數組內隨機的元素發生交換

public static void Sort2(List<string> arr)
{
    for (int i = 0; i < arr.Count; i++)
    { 
var index = new Random().Next(i, arr.Count); var tmp = arr[i]; var ran = arr[index]; arr[i] = ran; arr[index] = tmp; } }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM