递归一个List<T>,可自己根据需要改造为通用型。

本文介绍了一种使用递归来处理嵌套的组织数据结构的方法,具体为List<ProvinceOrg>类型的对象列表。通过递归函数RecursionProvinceOrgs,可以遍历所有层级的数据,分离出没有子级的组织,并将它们添加到新的列表中,同时保留具有子级的组织以进行进一步的处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

        /// <summary>
        /// 递归一个List<ProvinceOrg>
        /// </summary>
        /// <returns></returns>
        public void RecursionProvinceOrgs(List<ProvinceOrg> provinceOrgs, ref List<ProvinceOrg> _provinceOrgs)
        {
            if (provinceOrgs != null && provinceOrgs.Count() > 0)
            {
                // 1、通过linq查询出children为空的。
                var _provinceOrgs_ = provinceOrgs.Where(p => p.children.Count() == 0);
                if (_provinceOrgs_.Count() > 0)
                {
                    //2、将children为空的添加至_provinceOrgs
                    _provinceOrgs.AddRange(_provinceOrgs_);
                }

                // 处理剩余不为空的,父级的ORG
                var _provinceOrgs_Surplus = provinceOrgs.Where(p => p.children.Count() > 0);
                foreach (ProvinceOrg provinceOrg in _provinceOrgs_Surplus)
                {
                    ProvinceOrg provinceOrgClone = provinceOrg.Clone();
                    _provinceOrgs.Add(provinceOrgClone);
                    RecursionProvinceOrgs(provinceOrg.children, ref _provinceOrgs);
                }
            }
        }

 实体类:

    public class ProvinceOrg : ICloneable
    {
        public int orgId { get; set; }
        public int parentOrgId { get; set; }
        public int areaId { get; set; }
        public string areaCode { get; set; }
        public string orgName { get; set; }
        public string fullOrgName { get; set; }
        public string orgType { get; set; }
        public string state { get; set; }
        public string orgCode { get; set; }
        public int seq { get; set; }
        public string isBusDep { get; set; }
        public string depCateCode { get; set; }
        public string legalPerson { get; set; }
        public string contacts { get; set; }
        public string phone { get; set; }
        public string address { get; set; }
        public string orgFunctions { get; set; }
        public int num;
        public List<ProvinceOrg> children { get; set; }

        /// <summary>
        /// 克隆并返回一个对象。
        /// </summary>
        /// <returns></returns>
        public ProvinceOrg Clone()
        {
            ProvinceOrg p = (ProvinceOrg)this.MemberwiseClone();
            p.children = new List<ProvinceOrg>();
            return p;
        }

        object ICloneable.Clone()
        {
            return this.Clone();
        }
    }

转载于:https://www.cnblogs.com/netlws/p/10701640.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值