• ​力扣解法汇总1403-非递增顺序的最小子序列


    目录链接:

    力扣编程题-解法汇总_分享+记录-CSDN博客

    GitHub同步刷题项目:

    https://github.com/September26/java-algorithms

    原题链接:力扣


    描述:

    给你一个数组 nums,请你从中抽取一个子序列,满足该子序列的元素之和 严格 大于未包含在该子序列中的各元素之和。

    如果存在多个解决方案,只需返回 长度最小 的子序列。如果仍然有多个解决方案,则返回 元素之和最大 的子序列。

    与子数组不同的地方在于,「数组的子序列」不强调元素在原数组中的连续性,也就是说,它可以通过从数组中分离一些(也可能不分离)元素得到。

    注意,题目数据保证满足所有约束条件的解决方案是 唯一 的。同时,返回的答案应当按 非递增顺序 排列。

    示例 1:

    输入:nums = [4,3,10,9,8]
    输出:[10,9] 
    解释:子序列 [10,9] 和 [10,8] 是最小的、满足元素之和大于其他各元素之和的子序列。但是 [10,9] 的元素之和最大。 
    示例 2:

    输入:nums = [4,4,7,6,7]
    输出:[7,7,6] 
    解释:子序列 [7,7] 的和为 14 ,不严格大于剩下的其他元素之和(14 = 4 + 4 + 6)。因此,[7,6,7] 是满足题意的最小子序列。注意,元素按非递增顺序返回。  
    示例 3:

    输入:nums = [6]
    输出:[6]
     

    提示:

    1 <= nums.length <= 500
    1 <= nums[i] <= 100

    来源:力扣(LeetCode)
    链接:https://leetcode.cn/problems/minimum-subsequence-in-non-increasing-order
    著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    解题思路:

    * 解题思路:
    * 排序,然后求所有数的和。
    * 然后从尾开始遍历,并记录最大的序列的值。
    * 当最大的序列的值大于sum时,跳出循环。

    代码:

    1. public class Solution1403 {
    2. public List minSubsequence(int[] nums) {
    3. int sum = 0;
    4. for (int i = 0; i < nums.length; i++) {
    5. int num = nums[i];
    6. sum += num;
    7. }
    8. Arrays.sort(nums);
    9. ArrayList list = new ArrayList<>();
    10. int maxSum = 0;
    11. for (int i = nums.length - 1; i >= 0; i--) {
    12. maxSum += nums[i];
    13. sum -= nums[i];
    14. list.add(nums[i]);
    15. if (maxSum > sum) {
    16. break;
    17. }
    18. }
    19. return list;
    20. }
    21. }

  • 相关阅读:
    什么是设备运维管理系统?它对企业有什么帮助?
    信息学奥赛一本通:1170:计算2的N次方
    【环境搭建】linux docker-compose安装gitlab和redis
    深入理解Redis集群模式、协议、元数据维护方式
    HarmonyOS NEXT:华为开启全新操作系统时代
    Flink安装及简单使用
    redis + lua实现分布式接口限流实现方案
    聊聊 RocketMQ 名字服务
    最近公共祖先离线做法(tarjan)
    虚拟机改IP地址
  • 原文地址:https://blog.csdn.net/AA5279AA/article/details/126153728