笛卡尔积求二维数组所有组合

static void Main(string[] args)
{
    List<List<string>> allList = new List<List<string>>
    {
        new List<string>{ "a","b","c"},
        new List<string>{ "1","2","3"},
        new List<string>{ "A","B","C","D","E"}
    };
    List<string> result = new List<string>();
    Fun(allList, 0, result, string.Empty);
    foreach (var item in result)
    {
        Console.Write(item + "_");
    }
}

/// <param name="list">二维数组</param>
/// <param name="count">二维数组的索引</param>
/// <param name="result">返回的结果集</param>
/// <param name="str">单个组合</param>
public static void Fun(List<List<string>> list, int count, List<string> result, string str)
{
    //获取当前数组
    List<string> current = list[count];
    foreach (var item in current)
    {
        if (count + 1 < list.Count)
        {
            //跳至下一个数组
            Fun(list, count + 1, result, str + item);
        }
        else
        {
            //到达最后一个数组,将拼接的单个组合添加到结果集
            result.Add(str + item);
        }
    }
}

posted @ 2020-08-28 11:24  Wahaha、  阅读(791)  评论(0编辑  收藏  举报