【每日刷题】Day115

news2024/12/22 0:10:47

【每日刷题】Day115

🥕个人主页:开敲🍉

🔥所属专栏:每日刷题🍍

🌼文章目录🌼

1. LCR 089. 打家劫舍 - 力扣(LeetCode)

2. LCR 090. 打家劫舍 II - 力扣(LeetCode)

3. 740. 删除并获得点数 - 力扣(LeetCode)

1. LCR 089. 打家劫舍 - 力扣(LeetCode)

//思路:多状态动态规划。

class Solution {

public:

    int rob(vector<int>& nums)

    {

        int size = nums.size();

        if(!size) return 0;

        vector<int> f(size);

        auto g = f;

//因为0位置前没有任何数字,同时0位置又是选择偷窃,因此f[0] = nums[0]完成初始化

//而g[0],由于不选择偷窃,而前面也没有数字,因此g[0] = 0

        f[0] = nums[0];

        for(int i = 1;i<size;i++)

        {

//套用方程

            f[i] = g[i-1]+nums[i];

            g[i] = max(f[i-1],g[i-1]);

        }

//最后返回最后一个位置选择偷窃还是不偷窃之间中的最大值

        return max(f[size-1],g[size-1]);

    }

};

2. LCR 090. 打家劫舍 II - 力扣(LeetCode)

//思路:多状态动态规划。

//与打家劫舍Ⅰ的思路基本一致,区别在于,这里的房屋首尾是相连的,这会影响到第一个房子和最后一个房子。

//如果你抢了第一个房子,那么就不能够抢最后一个房子。但是环形也仅仅是影响第一个和最后一个,这中间的房子我们还可以按照打家劫舍Ⅰ的思路来做。分为以下两种情况:

① 如果我们抢了第一个房子,那么我们就不能抢第二个(1)和最后一个(n-1)房子,因此我们需要对 2~n-2 的区间做打家劫舍Ⅰ,让最后的结果加上 第一个房子

② 如果我们不选择抢第一个房子,那么我们从 1~n-1 做打家劫舍Ⅰ

最后返回两种情况下的较大值。

class Solution {

public:

    int rob(vector<int>& nums)

    {

        int size = nums.size();

        if(!size) return 0;

        if(size==1) return nums[0];

        if(size==2) return max(nums[0],nums[1]);

//f1为抢第一个房子的情况

        vector<int> f1(size);

//f2为不抢第一个房子的情况

        vector<int> f2(size);

//g1、g2对应f1、f2

        auto g1 = f1;

        auto g2 = f2;

        f1[2] = nums[2];

        f2[1] = nums[1];

//① 在2~n-2区间的房子做打家劫舍Ⅰ

        for(int i = 3;i<size-1;i++)

        {

            f1[i] = g1[i-1]+nums[i];

            g1[i] = max(f1[i-1],g1[i-1]);

        }

//最后的结果+第一个房子

        int max1 = max(f1[size-2],g1[size-2])+nums[0];

//② 在1~n-1区间的房子做打家劫舍Ⅰ

        for(int i = 2;i<size;i++)

        {

            f2[i] = g2[i-1]+nums[i];

            g2[i] = max(f2[i-1],g2[i-1]);

        }

        int max2 = max(f2[size-1],g2[size-1]);

//返回两种情况的较大值

        return max1>max2?max1:max2;

    }

};

3. 740. 删除并获得点数 - 力扣(LeetCode)

//思路:多状态动态规划。

//本题的思路其实和打家劫舍Ⅰ一模一样,只不过我们要将原数组处理一下:

class Solution {

public:

    int deleteAndEarn(vector<int>& nums)

    {

        vector<int> hash(10001);//哈希数组

        int size = nums.size(),max1 = 0;//max1代表后续对hash数组做 "打家劫舍" 的终点

        for(auto x:nums)

        {

            hash[x]+=x;//将原数组中每个数字的和映射进哈希数组中

            max1 = max1>x?max1:x;//终点就是原数组中的最大值

        }

//对hash做打家劫舍

        vector<int> f(max1+1);

        auto g = f;

        for(int i = 1;i<max1+1;i++)

        {

            f[i] = g[i-1]+hash[i];

            g[i] = max(f[i-1],g[i-1]);

        }

        return max(f[max1],g[max1]);

    }

};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2119641.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

阿里云服务器镜像,有大用处

大家好&#xff0c;我是小悟 有时候阿里云旧服务器快到期了&#xff0c;想把项目、数据、软件挪到新服务器上&#xff0c;如果全部重新搭建的话&#xff0c;那无疑是耗时又费力。有了镜像迁移&#xff0c;就方便了许多。 新旧服务器的类型要一致&#xff0c;比如都是ECS服务器…

Matlab程序练习

Part1 1.求 [100,999] 之间能被 21整除的数的个数。 程序&#xff1a; 主文件&#xff1a;main.m clear; start_num 100; end_num 999; div_num 21; res div(start_num,end_num,div_num); fprintf("[%d,%d]之间能被%d整除的数的个数为%d个\n",start_num,end_…

使用Azure+C#+visual studio开发图像目标检测系统

在这篇文章里面&#xff0c;我们讲解使用AzureC#visual studio在Azure上做图像的目标检测系统。 笔者是头一次接触C#。之前以Python Java和Scala为主。感觉C#.Net是一种挺好用的开发系统。C#和Java非常像。会一个学另一个很快。 首先&#xff0c;目标检测是个什么东西&#x…

vulhub spring 远程命令执行漏洞(CVE-2022-22963)

1.执行以下命令启动靶场环境并在浏览器访问 cd spring/CVE-2022-22963docker-compose up -ddocker ps 2.反弹shell 构造payload 3.页面刷新抓包&#xff0c;修改内容 POST /functionRouter HTTP/1.1 Host: 172.16.1.89:8080 Accept-Encoding: gzip, deflate Accept: */* Acc…

任务栏颜色怎么改?快速实现Windows系统任务栏透明,全面指南和操作实践!

任务栏是电脑操作系统的重要组成部分&#xff0c;电脑会自动为任务栏选择颜色&#xff0c;一般分为浅色&#xff08;白色&#xff09;、深色&#xff08;黑色&#xff09;。如果想要设置成自己喜欢的颜色&#xff0c;也是可以更改的&#xff0c;那么任务栏颜色怎么改呢&#xf…

实时图像处理的加速器:《基于FPGA的数字图像处理原理及应用》(可下载)

图像处理技术已成为我们生活中不可或缺的一部分。从智能手机的摄像头到卫星图像分析&#xff0c;从医疗影像到安全监控&#xff0c;图像处理技术的应用无处不在。随着技术的进步&#xff0c;我们对图像处理的速度和质量要求也越来越高。在这一背景下&#xff0c;现场可编程门阵…

CDGA|大模型数据治理的案例与实践深入剖析

随着人工智能技术的飞速发展&#xff0c;大模型在数据治理领域的应用日益广泛&#xff0c;为企业带来了前所未有的机遇与挑战。本文将通过几个具体案例&#xff0c;深入剖析大模型在数据治理中的实践应用&#xff0c;探讨其带来的变革与影响。 大模型在数据治理中的核心优势 大…

大腾智能出席龙华云创中心启动与鸿蒙园揭牌仪式

在数字化转型的浪潮中&#xff0c;深圳市龙华区再次引领行业创新&#xff0c;携手华为云成功举办“龙华工业软件云工程应用创新中心启动仪式暨鸿蒙产业园揭牌仪式”&#xff0c;本次盛会已于8月26日圆满落幕。活动现场&#xff0c;来自全国各地的行业精英、企业领袖及专家学者汇…

资料分析(2)

C B 增长量不变就是1002020 上面是利滚利:按照20%当利息 本题:涨跌幅度的意思就是增长率&#xff0c;本题是按照增长率不变的情况下进行计算D B 7551400X>1.2*100000 B B B 总体增量部分增量之和 先进行计算固定通信业务收入的增长量移动通信业务实现收入的增长量 增长量现期…

11大排序的原理讲解和Python源码剖析

排序算法 【谁教你这么剪的 | 11大排序的原理讲解和Python源码剖析】 https://www.bilibili.com/video/BV1Zs4y1X7mN/?share_sourcecopy_web&vd_sourceed4a51d52f6e5c9a2cb7def6fa64ad6a 稳定&#xff1a;如果a原本在b前面&#xff0c;而ab&#xff0c;排序之后a仍然在b…

如何实现数字孪生?看这篇就够了

数字孪生&#xff08;Digital Twin&#xff09;是一种集成了物理世界和数字世界的先进概念&#xff0c;通过高精度的模拟来反映现实世界的实体或系统。它利用物联网&#xff08;IoT&#xff09;、大数据、人工智能&#xff08;AI&#xff09;、云计算等先进技术&#xff0c;实现…

应对AI挑战的职业发展与培训策略

随着人工智能&#xff08;AI&#xff09;技术的飞速发展&#xff0c;各行各业正经历着前所未有的变革。为了在这场变革中保持竞争力并实现个人职业发展&#xff0c;职场人士需要积极应对AI带来的挑战&#xff0c;通过制定有效的职业发展与培训策略来不断提升自我。以下是几个关…

大数据决策分析平台建设方案(可编辑的56页PPT)

引言&#xff1a;在当今信息爆炸的时代&#xff0c;大数据已成为企业决策制定、业务优化与市场洞察的重要驱动力。为了充分挖掘大数据的潜在价值&#xff0c;提升决策效率与精准度&#xff0c;构建一套高效、灵活、可扩展的大数据决策分析平台显得尤为重要。通过大数据分析平台…

佰朔资本:沪指跌0.23%,金融板块集体上扬,半导体等板块下挫

6日早盘&#xff0c;沪指盘中轰动回落&#xff0c;深证成指、创业板指弱势下探&#xff0c;上证50指数逆市上扬&#xff0c;场内超4400股飘绿。 到午间收盘&#xff0c;沪指跌0.23%报2782点&#xff0c;深证成指跌1.01%&#xff0c;创业板指跌1.29%&#xff0c;上证50指数微涨…

不小心删除丢失了所有短信?如何在 iPhone 上查找和恢复误删除的短信

不小心删除了一条短信&#xff0c;或者丢失了所有短信&#xff1f;希望还未破灭&#xff0c;下面介绍如何在 iPhone 上查找和恢复已删除的短信。 短信通常都是非正式和无关紧要的&#xff0c;但短信中可能包含非常重要的信息。因此&#xff0c;如果您删除了一些短信以清理 iPh…

LeetCode第414场周赛(第一题)

目录 一&#xff1a;题目&#xff1a;3280. 将日期转换为二进制表示 一&#xff1a;题目&#xff1a;3280. 将日期转换为二进制表示 给你一个字符串 date&#xff0c;它的格式为 yyyy-mm-dd&#xff0c;表示一个公历日期。 date 可以重写为二进制表示&#xff0c;只需要将年…

idea创建一个spring项目,并编写一个初级spring项目实战(全网最详细)

1.创建spring项目 创建后界面显示 2.再pom.xml文件中添加Spring框架依赖 <dependency><groupId>org.springframework</groupId><artifactId>spring-context</artifactId><version>6.0.10</version> </dependency> 注意&…

Spring中FactoryBean的高级用法实战

❃博主首页 &#xff1a; 「码到三十五」 &#xff0c;同名公众号 :「码到三十五」&#xff0c;wx号 : 「liwu0213」 ☠博主专栏 &#xff1a; <mysql高手> <elasticsearch高手> <源码解读> <java核心> <面试攻关> ♝博主的话 &#xff1a…

AT3340-6T杭州中科微BDS定位授时板卡性能指标

AT3340-6T是一款高性能多系统卫星定位安全授时板卡&#xff0c;可通过配置支持各个单系统的定位授时。 外观尺寸&#xff1a; 电气参数 应用领域&#xff1a; 通信基站授时 电力授时 广播电视授时 轨道系统授时 金融系统授时 其他授时应用 注意事项&#xff1a; 为了充分发挥…

nvidia-smi命令视图含义

第一部分&#xff1a;NVIDIA-SMI 标题 ---------------------------------------------------------------------------------------- | NVIDIA-SMI 555.42.06 Driver Version: 555.42.06 CUDA Version: 12.5 | ------------------------------------------------------------…