RError.com

RError.com Logo RError.com Logo

RError.com Navigation

  • 主页

Mobile menu

Close
  • 主页
  • 系统&网络
    • 热门问题
    • 最新问题
    • 标签
  • Ubuntu
    • 热门问题
    • 最新问题
    • 标签
  • 帮助
主页 / 问题 / 1242211
Accepted
Madoka Magica
Madoka Magica
Asked:2022-02-10 15:33:47 +0000 UTC2022-02-10 15:33:47 +0000 UTC 2022-02-10 15:33:47 +0000 UTC

对嵌套循环进行递归

  • 772

这似乎不是一项艰巨的任务,但我无法解决它。这里有必要对 tstRec1() 循环进行递归(会有未知数) 我尝试在 tstRec2() 中进行。但尚不清楚如何以与 tstRec1() 相同的顺序进行添加:

List<int> poh = new List<int>();
List<int> poh2 = new List<int>();

public void startTest()
{
    tstRec2(2, 2);
    tstRec1();
}
public void tstRec1()
{
    
    for (int i = 0; i < 2; i++)
    {
        for (int u = 0; u < 2; u++)
        {
            for (int s = 0; s < 2; s++)
            {
                poh.Add(i);
                poh.Add(u);
                poh.Add(s);
            }
        }
    }
    
}

public void tstRec2(int countZikls, int counter, int lvl = 0, int transport = 0)
{
    for (int i = 0; i < counter; i++)
    {          
        if (lvl > countZikls)
        {
            
            break;
        }
        else if (lvl == countZikls)
        {
            poh2.Add(i);
        }
        else
        {
            tstRec2(countZikls, counter, lvl+1, i);
        }  
    }
}
c#
  • 1 1 个回答
  • 10 Views

1 个回答

  • Voted
  1. Best Answer
    aepot
    2022-02-10T17:36:34Z2022-02-10T17:36:34Z

    结果不知何故

    static void Main(string[] args)
    {
        Console.WriteLine(string.Join(" ", TestRec1(2)));
        Console.WriteLine(string.Join(" ", TestRec2(2, 2)));
    }
    
    public static List<int> TestRec1(int count)
    {
        List<int> list = new List<int>();
        for (int i = 0; i < count; i++)
        {
            for (int j = 0; j < count; j++)
            {
                for (int k = 0; k < count; k++)
                {
                    list.Add(i);
                    list.Add(j);
                    list.Add(k);
                }
            }
        }
        return list;
    }
    
    public static List<int> TestRec2(int maxDepth, int count)
    {
        List<int> list = new List<int>();
        for (int i = 0; i < count; i++)
        {
            List<int> values = new List<int> { i };
            TestRec2(list, maxDepth, count, values, 1);
        }
        return list;
    }
    
    private static void TestRec2(List<int> list, int maxDepth, int count, List<int> values, int depth)
    {
        values.Add(0);
        for (int i = 0; i < count; i++)
        {
            values[values.Count - 1] = i;
            if (depth < maxDepth)
                TestRec2(list, maxDepth, count, values, depth + 1);
            else
                list.AddRange(values);
        }
        values.RemoveAt(values.Count - 1);
    }
    

    控制台输出

    0 0 0 0 0 1 0 1 0 0 1 1 1 0 0 1 0 1 1 1 0 1 1 1
    0 0 0 0 0 1 0 1 0 0 1 1 1 0 0 1 0 1 1 1 0 1 1 1
    

    事实上,这个任务类似于数字系统的技巧:生成所有数字,其中maxDepth是数字的长度,count是数字系统的基数。在您的情况下,您只需将这些数字中的所有数字添加到列表中。其实解决办法是这样的:

    public static List<int> TestRec3(int maxDepth, int count)
    {
        List<int> list = new List<int>();
        int length = maxDepth + 1;
        int total = (int)Math.Pow(count, length);
        for (int i = 0; i < total; i++)
        {
            int[] digits = new int[length];
            int x = i;
            for (int j = maxDepth; j >= 0 && x > 0; j--)
            {
                digits[j] = x % count;
                x /= count;
            }
            list.AddRange(digits);
        }
        return list;
    }
    

    轻松简单地完成其余的除法。

    Console.WriteLine(string.Join(" ", TestRec3(2, 2)));
    

    与控制台的输出完全相同。

    0 0 0 0 0 1 0 1 0 0 1 1 1 0 0 1 0 1 1 1 0 1 1 1
    
    • 2

相关问题

  • 使用嵌套类导出 xml 文件

  • 分层数据模板 [WPF]

  • 如何在 WPF 中为 ListView 手动创建列?

  • 在 2D 空间中,Collider 2D 挂在玩家身上,它对敌人的重量相同,我需要它这样当它们碰撞时,它们不会飞向不同的方向。统一

  • 如何在 c# 中使用 python 神经网络来创建语音合成?

  • 如何知道类中的方法是否属于接口?

Sidebar

Stats

  • 问题 10021
  • Answers 30001
  • 最佳答案 8000
  • 用户 6900
  • 常问
  • 回答
  • Marko Smith

    表格填充不起作用

    • 2 个回答
  • Marko Smith

    提示 50/50,有两个,其中一个是正确的

    • 1 个回答
  • Marko Smith

    在 PyQt5 中停止进程

    • 1 个回答
  • Marko Smith

    我的脚本不工作

    • 1 个回答
  • Marko Smith

    在文本文件中写入和读取列表

    • 2 个回答
  • Marko Smith

    如何像屏幕截图中那样并排排列这些块?

    • 1 个回答
  • Marko Smith

    确定文本文件中每一行的字符数

    • 2 个回答
  • Marko Smith

    将接口对象传递给 JAVA 构造函数

    • 1 个回答
  • Marko Smith

    正确更新数据库中的数据

    • 1 个回答
  • Marko Smith

    Python解析不是css

    • 1 个回答
  • Martin Hope
    Alexandr_TT 2020年新年大赛! 2020-12-20 18:20:21 +0000 UTC
  • Martin Hope
    Alexandr_TT 圣诞树动画 2020-12-23 00:38:08 +0000 UTC
  • Martin Hope
    Air 究竟是什么标识了网站访问者? 2020-11-03 15:49:20 +0000 UTC
  • Martin Hope
    Qwertiy 号码显示 9223372036854775807 2020-07-11 18:16:49 +0000 UTC
  • Martin Hope
    user216109 如何为黑客设下陷阱,或充分击退攻击? 2020-05-10 02:22:52 +0000 UTC
  • Martin Hope
    Qwertiy 并变成3个无穷大 2020-11-06 07:15:57 +0000 UTC
  • Martin Hope
    koks_rs 什么是样板代码? 2020-10-27 15:43:19 +0000 UTC
  • Martin Hope
    Sirop4ik 向 git 提交发布的正确方法是什么? 2020-10-05 00:02:00 +0000 UTC
  • Martin Hope
    faoxis 为什么在这么多示例中函数都称为 foo? 2020-08-15 04:42:49 +0000 UTC
  • Martin Hope
    Pavel Mayorov 如何从事件或回调函数中返回值?或者至少等他们完成。 2020-08-11 16:49:28 +0000 UTC

热门标签

javascript python java php c# c++ html android jquery mysql

Explore

  • 主页
  • 问题
    • 热门问题
    • 最新问题
  • 标签
  • 帮助

Footer

RError.com

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

帮助

© 2023 RError.com All Rights Reserve   沪ICP备12040472号-5