力扣740-删除并获得点数

2024-02-19 06:32
文章标签 力扣 删除 点数 获得 740

本文主要是介绍力扣740-删除并获得点数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

        当选了第i个数的时候就不能再选第i-1和第i+1的数,则在解题的时候可以考虑将原始数组转为可以利用动态规划算法的数组处理,这样就比较简单了。只是这样空间复杂度会增加一点。

package likou;
/** 删除并获得点数* 题干:* 	给你一个整数数组nums,你可以对它进行一些操作;* 	每次操作中,选择任意一个nums[i]删除它并获得 nums[i]的点数;* 	 	然后你必须删除所有等于nums[i]-1和nums[i]+1的元素* 	开始你拥有 0 个点数,返回你能通过这些操作获得的最大点数;*/
public class Demo740 {/** 假设输入数组为nums,其中1 <= nums[i] <= 10000* 删除第i个元素,int temp = nums[i];* 则要求删除num数组中所有值等于temp-1和temp+1的值,然后再重新选* 要求返回的数字最大,则肯定是要能选点数最多的数据尽可能多* 	所选的数据尽可能多* 设计思路:* 		步骤1.先定义一个数组,下标为nums[i]的值,则i需要取nums数组中的最大值*      步骤2.对nums数组遍历,下标为nums[i]的值,相当于把数组转为满足打家劫舍条件的数组*      步骤3,按打家劫舍算法对数据进行处理(如取了[i]的值,则[i-1]和[i+1]两个相邻的数据都不能选)*/public int deleteAndEarn(int[] nums) {int maxValue = nums[0];for (int i = 0; i < nums.length; i++) {int temp = nums[i];maxValue = Math.max(maxValue, temp);}int[] tempNums = new int[maxValue+1];for (int j = 0; j < nums.length; j++) {int tempNum = nums[j];tempNums[tempNum] = tempNums[tempNum] + nums[j];}int p1 = tempNums[0];int p2 = Math.max(p1, tempNums[1]);int p3 = 0;for (int k = 2; k <tempNums.length; k++) {p3 = Math.max(p1 + tempNums[k], tempNums[k - 1]);p1 = tempNums[k - 1];p2 = p3;}return p3;}public static void main(String args[]) {Demo740 demo = new Demo740();int[] nums = {2,2,3,3,3,4};System.out.println(demo.deleteAndEarn(nums));}
}

这篇关于力扣740-删除并获得点数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/723782

相关文章

电脑不小心删除的文件怎么恢复?4个必备恢复方法!

“刚刚在对电脑里的某些垃圾文件进行清理时,我一不小心误删了比较重要的数据。这些误删的数据还有机会恢复吗?希望大家帮帮我,非常感谢!” 在这个数字化飞速发展的时代,电脑早已成为我们日常生活和工作中不可或缺的一部分。然而,就像生活中的小插曲一样,有时我们可能会在不经意间犯下一些小错误,比如不小心删除了重要的文件。 当那份文件消失在眼前,仿佛被时间吞噬,我们不禁会心生焦虑。但别担心,就像每个问题

力扣SQL50 每位经理的下属员工数量 join

Problem: 1731. 每位经理的下属员工数量 👨‍🏫 参考题解 Code select m.Employee_id, m.name,count(*) reports_count,round(avg(e.age),0) average_agefrom Employees ejoin Employees mon e.reports_to = m.Employee_id

如何在OS中获得SSD的寿命耐久度

这里还是以DELL的机器为例,通常DELL的服务器带有的磁盘会有显示SSD耐久度,当然也不排除SSD更新太快,有部分SSD无法在戴尔的服务器上查看到SSD的耐久度,但实际上本身只要是SSD肯定还是可以有方法查看SSD的耐久度,可以通过OS的方式进行查看,以RHEL7.9为例 首先我们需要下载安装DELL的PERCCLI的阵列卡工具,该工具可以很好的查看DELL服务器上的阵列卡对应的信息,如阵列卡

red hat enterprise 下完全删除oracle 数据库

步骤 1     以 oracle 用户登录主、备节点。 步骤 2     关闭 数据库 监听。 > lsnrctl stop 步骤 3     关闭数据库 实例 。 > sqlplus '/as sysdba' > shutdown immediate 步骤 4     以root用户登录数据库 服务器 。 步骤 5     删除Oracle用户。 # userdel -r or

【JavaSE ⑧】P219 ~ 225 Date类‘’DateFormat类转化Date和字符串;Calendar类获得日历中某值,修改日历,日历转日期

目录 日期时间类1 Date类概述常用方法 2DateFormat类构造方法格式规则常用方法parse方法format方法 3 Calendar类概念获取方式常用方法get/set方法add方法getTime方法 ● 练习1.判断Date不同参数构造的输出2. 用日期时间相关的API,计算一个人已经出生了多少天。3. 获取Calendar对象,输出日历当前年,月,日4. 把日历转换为日期

删除第三方AAR所请求的权限

1.问题:引了第三方的AAR库要求一些权限,但我APP不需要,我想删除掉,怎么办 答:很简单,只要在添加:http://schemas.android.com/tools 这个工具在manifest文件中,然后在相应的权限上增加:tools:node="remove"即可。 <manifest xmlns:android="http://schemas.android.com/apk/res/a

leetcode刷题(40)——83. 删除排序链表中的重复元素

给定一个排序链表,删除所有重复的元素,使得每个元素只出现一次。 示例 1: 输入: 1->1->2 输出: 1->2 示例 2: 输入: 1->1->2->3->3 输出: 1->2->3 平时我们删除一个链表中的某个元素,一般都是以下的写法: temp.next = temp.next.next; 这样temp.next就被删除了 此题解法如下: class Solution

client-go删除job同时删除job关联的pod

问题描述 client-go使用以下方式删除job时,并不会把其关联的pod删除,从而导致这些pod成为了孤儿(orphan): err := clientSet.BatchV1().Jobs(namespace).Delete(name, &metav1.DeleteOptions{}) 在删除job的时候将job关联的pod也删除的方法: propagationPolicy := m

力扣SQL50 游戏玩法分析 IV 子查询

Problem: 550. 游戏玩法分析 IV 👨‍🏫 参考题解 这个SQL查询的目的是计算每个玩家在登录后的第二天参与活动的比例。查询使用了子查询和左连接来实现这一目的。下面是查询的详细解释,包括每个部分的作用和注释: -- 计算每个玩家登录后第二天参与活动的比例select round(avg(a.event_date is not null), 2) as fractio

listView的item向左滑动实现删除

有一种删除功能是这样的: ListView的item向左滑动,实现删除功能 注释很清楚,简单明了 1.自定义LeftDeleteView.java继承HorizontalScrollView.java public class LeftDeleteView extends HorizontalScrollView { private int start;//开始滑动的位