C#中实现任意List的全组合算法代码

时间:2022-09-23 01:06:48 


using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace 算法
{
    class 全组合算法
    {
        [Flags]
        public enum PersonType
        {
            Audit = 1,
            Child = 2,
            Senior = 4
        }

        public static void Run(string[] args)
        {
            var lstSource = GetEnumList<PersonType>();
            var lstComb = FullCombination(lstSource);
            var lstResult = new List<PersonType>();
            lstComb.ForEach(item =>
            {
                lstResult.Add(item.Aggregate((result, source) => result | source));
            });
        }

        public static List<T> GetEnumList<T>()
        {
            var lst = new List<T>();
            foreach (T item in Enum.GetValues(typeof(T)))
            {
                lst.Add(item);
            }
            return lst;
        }

        //全组合算法
        public static List<List<T>> FullCombination<T>(List<T> lstSource)
        {
            var n = lstSource.Count;
            var max = 1 << n;
            var lstResult = new List<List<T>>();
            for (var i = 0; i < max; i++)
            {
                var lstTemp = new List<T>();
                for (var j = 0; j < n; j++)
                {
                    if ((i >> j & 1) > 0)
                    {
                        lstTemp.Add(lstSource[j]);
                    }
                }
                lstResult.Add(lstTemp);
            }
            lstResult.RemoveAt(0);
            return lstResult;
        }

    }
}

标签:List,全组合算法
0
投稿

猜你喜欢

  • SpringBoot整合TomCat实现本地图片服务器代码解析

    2021-07-30 16:34:19
  • 积累Visual Studio 常用快捷键的动画演示

    2022-11-29 08:29:46
  • java 的Collection接口实例详解

    2021-09-22 15:35:00
  • C#遍历文件夹获取指定后缀名文件

    2023-01-07 02:07:56
  • c# 委托和事件实例学习

    2023-07-04 06:25:58
  • springboot如何使用logback-spring配置日志格式,并分环境配置

    2023-11-10 04:37:34
  • Java中多媒体文件上传及页面回显的操作代码

    2021-11-21 09:45:31
  • Android 13新功能及适配工作详解

    2022-04-13 11:05:33
  • JAVA面试题 从源码角度分析StringBuffer和StringBuilder的区别

    2023-07-24 07:29:07
  • Java移动文件夹及其所有子文件与子文件夹

    2023-08-01 09:53:38
  • Android触屏测试实例代码

    2023-05-30 07:15:08
  • Spring实现处理跨域请求代码详解

    2023-11-25 12:28:34
  • C#中三种Timer计时器的详细用法

    2022-12-14 13:52:34
  • 面试中遇到的java逃逸分析问题

    2021-12-08 11:58:28
  • SpringBoot整合RabbitMQ实现消息确认机制

    2023-09-11 04:07:22
  • 通过IDEA快速定位和排除依赖冲突问题

    2021-06-07 02:01:16
  • c# 动态构建LINQ查询表达式

    2022-03-23 20:40:47
  • Android使用SQLite数据库的示例

    2023-09-17 07:36:58
  • 基于Java编写串口通信工具

    2022-11-30 09:25:34
  • Java KeyGenerator.generateKey的19个方法代码示例

    2022-08-08 14:26:40
  • asp之家 软件编程 m.aspxhome.com