热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

leetcode330给定数组,按要求进行补齐操作

packagecom.example.lettcode.dailyexercises;***@ClassMinPatches*@Description330按要求补齐数组*给定一个

package com.example.lettcode.dailyexercises;
/**
* @Class MinPatches
* @Description 330 按要求补齐数组
* 给定一个已排序的正整数数组 nums,和一个正整数 n 。从 [1, n] 区间内选取任意个数字补充到 nums 中,使得 [1, n] 区间内的任何数字都
* 可以用 nums 中某几个数字的和来表示。请输出满足上述要求的最少需要补充的数字个数。
*


* 示例 1:
*


* 输入: nums = [1,3], n = 6
* 输出: 1
* 解释:
* 根据 nums 里现有的组合 [1], [3], [1,3],可以得出 1, 3, 4。
* 现在如果我们将 2 添加到 nums 中, 组合变为: [1], [2], [3], [1,3], [2,3], [1,2,3]。
* 其和可以表示数字 1, 2, 3, 4, 5, 6,能够覆盖 [1, 6] 区间里所有的数。
* 所以我们最少需要添加一个数字。
*


* 示例 2:
*


* 输入: nums = [1,5,10], n = 20
* 输出: 2
* 解释: 我们需要添加 [2, 4]。
*


*


* 示例 3:
*


* 输入: nums = [1,2,2], n = 5
* 输出: 0
* @Author
* @Date 2020/12/29
**/
public class MinPatches {
/**
* 贪心算法
*
* @param nums
* @param n
* @return
*/
public static int minPatches(int[] nums, int n) {
int patchCount = 0;
int index = 0;
long miss = 1;
while (miss <= n) {
if (index // 当Miss能找到时,说明能直接覆盖到[1,miss+nums[index]-1)
miss += nums[index++];
}
else {
// 当找不到miss时,数组中添加miss,miss能找到说明能直接覆盖到[1,2*miss)
miss += miss;
patchCount++;
}
}
return patchCount;
}
}

//测试用例
public static void main(String[] args) {
int[] nums = new int[]{1, 3};
int n = 6;
int ans = minPatches(nums, n);
System.out.println("MinPatches demo01 result:" + ans);
nums = new int[]{1, 5, 10};
n = 20;
ans = minPatches(nums, n);
System.out.println("MinPatches demo02 result:" + ans);
nums = new int[]{1, 2, 2};
n = 5;
ans = minPatches(nums, n);
System.out.println("MinPatches demo03 result:" + ans);
nums = new int[]{};
n = 8;
ans = minPatches(nums, n);
System.out.println("MinPatches demo04 result:" + ans);
}


推荐阅读
  • 在金融和会计领域,准确无误地填写票据和结算凭证至关重要。这些文件不仅是支付结算和现金收付的重要依据,还直接关系到交易的安全性和准确性。本文介绍了一种使用C语言实现小写金额转换为大写金额的方法,确保数据的标准化和规范化。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文介绍了如何通过 Maven 依赖引入 SQLiteJDBC 和 HikariCP 包,从而在 Java 应用中高效地连接和操作 SQLite 数据库。文章提供了详细的代码示例,并解释了每个步骤的实现细节。 ... [详细]
  • 本文介绍如何使用阿里云的fastjson库解析包含时间戳、IP地址和参数等信息的JSON格式文本,并进行数据处理和保存。 ... [详细]
  • 深入解析Android自定义View面试题
    本文探讨了Android Launcher开发中自定义View的重要性,并通过一道经典的面试题,帮助开发者更好地理解自定义View的实现细节。文章不仅涵盖了基础知识,还提供了实际操作建议。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 1:有如下一段程序:packagea.b.c;publicclassTest{privatestaticinti0;publicintgetNext(){return ... [详细]
  • 本文介绍如何利用动态规划算法解决经典的0-1背包问题。通过具体实例和代码实现,详细解释了在给定容量的背包中选择若干物品以最大化总价值的过程。 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
  • 本文深入探讨了 Java 中的 Serializable 接口,解释了其实现机制、用途及注意事项,帮助开发者更好地理解和使用序列化功能。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Android 渐变圆环加载控件实现
    本文介绍了如何在 Android 中创建一个自定义的渐变圆环加载控件,该控件已在多个知名应用中使用。我们将详细探讨其工作原理和实现方法。 ... [详细]
  • UNP 第9章:主机名与地址转换
    本章探讨了用于在主机名和数值地址之间进行转换的函数,如gethostbyname和gethostbyaddr。此外,还介绍了getservbyname和getservbyport函数,用于在服务器名和端口号之间进行转换。 ... [详细]
  • 2023年京东Android面试真题解析与经验分享
    本文由一位拥有6年Android开发经验的工程师撰写,详细解析了京东面试中常见的技术问题。涵盖引用传递、Handler机制、ListView优化、多线程控制及ANR处理等核心知识点。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
author-avatar
SOCHUNGKWAN
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有