第388场 LeetCode 周赛题解

A 重新分装苹果

在这里插入图片描述
在这里插入图片描述

排序

class Solution {
public:int minimumBoxes(vector<int> &apple, vector<int> &capacity) {int s = accumulate(apple.begin(), apple.end(), 0);sort(capacity.begin(), capacity.end(), greater<int>());int res = 0;for (int cur = 0, i = 0; i < capacity.size(); i++) {cur += capacity[i];res++;if (cur >= s)break;}return res;}
};

B 幸福值最大化的选择方案

在这里插入图片描述
在这里插入图片描述

贪心:优先选幸福值较大的孩子,降序排序然后边遍历

class Solution {
public:long long maximumHappinessSum(vector<int> &happiness, int k) {long long res = 0;sort(happiness.begin(), happiness.end(), greater<int>());for (int i = 0; i < k; i++)res += max(0, happiness[i] - i);return res;}
};

C 数组中的最短非公共子字符串

在这里插入图片描述
在这里插入图片描述

哈希 + 二分:设 c n t [ s ] cnt[s] cnt[s] a r r arr arr 中包含子字符串 s s s 的元素数,遍历 a r r arr arr 中的字符串 s s s ,枚举其所有子字符串,并更新 c n t cnt cnt ,遍历 a r r arr arr 中的字符串 s s s ,二分搜素最短长度 m i d mid mid ,然后枚举 s s s 长为 m i d mid mid 的子字符串,判断是否存在满足条件的子字符串

class Solution {
public:vector<string> shortestSubstrings(vector<string> &arr) {int mxn = 0;unordered_map<string, int> cnt;for (auto &s: arr) {mxn = max(mxn, (int) s.size());unordered_set<string> tmp;for (int i = 0; i < s.size(); i++) {//枚举s的子字符串string cur = "";for (int j = i; j < s.size(); j++) {//s[i,j]cur.push_back(s[j]);tmp.insert(cur);}}for (auto &subs: tmp)//更新cntcnt[subs]++;}vector<string> res;for (auto &s: arr) {int l = 1, r = s.size() + 1;string res_i;while (l < r) {//二分搜素满足条件的子字符串的最短长度int mid = (l + r) / 2;string cur_res;for (int i = 0; i + mid - 1 < s.size(); i++) {if (auto subs = s.substr(i, mid);cnt[subs] == 1) {if (cur_res.empty() || subs < cur_res)//满足条件且字典序最小cur_res = subs;}}if (!cur_res.empty()) {r = mid;res_i = cur_res;} elsel = mid + 1;}res.push_back(l != s.size() + 1 ? res_i : "");}return res;}
};

D K 个不相交子数组的最大能量值

在这里插入图片描述
在这里插入图片描述

动态规划: 设 p [ i + 1 ] [ j ] [ t a g ] p[i+1][j][tag] p[i+1][j][tag] 表示在 n u m s [ 0 , i ] nums[0,i] nums[0,i] 中选择 j j j 个不相交的子数组的最大能量值(tag为 0 0 0 表示选择的数中不包含 n u m s [ i ] nums[i] nums[i] ,tag为 1 1 1 表示选择的数中包含 n u m s [ i ] nums[i] nums[i])。

class Solution {
public:using ll = long long;ll inf = INT64_MIN;long long maximumStrength(vector<int> &nums, int k) {vector<ll> vx;for (int i = k, pos = 1; i >= 1; i--, pos ^= 1)vx.push_back(pos == 1 ? i : -1 * i);int n = nums.size();ll p[n + 1][k + 1][2];for (int i = 0; i <= n; i++)for (int j = 0; j <= k; j++)for (int t = 0; t < 2; t++)p[i][j][t] = inf;//初始化标志for (int i = 0; i <= n; i++)p[i][0][0] = p[i][0][1] = 0;//未选择的情况for (int i = 0; i < n; i++) {for (int j = 1; j <= min(i + 1, k); j++) {p[i + 1][j][1] = p[i][j - 1][1] + nums[i] * vx[j - 1];//nums[i] 为一个新选择的子数组的首元素if (p[i][j][1] != inf)p[i + 1][j][1] = max(p[i + 1][j][1], p[i][j][1] + nums[i] * vx[j - 1]);//nums[i]为上一个选择的子数组中的元素if (p[i][j - 1][0] != inf)p[i + 1][j][1] = max(p[i + 1][j][1], p[i][j - 1][0] + nums[i] * vx[j - 1]);//nums[i]为一个新选择的子数组的首元素p[i + 1][j][0] = max(p[i][j][0], p[i][j][1]);}}ll res = inf;for (int i = k - 1; i < n; i++)res = max({res, p[i + 1][k][0], p[i + 1][k][1]});return res;}
};

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

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

相关文章

STM32系列——F103C8T6 控制SG90舵机(HAL库)

文章目录 一、舵机控制原理二、.CubeMX配置配置RCC、SYS、时钟树配置RCC配置SYS配置时钟树配置定时器产生PWM波形 Keil5代码接线图及效果如果您发现文章有错误请与我留言&#xff0c;感谢 一、舵机控制原理 舵机的控制一般需要一个20ms左右的时基脉冲&#xff0c;该脉冲的高电平…

【MatLab】之:Simulink安装

一、内容简介 本文介绍如何在 MatLab 中安装 Simulink 仿真工具包。 二、所需原材料 MatLab R2020b&#xff08;教学使用&#xff09; 三、安装步骤 1. 点击菜单中的“附加功能”&#xff0c;进入附加功能管理器&#xff1a; 2. 在左侧的“按类别筛选”下选择Using Simulin…

基于Springboot+Redis+mysql实现的闲置二手交易网站管理系统

1.1 背景分析 二手商品是学生比较青睐的廉价商品&#xff0c;网站设计应着重突出实用和廉价。也有一部分消费者是淘宝者&#xff0c;他们对相中的商品有着急切的拥有欲望。网上交易的好学生提供一个供需平台&#xff0c;学生可以将自己不用的东西放在网上&#xff0c;也可在网…

通过更新路书当前坐标下marker的icon来展示沿途的风景

通过更新路书当前坐标下marker的icon来展示沿途的风景 1.效果图2.[工程链接](https://download.csdn.net/download/m0_61864577/88978866)3.需修改地方: 本文演示了如何通过百度地图的路书功能,展示途经的风景。定时缩放,既有全局路径,又有当前位置和运动轨迹;可以显示当前坐标…

力扣59. 螺旋矩阵 II

思路&#xff1a;此题思路就是绕圈遍历&#xff0c;全靠条件处理技巧&#xff0c;重点要清楚的就是循环不变量&#xff1a;左闭右开&#xff08;即拐弯处的一个数&#xff0c;留给第二行处理&#xff09; 以下是代码随想录的作者的一张图片&#xff0c;每次for循环&#xff0c;…

SQL的执行与优化

文章目录 MySQL查询原理与优化一、select语句的执行顺序二、join 的执行与优化1、驱动表 & 被驱动表2、Simple Nested Loop Join3、Index Nested Loop Join4、Block Nested Loop Join5、Hash Join6、join 优化小结 三、on 与 where 对比四、group by 的执行与优化1、group …

拜占庭将军问题相关问题

1、拜占庭将军问题基本描述 问题 当我们讨论区块链共识时&#xff0c;为什么会讨论拜占庭将军问题&#xff1f; 区块链网络的本质是一个分布式系统&#xff0c;在存在恶意节点的情况下&#xff0c;希望 整个系统当中的善良节点能够对于重要的信息达成一致&#xff0c;这个机…

设计模式 --3:装扮模式

结构图 代码 #include<iostream>using namespace std;class person { public:person() {};person(string name) { this->name name; }virtual void show() {cout << "装扮的:" << this->name << endl;} private:string name; }; //装…

C语言中,基本数据类型介绍

C语言当中各种数据类型的大小&#xff0c;首先要了解有哪些数据类型。 一 字符型&#xff1a; 整数&#xff08;字符&#xff09;类型存储大小值范围char1 字节-128 到 127 或 0 到 255&#xff08;2的8次方&#xff09;unsigned char1 字节0 到 255&#xff08;&#xff09;s…

搭建个人智能家居 3 -第一个设备“点灯”

搭建个人智能家居 3 -第一个外设“点灯” 前言ESPHome点灯 HomeAssistant 前言 前面我们已经完成了搭建这个智能家居所需要的环境HomeAssistant和ESPHome&#xff0c;今天我们开始在这个智能家居中添加我们的第一个设备&#xff08;一颗LED灯&#xff09;&#xff0c;如果环境…

vim | 介绍vim以及配置vimrc文件

好像熟练使用vim 是玩linux 必修课 当然&#xff0c;初代玩家能在vim 完成编辑 并保存已是入门了&#xff0c;想当初在大学的时候&#xff0c;死活转不过来&#xff0c;玩不过来&#xff0c;甚至有些恐惧 但后来&#xff0c;弄清楚原理&#xff0c;反倒觉得简简单单已是完美了。…

HSE化工应急安全生产管理平台:衢州某巨大型化工企业的成功应用

在化工行业中&#xff0c;安全生产一直是至关重要的议题。为了提高生产安全性、降低成本并提升企业形象&#xff0c;衢州某巨大型化工企业引入了HSE化工应急安全生产管理平台&#xff0c;取得了显著的改善和获益。 该平台的核心功能包括风险管理和应急预案制定。通过对化工生产…

HJ212协议C#代码解析实现

HJ212协议C#代码解析实现 HJ212协议是环保中一个非常重要的标准协议&#xff08;字符串协议&#xff09;&#xff0c;之前写了两篇C HJ212协议解析的相关博文&#xff1a; 环保 HJ212协议解析基于Qt5.14.2的HJ212 TCP服务端接收解析入库程序 最近在学习C#&#xff0c;所以打算…

【原创】java+swing+mysql二手车交易管理系统

前言&#xff1a; 本文主要介绍了二手车交易管理设计与实现。首先&#xff0c;通过市场需求&#xff0c;我们确定了二手车的功能&#xff0c;通常的二手车交易系统都是B/S架构&#xff0c;然而我们今天要用javaswing去开发一个C/S架构的二手车交易管理系统&#xff0c;主要功能…

面试经典-33-反转链表 II

题目 给你单链表的头指针 head 和两个整数 left 和 right &#xff0c;其中 left < right 。请你反转从位置 left 到位置 right 的链表节点&#xff0c;返回 反转后的链表 。 示例 1&#xff1a; 输入&#xff1a;head [1,2,3,4,5], left 2, right 4 输出&#xff1a…

【运维】PVE 自带监控显示问题处理

目录 问题描述 问题处理 问题描述 CPU和服务器负载显示为1970-01-01&#xff0c;无法正确显示当前监控 问题处理 使用如下命令 rm /var/lib/rrdcached/db/* -rf刷新网页显示如下

论文浅尝 | GPT-RE:基于大语言模型针对关系抽取的上下文学习

笔记整理&#xff1a;张廉臣&#xff0c;东南大学硕士&#xff0c;研究方向为自然语言处理、信息抽取 链接&#xff1a;https://arxiv.org/pdf/2305.02105.pdf 1、动机 在很多自然语言处理任务中&#xff0c;上下文学习的性能已经媲美甚至超过了全资源微调的方法。但是&#xf…

day10-SpringBootWeb案例-1

一、准备工作 1 需求&环境搭建 步骤&#xff1a; 准备数据库表(dept、emp)创建 springboot 工程&#xff0c;引入对应的起步依赖&#xff08;web、mybatis、mysql 驱动、lombok&#xff09;配置文件 application.properties 中引入 mybatis 的配置信息&#xff0c;准备对应…

【JAVA】JAVA方法的学习和创造

&#x1f308;个人主页: Aileen_0v0 &#x1f525;热门专栏: 华为鸿蒙系统学习|计算机网络|数据结构与算法|MySQL| ​&#x1f4ab;个人格言:“没有罗马,那就自己创造罗马~” 前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不…

算法导论第十一章思考题参考答案(21)

Ploblem 11-1 a.从所有可能的索引中统一计算每个探针的索引。由于我们有 n≤m/2&#xff0c;我们知道在任何阶段至少有一半的指标是空的。因此&#xff0c;对于需要超过 k 个探针&#xff0c;我 们需要在每 k 个第一个探针中&#xff0c;我们探测到一个已经有一个入口的顶点&a…