访问List以随机的顺序
本文关键字:随机 顺序 List 访问 | 更新日期: 2023-09-27 17:52:34
我有一个列表,T有一个属性CoverImage。我想以随机顺序访问列表内的所有项目,并从服务器加载适当的图像。我对从服务器加载数据不感兴趣,我想知道的是如何以随机的方式访问列表中的所有元素,只有一次?
Random rnd = new Random();
foreach(var elem in list.OrderBy(x => rnd.Next()))
{
}
合适的术语是洗牌。洗牌是将集合/序列重新排序为随机顺序的概念。
有许多方法可以这样做,具有不同的性能含义。一个很好的选择是Fisher-Yates洗牌法
伪代码:
To shuffle an array a of n elements (indices 0..n-1):
for i from n − 1 downto 1 do
j ← random integer with 0 ≤ j ≤ i
exchange a[j] and a[i]
Random r = new Random();
List<T> myListRnd = new List<T>();
int p = 0;
while (myList.Count > 0)
{
p = r.Next(myList.Count + 1)
myListRnd.Add(myList[p]);
myList.RemoveAt[p];
}
如果您对编写自己的扩展方法感兴趣,它可能看起来像这样:
public static IEnumerable<T> Shuffle<T>(this IEnumerable<T> enumerable, Random random)
{
List<T> itemList = new List<T>(enumerable);
for (int i = 0; i < itemList.Count; ++i)
{
int randomIndex = random.Next(itemList.Count);
if (randomIndex != i)
{
T temp = itemList[i];
itemList[i] = itemList[randomIndex];
itemList[randomIndex] = temp;
}
}
return itemList;
}