【问题标题】:Specific Algorithm for determining all multiple of a number确定一个数的所有倍数的特定算法
【发布时间】:2018-06-17 00:38:17
【问题描述】:

我正在尝试为我正在做的项目确定算法。目标是获得所有数字组合序列,其中每个相邻数字的最大值是彼此的倍数。数字和序列长度是输入。

示例: 如果我输入 sequence length 3ma​​x number 5 我应该得到这样的输出。

[ 1, 1, 1 ]
[ 1, 1, 2 ]
[ 1, 1, 3 ]
[ 1, 1, 4 ]
[ 1, 2, 4 ]
[ 1, 3, 3 ]
[ 1, 4, 4 ]
[ 2, 2, 2 ]
[ 2, 2, 4 ]
[ 2, 4, 4 ]
[ 3, 3, 3 ]
[ 4, 4, 4 ]

在所有序列中,每个数字都是其前一个邻居的倍数,而所有数字都小于 5,这是作为输入给出的最大值。

【问题讨论】:

  • 到目前为止你尝试过什么?
  • 我尝试了一种顺序算法,它没有让我到达任何我想要的地方,我正在尝试实现一棵树,其中根是每个序列的唯一初始数字,所以在示例中,我们得到4 棵树。

标签: algorithm


【解决方案1】:

您可以使用回溯来获取您想要的所有序列。

回溯与 DFS 非常相似。您可以制作使用参数{您在序列中放入多少个数字}的递归函数,并在将适当的值放入序列(参数+ 1)后调用递归函数。 在函数结束时,您必须清除您按顺序输入的数字。 如果序列已满,您也将终止该功能。

【讨论】:

  • 你能用一些代码或伪代码解释更多吗?
【解决方案2】:
int seq[105];

void f(int idx) {
    if(idx == length) print();
    for(int i=1;1;i++) {
        if(i*seq[idx-1] > max_number) break;
        seq[idx]=i*seq[idx-1];
        f(idx+1);
        seq[idx]=0;
    }

【讨论】:

  • 如果您可以发布完整代码并最好编辑自己的答案,
猜你喜欢
  • 2012-07-26
  • 2012-09-07
  • 2019-06-07
  • 2015-11-30
  • 2017-01-24
  • 2015-05-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多