码迷,mamicode.com
首页 > 其他好文 > 详细

leetcode1403

时间:2020-04-05 13:24:19      阅读:52      评论:0      收藏:0      [点我收藏+]

标签:lis   思路   turn   i+1   遍历   reverse   算法思路   rev   eve   

 1 class Solution:
 2     def minSubsequence(self, nums: List[int]) -> List[int]:
 3         nums = sorted(nums,reverse=True)
 4         n = len(nums)
 5         if n == 1:
 6             return nums
 7         sums = 0
 8         presum = [0] * (n+1)
 9         
10         for i in range(n):
11             sums += nums[i]
12             presum[i+1] = presum[i] + nums[i]
13         print(sums,presum)
14         for i in range(n):
15             if presum[i+1] > sums - presum[i+1]:
16                 return nums[:i+1]

算法思路:贪心算法。

先将数组倒序排序,计算前序和数组。

然后再一次遍历,每次计算前序和与剩余部分的大小,当首次出现前序和大于剩余部分和的时候,即为所求。

leetcode1403

标签:lis   思路   turn   i+1   遍历   reverse   算法思路   rev   eve   

原文地址:https://www.cnblogs.com/asenyang/p/12636760.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!