鱼C论坛

 找回密码
 立即注册
查看: 3690|回复: 29

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

[复制链接]
发表于 2020-1-22 13:43:57 | 显示全部楼层 |阅读模式

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

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

x
本帖最后由 zltzlt 于 2020-1-22 14:17 编辑

今天的题目:


给定一个数组,返回数组中的所有子数组之和。

说明:如果数组为 [2, 4, 1],则该数组所有的子集是 [[2], [4], [1], [2, 4], [4, 1], [2, 4, 1]]

示例 1:

输入:[1, 2, 3]
输出:20
解释:(1) + (2) + (3) + (2 + 3) + (1 + 2) + (1 + 2 + 3) = 20

示例 2:

输入:[1, 2]
输出:6
解释:(1) + (2) + (1 + 2) = 6


欢迎大家一起答题!
最佳答案
2020-1-22 18:20:15
上一题不会,这一题我用递归来解决吧。实在看不懂你们的高深的方法。
  1. def func312(array):
  2.     l = len(array)
  3.     res = 0
  4.     if l == 1:
  5.         res = array[0]
  6.     elif l == 2:
  7.         res = array[0] + array[1] + (array[0] + array[1])
  8.     else:
  9.         res = func312(array[:(l-1)])
  10.         for i in range(0, l):
  11.             res += add(array[i:])
  12.     #递归法解决该问题,每添加一个元素,多出来的数组统统加一遍
  13.     return res

  14. def add(array):
  15.     res = 0
  16.     for each in array:
  17.         res += each
  18.     return res


  19. print('array [1, 2, 3]的答案是: ', func312([1, 2, 3]))
  20. print('array [1, 2]的答案是: ', func312([1, 2]))
  21. print('array [5, 2, 8, 4, 2]的答案是: ', func312([5, 2, 8, 4, 2]))
复制代码

本帖被以下淘专辑推荐:

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

使用道具 举报

发表于 2021-3-30 17:04:12 | 显示全部楼层
  1. def fun312(x):
  2.     sub_array = []
  3.     for i in range(len(x)):
  4.         for j in range(i+1,len(x)+1):
  5.             sub_array.append(x[i:j])
  6.     return sum([sum(i) for i in sub_array])
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-23 18:04:02 | 显示全部楼层
  1. def add(num:int,length,list1):
  2.     list2 = []
  3.     for i in range(length):
  4.         if i+num<=length:
  5.             list2.append(sum(list1[i:i+num]))
  6.     return list2
  7. def solve_312(list1:list):
  8.     lenght = len(list1)
  9.     sum_list = []
  10.     for i in range(1,lenght):
  11.         sum_list.extend(add(i,lenght,list1))
  12.     return sum(sum_list)+sum(list1)
  13. print(solve_312([5,2,8,4,2]))
复制代码

一把梭子直接干,暴力解决,完事收工!
请楼主帮忙测试一下,非常感谢!!!
昨天忙,没带电脑,今天补上!

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-1-23 15:03:15 | 显示全部楼层
Croper 发表于 2020-1-22 14:51
写成一行的版本

这应该是这道题最好的解法了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-23 12:31:08 From FishC Mobile | 显示全部楼层
Croper 发表于 2020-1-22 14:51
写成一行的版本

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

使用道具 举报

发表于 2020-1-23 08:46:44 | 显示全部楼层
改善了一下,不用递归了。
  1. def func312(array):
  2.     l, res = len(array), 0
  3.     for i in range(0, l):
  4.         for j in range(i+1, l+1):
  5.             for each in array[i:j]:
  6.                 res += each
  7.     return res
  8. print('array [1, 2, 3]的答案是: ', func312([1, 2, 3]))
  9. print('array [1, 2]的答案是: ', func312([1, 2]))
  10. print('array [5, 2, 8, 4, 2]的答案是: ', func312([5, 2, 8, 4, 2]))
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-1-22 22:28:29 | 显示全部楼层
zltzlt 发表于 2020-1-22 14:40
解答错误

输入:[5, 2, 8, 4, 2]

汗~是我疏忽了……
  1. def solve(lst):
  2.     res = times = 0
  3.     while len(lst)>1:
  4.         times += len(lst)
  5.         res += (lst[0]+lst[-1]) * times
  6.         #print('调试',lst[0],lst[-1],times)
  7.         lst = lst[1:-1]
  8.     else:
  9.         if lst:
  10.             res += lst[0]*(times+1)
  11.     return res
  12. if __name__ == '__main__':
  13.     print('示例1 输出:',solve([1,2,3]))
  14.     print('示例2 输出:',solve([1,2]))
复制代码

评分

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

查看全部评分

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

使用道具 举报

 楼主| 发表于 2020-1-22 20:42:44 | 显示全部楼层
TJBEST 发表于 2020-1-22 20:40
楼主试试这个,我感觉不算慢

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

使用道具 举报

发表于 2020-1-22 20:40:37 | 显示全部楼层
楼主试试这个,我感觉不算慢
  1. def fun312(arr):
  2.     if arr == []:
  3.         return 0
  4.     res = 0
  5.     N = len(arr)
  6.     for i in range(0,N//2):
  7.         alpha = (i + 1)*(N - i)
  8.         res = res + (arr[i] + arr[N - 1 - i])* alpha
  9.     if N % 2:
  10.         alpha = (N//2 + 1)*(N - N//2)
  11.         res = res + arr[N//2]*alpha
  12.     return res
复制代码

评分

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

查看全部评分

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

使用道具 举报

 楼主| 发表于 2020-1-22 20:29:13 | 显示全部楼层
TJBEST 发表于 2020-1-22 20:28
楼主先不要封题,我想到一个方法,可能比较快,一会受累测一下啊


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

使用道具 举报

发表于 2020-1-22 20:28:15 | 显示全部楼层
楼主先不要封题,我想到一个方法,可能比较快,一会受累测一下啊
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-22 19:55:41 | 显示全部楼层
  1. def fun312(lst):
  2.     t=[]
  3.     for i in range(1,len(lst)+1):
  4.         for j in range(len(lst)-i+1):
  5.             t.extend(lst[j:j+i])
  6.     return sum(t)
复制代码

可能效率低哈

评分

参与人数 1荣誉 +5 鱼币 +5 收起 理由
zltzlt + 5 + 5 效率确实低

查看全部评分

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

使用道具 举报

发表于 2020-1-22 18:20:15 | 显示全部楼层    本楼为最佳答案   
上一题不会,这一题我用递归来解决吧。实在看不懂你们的高深的方法。
  1. def func312(array):
  2.     l = len(array)
  3.     res = 0
  4.     if l == 1:
  5.         res = array[0]
  6.     elif l == 2:
  7.         res = array[0] + array[1] + (array[0] + array[1])
  8.     else:
  9.         res = func312(array[:(l-1)])
  10.         for i in range(0, l):
  11.             res += add(array[i:])
  12.     #递归法解决该问题,每添加一个元素,多出来的数组统统加一遍
  13.     return res

  14. def add(array):
  15.     res = 0
  16.     for each in array:
  17.         res += each
  18.     return res


  19. print('array [1, 2, 3]的答案是: ', func312([1, 2, 3]))
  20. print('array [1, 2]的答案是: ', func312([1, 2]))
  21. print('array [5, 2, 8, 4, 2]的答案是: ', func312([5, 2, 8, 4, 2]))
复制代码

评分

参与人数 1荣誉 +8 鱼币 +8 收起 理由
zltzlt + 8 + 8 1279 ms(不检查是否超出递归深度)

查看全部评分

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

使用道具 举报

发表于 2020-1-22 16:47:31 | 显示全部楼层
我的代码总是很长,需要改进
  1. def fun312(arr):
  2.     def inner(n):
  3.         down_gate = n - 1
  4.         up_gate = N - n
  5.         res = 0
  6.         if down_gate <= up_gate:
  7.             for i in range(0,down_gate):
  8.                 res = res + (i + 1)*arr[i]
  9.             for i in range(down_gate,up_gate + 1):
  10.                 res = res + n * arr[i]
  11.             for i in range(up_gate + 1,N):
  12.                 res = res + (N - i) * arr[i]
  13.             return res
  14.         else:
  15.             for i in range(0,up_gate):
  16.                 res = res + (i + 1)*arr[i]
  17.             for i in range(up_gate,down_gate + 1):
  18.                 res = res + (N - n + 1) * arr[i]
  19.             for i in range(down_gate + 1,N):
  20.                 res = res + (N - i) * arr[i]
  21.             return res
  22.             
  23.                
  24.     if arr == []:
  25.         return 0
  26.    
  27.     res = 0
  28.     N = len(arr)
  29.     for i in range(1,N + 1):
  30.         res = res + inner(i)
  31.     return res
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-1-22 16:16:42 | 显示全部楼层

没有,看了大神的感觉走了点弯路,,
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-22 16:07:31 | 显示全部楼层
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-22 15:30:07 | 显示全部楼层
  1. def f312(x):
  2.     s=sum(x)
  3.     n=len(x)
  4.     r=n*(n+1)//2*s
  5.     coef=[(n-i)*(n-i-1)//2 for i in range(n)]
  6.     for e in zip(x,coef,coef[::-1]):
  7.         a,b,c=e
  8.         r-=a*(b+c)
  9.     return r
复制代码

评分

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

查看全部评分

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

使用道具 举报

发表于 2020-1-22 15:02:09 | 显示全部楼层
Croper 发表于 2020-1-22 14:51
写成一行的版本

只是佩服Croper老大的头脑
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-22 15:00:55 From FishC Mobile | 显示全部楼层
看起来测试用例有点长。。。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-1-22 14:51:39 From FishC Mobile | 显示全部楼层
本帖最后由 Croper 于 2020-1-22 14:52 编辑

写成一行的版本
  1. def func312(l:list):
  2.         return sum((i+1)*(len(l)-i)*l[i] for i in range(len(l)))
复制代码

评分

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

查看全部评分

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

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-10-30 04:03

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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