LeetCode---127双周赛

题目列表

3095. 或值至少 K 的最短子数组 I

3096. 得到更多分数的最少关卡数目

3097. 或值至少为 K 的最短子数组 II

3098. 求出所有子序列的能量和

一、或值至少k的最短子数组I&II

暴力的做法大家都会,这里就不说了,下面我们来看看如何进行优化

其实看到题目,我们就差不多有一个优化的思路:子数组+区间性质 => 滑动窗口,我们需要维护一个或值至少为k的区间(或运算满足数字越多,结果越大的单调性,所以用滑动窗口是可以的

滑动窗口三个步骤:进窗口,判断是否出窗口以及何时更新答案

进窗口时维护区间或值很简单,只要或上当前元素就行,但是我们如何在元素出窗口时,维护区间的或值呢?或运算的本质就是看bit位上是否有1,我们只要维护一个数据用来记录每个bit位上1出现的次数,就能很快的得出当前区间的或值

代码如下

class Solution {
public:int minimumSubarrayLength(vector<int>& nums, int k) {int n = nums.size();int ans = n + 1, or_ = 0;int cnt[32] = { 0 };for(int l = 0, r = 0; r < n; r++){or_ |= nums[r];for(int i = 0; i < 32; i++)cnt[i] += (nums[r]>>i)&1;while(or_ >= k && l <= r){ // 这里一般是不用加l<=r这个条件的,这里是因为k=0会导致越界问题ans = min(ans, r-l+1);for(int i = 0; i < 32; i++){if((nums[l]>>i)&1){if(--cnt[i]==0)or_ &= (~(1<<i));}}l++;}}return ans==n+1?-1:ans;}
};

这里在提供一种方法(or通用模板),如下

代码如下

class Solution {
public:int minimumSubarrayLength(vector<int>& nums, int k) {int n = nums.size();int ans = INT_MAX;vector<pair<int,int>> v;for(int i = 0; i < n; i++){v.emplace_back(0,i); // 以i位左端点,or_ = 0,后面会让它|nums[i]int j = 0;for(auto& p:v){auto&[or_,left] = p;or_ |= nums[i]; // 区间为[left,i]if(or_ >= k)ans = min(ans,i-left+1);if(v[j].first == or_) // 当or_相等时,保留最靠右的左端点下标v[j].second = left;elsev[++j]=p;}v.resize(j+1); // 去重}return ans == INT_MAX?-1:ans;}
};

二、得到更多分数的最少关卡数目

题目说的很复杂,其实很简单,就是模拟,我们只要将数组分为左右两个部分,要求左边部分的得分大于右边部分的得分,问左边部分的最少关卡数(注意:题目要求每个玩家至少要完成一个关卡)代码如下

class Solution {
public:int minimumLevels(vector<int>& possible) {int s = 0;for(auto x:possible)s += 2*x-1;int n = possible.size();for(int i = 0,pre = 0; i < n-1; i++){pre += 2*possible[i]-1;if(pre > s - pre)return i + 1;}return -1;}
};

三、求出所有子序列的能量和

子序列问题一般和顺序无关,这题也一样,我们先给数组排序。问子序列的能量(最小差值),只可能是相邻元素间的差才可能是子序列的能量(排完序后),显然该问题是个经典的相邻相关的子序列问题,即需要记录它的上一个数字是多少,再结合选或不选的思想,我们很容易得到下面这样一个递归函数定义

设 dfs(i,j,pre,mn) 表示 从nums[0]~nums[i]中再选j个充当子序列中的元素,其中pre表示上一个选择的元素,mn记录nums[i+1]~nums[n-1]中选出的k-j个数之间的最小差值,返回值表示已选出的数字组成的子序列的能量

递归入口: 

dfs(n-1,k,INT_MAX/2,INT_MAX/2)

递归出口:

  • j==0时,返回mn --- 表示当前子序列的能量为mn
  • j>i+1时,返回0 --- 剩余元素个数不足j个,不能构成符合要求的子序列,不贡献能量,返回0

递归转移方程:

  • 不选当前元素作为子序列元素:dfs(i-1,j,pre,mn) 
  • 选当前元素作为子序列元素:dfs(i-1,j-1,nums[i],min(mn,pre-nums[i]))

dfs(i,j,pre,mn) = dfs(i-1,j,pre,mn) + dfs(i-1,j-1,nums[i],min(mn,pre-nums[i]))

代码如下

class Solution {
public:int sumOfPowers(vector<int>& nums, int k) {int n = nums.size();sort(nums.begin(),nums.end());const int MOD = 1e9+7;unordered_map<int,unordered_map<int,unordered_map<int,unordered_map<int,int>>>> mp;function<int(int,int,int,int)>dfs=[&](int i,int j,int pre,int mn)->int{if(j==0) return mn;if(j>i+1) return 0;if(mp.count(i)&&mp[i].count(j)&&mp[i][j].count(pre)&&mp[i][j][pre].count(mn))return mp[i][j][pre][mn];int res1 = dfs(i-1,j,pre,mn); // 不选int res2 = dfs(i-1,j-1,nums[i],min(mn,pre-nums[i])); // 选return mp[i][j][pre][mn]=(res1+res2)%MOD;};return dfs(n-1,k,INT_MAX/2,INT_MAX/2);}
};

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

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

相关文章

1、快速上手Docker:入门指南

文章目录 Linux中安装docker防火墙端口配置web项目需要的环境安装yarn安装nodejs安装脚手架并准备项目 构建镜像启动镜像查看日志管理镜像推送镜像 发布项目准备服务器环境部署项目&#xff1a; PS&#xff1a;扩展一点小知识 这篇文章只是docker入门的第一个Docker项目&#x…

STM32使用HAL库获取GPS模块HT1818Z3G5L信息(方法1)

1、写在最前 先了解一下GPRMC的格式 格 式&#xff1a; GPRMC,024813.640,A,3158.4608,N,11848.3737,E,10.05,324.27,150706,A*50 说 明&#xff1a; 字段 0&#xff1a;$GPRMC&#xff0c;语句ID&#xff0c;表明该语句为Recommended Minimum Specific GPS/TRANSIT Data&…

数据结构|排序总结(1)|直接插入排序

排序分类 插入排序&#xff1a;直接插入排序&#xff0c;希尔排序 选择排序&#xff1a;选择排序&#xff0c;堆排序 交换排序&#xff1a;冒泡排序&#xff0c;快速排序 归并排序 插入排序 直接插入排序 相当于摸牌&#xff0c;例如我们现在手上有{2&#xff0c;4&#xff0…

碘浊度法与红外相机联用测定食品中维生素C

&#x1f31e;欢迎来到看论文的世界 &#x1f308;博客主页&#xff1a;卿云阁 &#x1f48c;欢迎关注&#x1f389;点赞&#x1f44d;收藏⭐️留言&#x1f4dd; &#x1f31f;本文由卿云阁原创&#xff01; &#x1f4c6;首发时间&#xff1a;&#x1f339;2024年4月6日&…

数据库的简单查询

一、检索一列或多列1.检索单独一列 select 列名 from 表名; select order_num from orders; 2.检索多列数据 select 列 1&#xff0c;列 2... from 表名; select order_num,order_date from orders; select order_date,order_num from orders; 3.查询所有字段 select * from…

正排索引 vs 倒排索引 - 搜索引擎具体原理

阅读导航 一、正排索引1. 概念2. 实例 二、倒排索引1. 概念2. 实例 三、正排 VS 倒排1. 正排索引优缺点2. 倒排索引优缺点3. 应用场景 三、搜索引擎原理1. 宏观原理2. 具体原理 一、正排索引 1. 概念 正排索引是一种索引机制&#xff0c;它将文档或数据记录按照某种特定的顺序…

016——DHT11驱动开发(基于I.MX6uLL)

目录 一、 模块介绍 1.1 简介 1.2 电路描述 1.3 通信协议 二、 驱动程序 三、 应用程序 四、 上机实验 一、 模块介绍 1.1 简介 DHT11 是一款可测量温度和湿度的传感器。比如市面上一些空气加湿器&#xff0c;会测量空气中湿度&#xff0c;再根据测量结果决定是否继续加…

Cortex-M7 内存映射模型

1 前言 如图1所示&#xff0c; Cortex-M7最大支持4GB的内存寻址&#xff0c;并对内存映射(memory map)做了初步的规定&#xff0c;将整个内存空间划分为了多个内存区域(region)。每个内存区域有着既定的内存类型(memory type)和内存属性(memory attribute)&#xff0c;这两者决…

物理层习题及其相关知识(谁看谁不迷糊呢)

1. 对于带宽为50k Hz的信道&#xff0c;若有4种不同的物理状态来表示数据&#xff0c;信噪比为20dB 。&#xff08;1&#xff09; 按奈奎斯特定理&#xff0c;信道的最大传输数据速率是多少&#xff1f;&#xff08;2&#xff09; 按香农定理&#xff0c;信道的最大传输数据速度…

基于Springboot+Vue实现前后端分离酒店管理系统

一、&#x1f680;选题背景介绍 &#x1f4da;推荐理由&#xff1a; 近几年来&#xff0c;随着各行各业计算机智能化管理的转型&#xff0c;以及人们经济实力的提升&#xff0c;人们对于酒店住宿的需求不断的提升&#xff0c;用户的增多导致酒店管理信息的不断增多&#xff0c;…

ICLR 2024 | 联邦学习后门攻击的模型关键层

ChatGPT狂飙160天&#xff0c;世界已经不是之前的样子。 新建了免费的人工智能中文站https://ai.weoknow.com 新建了收费的人工智能中文站https://ai.hzytsoft.cn/ 更多资源欢迎关注 联邦学习使多个参与方可以在数据隐私得到保护的情况下训练机器学习模型。但是由于服务器无法…

华为分红出炉,人均超50w!

华为分红 770 亿 4 月 2 日&#xff0c;北京金融资产交易所官网发布了《华为投资控股有限公司关于分配股利的公告》。 公告指出&#xff1a;经公司内部有权机构决议&#xff0c;拟向股东分配股利约 770.945 亿元。 众所周知&#xff0c;华为并不是一家上市公司&#xff0c;这里…

C++从入门到精通——初步认识面向对象及类的引入

初步认识面向对象及类的引入 前言一、面向过程和面向对象初步认识C语言C 二、类的引入C的类名代表什么示例 C与C语言的struct的比较成员函数访问权限继承默认构造函数默认成员初始化结构体大小 总结 前言 面向过程注重任务的流程和控制&#xff0c;适合简单任务和流程固定的场…

自定义实现shell/bash

文章目录 函数和进程之间的相似性shell打印提示符&#xff0c;以及获取用户输入分割用户的输入判断是否是内建命令执行相关的命令 全部代码 正文开始前给大家推荐个网站&#xff0c;前些天发现了一个巨牛的 人工智能学习网站&#xff0c; 通俗易懂&#xff0c;风趣幽默&#…

Day30 线程安全之窗口售票问题(含代码)

Day30 线程安全之窗口售票问题&#xff08;含代码&#xff09; 一、需求&#xff1a; 铁道部发布了一个售票任务&#xff0c;要求销售1000张票&#xff0c;要求有3个窗口来进行销售&#xff0c; 请编写多线程程序来模拟这个效果&#xff08; 注意&#xff1a;使用线程类的方式…

【Qt 学习笔记】详解Qt中的信号和槽

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Qt 专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ 详解Qt中的信号与槽 文章编号&#xff1a;Qt 学习笔记 / 12 文章目录…

红黑树的平衡之道:深入解析右旋操作的原理与实践

红黑树的平衡之道&#xff1a;深入解析右旋操作的原理与实践 一、 红黑树旋转的背景二、右旋&#xff08;RIGHT-ROTATE&#xff09;的原理三、右旋&#xff08;RIGHT-ROTATE&#xff09;的算法步骤四、右旋&#xff08;RIGHT-ROTATE&#xff09;的伪代码五、右旋&#xff08;RI…

ctf_show笔记篇(web入门---jwt)

目录 jwt简介 web345&#xff1a; web346&#xff1a; web347&#xff1a; web348: web349&#xff1a; web350&#xff1a; jwt简介 JSON Web Token&#xff08;JWT&#xff09;通常由三部分组成 Header&#xff08;头部&#xff09;&#xff1a;包含了两部分信息&…

蓝桥杯备考3

P8196 [传智杯 #4 决赛] 三元组 题目描述 给定一个长度为 n 的数列 a&#xff0c;对于一个有序整数三元组 (i,j,k)&#xff0c;若其满足 1≤i≤j≤k≤n 并且&#xff0c;则我们称这个三元组是「传智的」。 现在请你计算&#xff0c;有多少有序整数三元组是传智的。 输入格式…

LRU的原理与实现(java)

介绍 LRU的英文全称为Least Recently Used&#xff0c;即最近最少使用。它是一种内存数据淘汰算法&#xff0c;当添加想要添加数据而内存不足时&#xff0c;它会优先将最近一段时间内使用最少的数据淘汰掉&#xff0c;再将数据添加进来。 原理 LRU的原理在介绍中就已经基本说…