2023-07-27 00:31:52 -05:00
|
|
|
/*
|
2024-02-13 09:59:27 -06:00
|
|
|
* SPDX-FileCopyrightText: syuilo and misskey-project
|
2023-07-27 00:31:52 -05:00
|
|
|
* SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
*/
|
|
|
|
|
2022-07-15 03:12:08 -05:00
|
|
|
/**
|
|
|
|
* 配列をシャッフル (破壊的)
|
|
|
|
*/
|
2024-10-30 23:46:42 -05:00
|
|
|
export function shuffle<T extends unknown[]>(array: T): T {
|
|
|
|
let currentIndex = array.length;
|
|
|
|
let randomIndex: number;
|
2022-07-15 03:12:08 -05:00
|
|
|
|
|
|
|
// While there remain elements to shuffle.
|
|
|
|
while (currentIndex !== 0) {
|
|
|
|
// Pick a remaining element.
|
|
|
|
randomIndex = Math.floor(Math.random() * currentIndex);
|
|
|
|
currentIndex--;
|
|
|
|
|
|
|
|
// And swap it with the current element.
|
|
|
|
[array[currentIndex], array[randomIndex]] = [
|
|
|
|
array[randomIndex], array[currentIndex]];
|
|
|
|
}
|
|
|
|
|
|
|
|
return array;
|
|
|
|
}
|