猿问

忽略排除条件的递归函数

我可能很厚,但我很困惑为什么这个递归函数忽略了我提供的排除条件。


在下面的代码中,我取一个基值,并从另一个函数中获取对应值的列表。列表中的每个值都需要被处理,并且需要获取它自己的对应值列表,为此会发生相同的过程,直到处理完所有相关值。


为避免两次处理任何值,我在其中添加了一个条件the_loop,旨在仅处理尚未处理的值。每次处理一个值时,它都会被添加到排除列表中,并且应该跳过循环。


def the_recursive_func(key):

   values = get_values(key) # values is a list of numbers

   processed_values = {}


   def the_loop(list_of_values):

      not_processed = [v for v in list_of_values if v not in processed_values.keys()]


      for v in not_processed:

          processed = process_value(v)

          processed_values[v] = processed

          new_values_list = get_values(v)

          the_loop(new_values_list)


   the_loop(values)

   return processed_values

相反,我两次处理了很多值。我正在努力看看这是哪里出了问题。如果我将 for 循环更改为:


      for v in not_processed:

          if v in processed_values.keys():

             continue

          processed = process_value(v)

          processed_values[v] = processed

          new_values_list = get_values(v)

          the_loop(new_values_list)

然后我得到了我正在寻找的结果,但是 A)这是意大利面条,并且 B)我缺少一些基本的东西,为什么初始代码不起作用。


BIG阳
浏览 83回答 1
1回答

拉莫斯之舞

您只是在函数开头排除值。如果您需要排除在循环的早期迭代中处理的值(可能在递归中),则需要在每次循环中进行测试。    def the_loop(list_of_values):        for v in list_of_values:            if v in processed_values:                continue            processed = process_value(v)            processed_values[v] = processed            new_values_list = get_values(v)            the_loop(new_values_list)
随时随地看视频慕课网APP

相关分类

Python
我要回答