C# 泛型List随机排列
来源:互联网 发布:软件用什么服务器 编辑:程序博客网 时间:2024/06/07 06:09
有时候得到了一个List,我想把它随机排列一下顺序。而且如果针对不同类型的List都能用,就要用到泛型。
其实思想很简单,就是从原List中每次随机取一项,添加到新的List中,并在原List中删除。这样重复,直到原List为空为止。
不过要注意,如果要保护原List不受变化,就必须先Copy一份List,再在Copy上进行操作
public static List<T> GetRandomList<T>(List<T> inputList){ //Copy to a array T[] copyArray = new T[inputList.Count]; inputList.CopyTo(copyArray); //Add range List<T> copyList = new List<T>(); copyList.AddRange(copyArray); //Set outputList and random List<T> outputList = new List<T>(); Random rd = new Random(DateTime.Now.Millisecond); while (copyList.Count > 0) { //Select an index and item int rdIndex = rd.Next(0, copyList.Count - 1); T remove = copyList[rdIndex]; //remove it from copyList and add it to output copyList.Remove(remove); outputList.Add(remove); } return outputList;}
感谢一楼的回复,他提出了比较简洁的代码,不过缺点是都用到了排序,这样时间复杂度至少是O(N*logN),本文中是O(N),如果List比较小的话,那么采用简洁的代码更合适,如果List很大,就可能不能满足要求了。
List<T> l = new List<T>();
l.Sort(delegate(T a, T b) { return (new Random()).Next(-1, 1); });
也可以用linq
List<T> l = new List<T>();
l = l.Select(a => new { a, newID = Guid.NewGuid() }).OrderBy(b => b.newID).Select(c=>c.a).ToList();
- C# 泛型List随机排列
- list 随机排列
- c# List实现随机排序
- 对List顺序,逆序,随机排列实例代码
- 随机排列
- 随机排列
- 随机排列
- java随机排列数组
- 随机排列数组
- vector随机排列
- 算法 生成随机排列
- 随机排列问题
- 原地随机排列数组
- 随机排列数组
- 随机排列数组
- 随机排列数组
- 随机排列数组
- 随机排列出场顺序
- php-fig / fig-standards
- 如何使Metrics好用
- shell 命令
- 第一次用python:计算概率矩阵
- I2S音频总线学习(三)S3C2440的I2S控制器
- C# 泛型List随机排列
- Python图表软件包ChartDirector的安装和使用
- Java多线程学习
- centos 安装中文语言包
- Linux关闭终端屏保
- 使用JRockit JVM剖析当前进程
- vsftpd简易配置
- Javascript高级程序设计第二版第十二章--Event--笔记
- (转)MDB链接SQLSERVER导致写入冲突,头疼的问题,原来错在这里!!