鱼C论坛

 找回密码
 立即注册
查看: 1275|回复: 3

[已解决]递归函数问题

[复制链接]
发表于 2018-2-8 04:26:08 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
定义一个 递归函数 lst2set(lst) 满足一下条件:

  1. assert lst2set([1,2,[3,[4,5]]]) == {1,2,3,4,5}
  2. assert lst2set([1,3,[[5,[7,6]]],[22]]) == {22,1,3,5,6,7}
复制代码
最佳答案
2018-2-8 10:00:08
  1. def lst2set(lst,sets=set()):
  2.         if lst:
  3.                 if isinstance(lst[0], list):
  4.                         return lst2set(lst[0]+lst[1:],sets)
  5.                 else:
  6.                         sets.add(lst[0])
  7.                         return lst2set(lst[1:], sets)
  8.         else:
  9.                 return sets
  10. print(lst2set([1,2,[3,[4,5]]]))
  11. print(lst2set([1,3,[[5,[7,6]]],[22]]))
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2018-2-8 09:05:55 | 显示全部楼层
这规律还得自己找?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-8 09:15:34 From FishC Mobile | 显示全部楼层
函数对传进来的lst参数做些处理,取lst 列表长度,,取列表成员类型,如果是列表就调用自己,返回自己处理好的列表,我是新人,这是我的思路,希望帮到你,代码不会写!_!
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-2-8 10:00:08 | 显示全部楼层    本楼为最佳答案   
  1. def lst2set(lst,sets=set()):
  2.         if lst:
  3.                 if isinstance(lst[0], list):
  4.                         return lst2set(lst[0]+lst[1:],sets)
  5.                 else:
  6.                         sets.add(lst[0])
  7.                         return lst2set(lst[1:], sets)
  8.         else:
  9.                 return sets
  10. print(lst2set([1,2,[3,[4,5]]]))
  11. print(lst2set([1,3,[[5,[7,6]]],[22]]))
复制代码
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-5-18 20:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表