热门标签 | 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);
}


推荐阅读
  • 本文探讨了Android系统中联系人数据库的设计,特别是AbstractContactsProvider类的作用与实现。文章提供了对源代码的详细分析,并解释了该类如何支持跨数据库操作及事务处理。源代码可从官方Android网站下载。 ... [详细]
  • 转自:http:blog.sina.com.cnsblog_67419c420100vmkt.html 1.为什么要使用blocks将一个blocks作为函数或者方法的参数传递,可 ... [详细]
  • 2022年4月15日的算法练习题,包括最长公共子序列和线段树的应用。 ... [详细]
  • 深入解析mt_allocator内存分配器(二):多线程与单线程场景下的实现
    本文详细介绍了mt_allocator内存分配器在多线程和单线程环境下的实现机制。该分配器以2的幂次方字节为单位分配内存,支持灵活的配置和高效的性能。文章分为内存池特性描述、内存池实现、单线程内存池实现、内存池策略类实现及多线程内存池实现等部分,深入探讨了内存池的初始化、内存分配与回收的具体实现。 ... [详细]
  • 深入解析Java并发之ArrayBlockingQueue
    本文详细探讨了ArrayBlockingQueue,这是一种基于数组实现的阻塞队列。ArrayBlockingQueue在初始化时需要指定容量,因此它是一个有界的阻塞队列。文章不仅介绍了其基本概念和数据结构,还深入分析了其源码实现,包括各种入队、出队、获取元素和删除元素的方法。 ... [详细]
  • 来自FallDream的博客,未经允许,请勿转载,谢谢。一天一套noi简直了.昨天勉强做完了noi2011今天教练又丢出来一套noi ... [详细]
  • [编程题] LeetCode上的Dynamic Programming(动态规划)类型的题目
    继上次把backTracking的题目做了一下之后:backTracking,我把LeetCode的动态规划的题目又做了一下,还有几道比较难的Medium的题和Hard的题没做出来,后面会继续 ... [详细]
  • 探讨了生成时间敏感的一次性伪随机密码的方法,旨在通过加入时间因素防止重放攻击。 ... [详细]
  • 本文详细介绍了如何将After Effects中的动画相机数据导入到Vizrt系统中,提供了一种有效的解决方案,适用于需要在广播级图形制作中使用AE动画的专业人士。 ... [详细]
  • 深入解析轻量级数据库 SQL Server Express LocalDB
    本文详细介绍了 SQL Server Express LocalDB,这是一种轻量级的本地 T-SQL 数据库解决方案,特别适合开发环境使用。文章还探讨了 LocalDB 与其他轻量级数据库的对比,并提供了安装和连接 LocalDB 的步骤。 ... [详细]
  • A1166 峰会区域安排问题(25分)PAT甲级 C++满分解析【图论】
    峰会是指国家元首或政府首脑之间的会议。合理安排峰会的休息区是一项复杂的工作,理想的情况是邀请的每位领导人都是彼此的直接朋友。 ... [详细]
  • 本文探讨了Java中有效停止线程的多种方法,包括使用标志位、中断机制及处理阻塞I/O操作等,旨在帮助开发者避免使用已废弃的危险方法,确保线程安全和程序稳定性。 ... [详细]
  • 本文介绍了一个将 Java 实体对象转换为 Map 的工具类,通过反射机制获取实体类的字段并将其值映射到 Map 中,适用于需要将对象数据结构化处理的场景。 ... [详细]
  • 如何使用Maven将依赖插件一并打包进JAR文件
    本文详细介绍了在使用Maven构建项目时,如何将所需的依赖插件一同打包进最终的JAR文件中,以避免手动部署依赖库的麻烦。 ... [详细]
  • Hadoop MapReduce 实战案例:手机流量使用统计分析
    本文通过一个具体的Hadoop MapReduce案例,详细介绍了如何利用MapReduce框架来统计和分析手机用户的流量使用情况,包括上行和下行流量的计算以及总流量的汇总。 ... [详细]
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社区 版权所有