鱼C论坛

 找回密码
 立即注册
查看: 3675|回复: 53

[已解决]Python:每日一题 349

[复制链接]
发表于 2020-3-11 15:34:30 | 显示全部楼层
  1. def f(m,n):
  2.     if m == 0:
  3.         list1=[]
  4.         string = 'b'*n
  5.         list1.append(string)
  6.         return list1
  7.     else:      
  8.         list3 = []
  9.         for each in f(m-1,n):
  10.             for number in range(len(each)+1):
  11.                 list3.append(each[:number]+'a'+each[number:])
  12.         return list3

  13. def d(l):
  14.     list1 = list({}.fromkeys(f((len(l[0])-1),(len(l)-1))).keys())
  15.     count = []
  16.     for each in list1:
  17.         a = 0
  18.         b = 0
  19.         n = l[a][b]
  20.         for value in each:
  21.             if value == 'a':
  22.                 b += 1
  23.                 n += l[a][b]
  24.             else:
  25.                 a += 1
  26.                 n += l[a][b]
  27.         count.append(n)
  28.     count.sort()
  29.     return count.pop()
  30.         
  31. print(d([[1,3,1],[1,5,1],[4,2,1]]))         
  32.    
复制代码
自己都有点看不下去

评分

参与人数 1荣誉 +2 鱼币 +2 收起 理由
zltzlt + 2 + 2

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-11 16:23:47 | 显示全部楼层
TJBEST 发表于 2020-3-11 14:29
此法比较费空间,但是时间上还是不慢的。

大佬,看了你的代码之后写的
  1. def f(list1,m,n):
  2.     if m>1 and n>1:
  3.         return max(f(list1,m-1,n),f(list1,m,n-1))+list1[m-1][n-1]
  4.     if m==1 and n>1:
  5.         return f(list1,m,n-1)+list1[m-1][n-1]
  6.     if m>1 and n==1:
  7.         return f(list1,m-1,n)+list1[m-1][n-1]
  8.     if m==1 and n==1:
  9.         return list1[m-1][n-1]
  10.    
  11. def d(list1):
  12.     return f(list1,len(list1),len(list1[0]))
复制代码

评分

参与人数 1荣誉 +1 鱼币 +1 收起 理由
zltzlt + 1 + 1

查看全部评分

小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-15 05:07

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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