加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

将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;
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读