将C#集合拆分成相等的部分,保持排序
发布时间:2020-12-15 06:48:54 所属栏目:百科 来源:网络整理
导读:我试图将一个集合拆分成多个集合,同时保持对集合的排序.我已经尝试使用以下扩展方法,但它不正确地打破它们.基本上,如果要查看收藏中的项目,与加入的分类集合相比,顺序应该相同.这里是我使用的代码不起作用: public static IEnumerableIEnumerableT SplitT(t
我试图将一个集合拆分成多个集合,同时保持对集合的排序.我已经尝试使用以下扩展方法,但它不正确地打破它们.基本上,如果要查看收藏中的项目,与加入的分类集合相比,顺序应该相同.这里是我使用的代码不起作用:
public static IEnumerable<IEnumerable<T>> Split<T>(this IEnumerable<T> list,int parts) { int i = 0; var splits = from name in list group name by i++ % parts into part select part.AsEnumerable(); return splits; } > int parts =子枚举数 解决方法
我不得不利用这个来比较一组对象的对象列表中的4 …
它会按照原来的顺序保留对象.可以扩展到做一些除“列表” /// <summary> /// Partition a list of elements into a smaller group of elements /// </summary> /// <typeparam name="T"></typeparam> /// <param name="list"></param> /// <param name="totalPartitions"></param> /// <returns></returns> public static List<T>[] Partition<T>(List<T> list,int totalPartitions) { if (list == null) throw new ArgumentNullException("list"); if (totalPartitions < 1) throw new ArgumentOutOfRangeException("totalPartitions"); List<T>[] partitions = new List<T>[totalPartitions]; int maxSize = (int)Math.Ceiling(list.Count / (double)totalPartitions); int k = 0; for (int i = 0; i < partitions.Length; i++) { partitions[i] = new List<T>(); for (int j = k; j < k + maxSize; j++) { if (j >= list.Count) break; partitions[i].Add(list[j]); } k += maxSize; } return partitions; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |