shuffle實現 / 洗牌算法

目的

隨機打亂一個數組

code

#include <bits/stdc++.h>
using namespace std;

void knuth_shuffle(int *arr, int n)
{
        for (int i = n - 1; i > 1; i--)
                swap(arr[i], arr[rand()%(i-1)]);
        swap(arr[1], arr[0]);
}


int main()
{
        int arr[256];
        int n;
        cin >> n;
        for (int i = 0; i < n; i++)
                cin >> arr[i];

        knuth_shuffle(arr, n);

        for (int i = 0; i < n; i++)
                cout << arr[i] << " ";
        cout << endl;

        return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章