ryan技术小白 2021-06-08 21:57 采纳率: 100%
浏览 32
已采纳

请问我的代码为什么算的结果是错的?

给定一个数组序列, 需要求选出一个区间, 使得该区间是所有区间中经过如下计算的值最大的一个:

区间中的最小数 * 区间所有数的和最后程序输出经过计算后的最大值即可,不需要输出具体的区间。如给定序列  [6 2 1]则根据上述公式, 可得到所有可以选定各个区间的计算值:

 

[6] = 6 * 6 = 36;

[2] = 2 * 2 = 4;

[1] = 1 * 1 = 1;

[6,2] = 2 * 8 = 16;

[2,1] = 1 * 3 = 3;

[6, 2, 1] = 1 * 9 = 9;

 

从上述计算可见选定区间 [6] ,计算值为 36, 则程序输出为 36。

区间内的所有数字都在[0, 100]的范围内;

 

  • 写回答

2条回答 默认 最新

  • CSDN专家-HGJ 2021-06-09 00:37
    关注
    from itertools import combinations
    n=int(input())
    lst=list(map(int,input().split(' ',n-1)))
    #lst=sorted(lst,reverse=True)
    multiply=[]
    new_list=[]
    n = len(lst)
    s = []
    for i in range(1, n+1):
        s.extend([x for x in combinations(lst, i)])
    for x in s:
        for i in range(len(x)):
            new_list.append(x[i])
            multiply.append(min(new_list)*sum(new_list))
    print(max(multiply))
    

     如对你有帮助,请点击采纳。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 高价求中通快递查询接口
  • ¥15 解决一个加好友限制问题 或者有好的方案
  • ¥15 关于#java#的问题,请各位专家解答!
  • ¥15 急matlab编程仿真二阶震荡系统
  • ¥20 TEC-9的数据通路实验
  • ¥15 ue5 .3之前好好的现在只要是激活关卡就会崩溃
  • ¥50 MATLAB实现圆柱体容器内球形颗粒堆积
  • ¥15 python如何将动态的多个子列表,拼接后进行集合的交集
  • ¥20 vitis-ai量化基于pytorch框架下的yolov5模型
  • ¥15 如何实现H5在QQ平台上的二次分享卡片效果?