gpt4 book ai didi

java - 没有递归的嵌套循环系列

转载 作者:行者123 更新时间:2023-11-30 09:26:16 25 4
gpt4 key购买 nike

在 Java 中,我有以下整数的通用代码 d等于 2, 3, 4, ..., dmax - 最大数量dmax : d < dmax (因此对于该范围内 d 的每个值重复此代码):

// d is the number of wrapper loops
int[] ls = new int[d];
...
// let ls array be filled with some arbitrary positive numbers here
...
// first wrapper loop
for (int i1 = 0; i1 < ls[0]; i1++) {

...

// last wrapper loop
for (int id = 0; id < ls[d - 1]; id++) {

// internal loop
for (int j = id + 1; j < ls[d - 1]; j++) {

myCode();

}

}

...

}

如果是d = 3它看起来像:

int ls = new int[3];
ls[0] = 5; ls[1] = 7; ls[2] = 5;

for (int i1 = 0; i1 < ls[0]; i1++) {

for (int i2 = 0; i2 < ls[1]; i2++) {

for (int i3 = 0; i3 < ls[2]; i3++) {

for (int j = i3 + 1; j < ls[2]; j++) {

myCode();

}

}

}

}

我想将所有重复的代码收集到一个通用的代码中。为此,我可以使用 while循环和递归如下:

int d = 2, dmax = 10;
while (d < dmax) {
// in algorithm ls is pre-filled, here its length is shown for clearance
int[] ls = new int[d];
for (int i = 0; i < ls[0]; i++) {
doRecursiveLoop(1, d, -1, ls);
}
d++;
}

doRecursiveLoop(int c, int d, int index, int[] ls) {

if (c < d) {
for (int i = 0; i < ls[c]; i++) {
// only on the last call we give the correct index, otherwise -1
if (c == d - 1) index = i;
doRecursiveLoop(c + 1, d, index, ls);
}
} else {
for (int j = index + 1; j < ls[d - 1]; j++) {

myCode();

}
}

}

任何人都可以阐明我将如何解决这个动态发生的嵌套循环而不使用递归的问题吗?

最佳答案

您实际上拥有 tail recursion这里。任何尾递归函数都可以 trivially be converted到使用循环的迭代函数。

例如:

void foo() {
// ... Stuff ...

if (someCondition) {
foo();
} else {
bar();
}
}

变成:

void foo() {
while (someCondition) {
// ... Stuff ...
}
bar();
}

关于java - 没有递归的嵌套循环系列,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14986124/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com