LeetCode --- 401周赛

题目列表

3178. 找出 K 秒后拿着球的孩子

3179. K 秒后第 N 个元素的值

3180. 执行操作可获得的最大总奖励 I

3181. 执行操作可获得的最大总奖励 II

一、找出K秒后拿着球的孩子

这题可以直接模拟,从前往后,再从后往前走k次,最后直接返回下标。或者我们可以直接计算,先算出球是从前往后走,还是从后往前走,然后判断球是第几个,返回下标即可,代码如下

//数学
class Solution {
public:int numberOfChild(int n, int k) {int m = k/(n-1), left = k%(n-1); // 因为起始下标是0,所以只要走n-1步就能到最后// m如果是奇数,说明是从后往前,如果是偶数,说明是从前往后return m&1 ? n - left - 1 : left; }
};// 模拟
class Solution {
public:int numberOfChild(int n, int k) {int i = 0, dir = -1;while(k){if(i <= 0|| i >= n-1) dir *= -1;i += dir;k--;}return i;}
};

二、K秒后第N个元素的值

这题可以直接模拟,就是求k次前缀和,返回最后一个元素,也可以直接用数学,去观察它,本质是在求一个组合数C(n+k-1,n-1),具体过程如下

代码如下

// 数学
const int MOD = 1e9+7;
int C[2001][2001]{};
int init=[]()->int{C[0][0] = 1;for(int i = 1; i < 2001; i++){C[i][0] = C[i][i] = 1;for(int j = 1; j <= i/2; j++){C[i][j] = C[i][i-j] = (C[i-1][j] + C[i-1][j-1])%MOD;}}return 0;
}();class Solution {
public:int valueAfterKSeconds(int n, int k) {return C[n+k-1][k];}
};// 模拟
class Solution {const int MOD = 1e9+7;
public:int valueAfterKSeconds(int n, int k) {vector<int> v(n,1);while(k--){for(int i=1;i<n;i++){v[i] = (v[i] + v[i-1])%MOD;}}return v.back();}
};

三、执行操作可获得的最大总奖励 I & II

这题和0-1背包很相似,状态定义为:dp[i][j]表示能否在前i个数中选出一些数使得它们的和为j

状态转移方程为

  • 不选nums[i],dp[i][j] = dp[i-1][j]
  • 选nums[i],dp[i][j] = dp[i-1][j-nums[i]],其中 0 <= j - nums[i] < nums[i]
  • 故dp[i][j] = dp[i-1][j] | dp[i-1][j-nums[i]]

代码如下

class Solution {
public:int maxTotalReward(vector<int>& nums) {sort(nums.begin(),nums.end());nums.erase(unique(nums.begin(),nums.end()),nums.end()); // 无法选择多个相同的数int n = nums.size(), mx = ranges::max(nums);vector<vector<bool>> dp(n+1,vector<bool>(mx*2));dp[0][0] = true;int ans = 0;for(int i = 0; i < n; i++){for(int j = 0; j < 2*nums[i]; j++){ // 当 j >= 2*nums[i] 时,dp[i+1][j] = dp[i][j],根据递推,它们都是false,没必要更新dp[i+1][j] = dp[i][j];if(j >= nums[i]) dp[i+1][j] = dp[i+1][j] | dp[i][j - nums[i]];}}for(int i=mx*2-1;i>=0;i--)if(dp[n][i])return i;return -1;}
};
// 优化
class Solution {
public:int maxTotalReward(vector<int>& nums) {sort(nums.begin(),nums.end());nums.erase(unique(nums.begin(),nums.end()),nums.end());int n = nums.size(), mx = ranges::max(nums);vector<bool>dp(mx*2);dp[0] =true;int ans = 0;for(int i = 0; i < n; i++){for(int j = nums[i]; j < 2*nums[i]; j++){dp[j] = dp[j] | dp[j - nums[i]];}}for(int i=mx*2-1;i>=0;i--)if(dp[i])return i;return -1;}
};

第四问的数据范围变大,我们还需要对时间复杂度进行优化,如何做???

根据上面的代码,我们只要维护一个2*mx大小的bool数组就可以,但是维护true / false其实只需要一个二进制位就能表示,我们可以将数组大小进行压缩,同时,一旦它用二进制来表示,我们的状态转移,就可以用二进制的 | 运算进行,即可以批量的进行,因为整数在cpu上计算时是以32位整型/64位整型进行或运算的,即速度会提升32倍/64倍,代码如下

class Solution {
public:int maxTotalReward(vector<int>& nums) {sort(nums.begin(),nums.end());nums.erase(unique(nums.begin(),nums.end()),nums.end());int n = nums.size(), mx = ranges::max(nums);bitset<100000> f = 1;for(auto v:nums){int shift = f.size() - v;f |= f << shift >> shift << v;}for(int i = mx*2 - 1; i >= 0; i--)if(f.test(i))return i;return -1;}
};

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

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

相关文章

第〇篇:深入Docker的世界系列博客介绍

深入Docker的世界系列博客介绍 欢迎来到“深入Docker的世界”系列博客&#xff0c;这是一次旨在全面探索Docker容器化技术的冒险之旅。从基础原理到高级应用&#xff0c;再到实践案例分析&#xff0c;我们将深入挖掘Docker的每一个角落&#xff0c;帮助你不仅掌握这项技术的实…

ecshop鲜花商城微信分销源码附移动端

ecshop 微信手机分销商城 微信支付微信通&#xff0c;PHP鲜花礼品商城源码带手机wap ecshop鲜花商城微信分销源码附移动端

C语言小例程20/100

题目&#xff1a;一个数如果恰好等于它的因子之和&#xff0c;这个数就称为"完数"。例如61&#xff0b;2&#xff0b;3.编程找出1000以内的所有完数。 #include<stdio.h> #define N 1000 int main() {int i,j,k,n,sum;int a[256];for(i2;i<N;i){suma[0]1;k…

LabVIEW在高校中的应用

LabVIEW 作为一款功能强大的图形化编程工具&#xff0c;在高校中有广泛的应用。它不仅用于教学实验&#xff0c;还广泛应用于科研项目和工程训练。本文将从教学、科研、实验室管理和学生技能培养等多个角度&#xff0c;详细分析LabVIEW在高校中的应用。 教学应用 课程设计 自动…

Flutter调用本地web

前言: 在目前Flutter 环境中&#xff0c;使用在线 webview 是一种很常见的行为 而在 app 环境中&#xff0c;离线使用则更有必要 1.环境准备 将依赖导入 2.引入前端代码 前端代码有两种情况 一种是使用打包工具 build 而来的前端代码 另一种情况是直接使用 HTML 文件 …

深入探讨限流算法:固定窗口、滑动窗口、漏桶与令牌桶原理及应用场景

固定窗口算法 简单粗暴&#xff0c;但有临界问题&#xff1a; 滑动窗口算法 滑动窗口通俗来讲是一种流量控制技术&#xff0c;描述接收方TCP数据报缓冲区大小的数据。发送方根据这个数据计算最大可发送的数据量。滑动窗口协议是TCP使用的一种流量控制方法&#xff0c;允许发送…

【Linux硬盘数据读取】WIN10访问linux分区解决方案:ext2fsd

<div id"content_views" class"htmledit_views" style"user-select: auto;"><p>尝试ext2explore、Paragon ExtFS都不好用&#xff0c;强烈安利ext2fsd&#xff0c;可读写&#xff0c;很强大</p> 转自&#xff1a;https://blog…

设计通用灵活的LabVIEW自动测试系统

为了在不同客户案例中灵活使用不同设备&#xff08;如采集卡、Modbus模块&#xff09;且保持功能一致的LabVIEW自动测试系统&#xff0c;需要采用模块化的软件架构、配置文件管理、标准化接口和良好的升级维护策略。本文从软件架构、模块化设计、配置管理、升级维护、代码管理和…

sigmoid函数

σ ( x ) 1 1 e − x \sigma(x)\frac1{1e^{-x}} σ(x)1e−x1​ sigmoid函数好处 1. σ ( x ) \sigma(x) σ(x)的域值是[0,1] &#xff0c;在(-∞, ∞)单调递增&#xff0c;很符合概率分布函数的特点 2.以 σ ( x ) \sigma(x) σ(x)为分布函数的概率密度函数在远离零点的位置…

springSecurity学习笔记(一)

简介 Spring Security是一个Java框架&#xff0c;用于保护应用程序的安全性。它提供了一套全面的安全解决方案&#xff0c;包括身份验证、授权、防止攻击等功能。Spring Security基于过滤器链的概念&#xff0c;可以轻松地集成到任何基于Spring的应用程序中。它支持多种身份验…

hugo-magic主题使用教程(一)

前提条件 以下教程以windows10为例操作终端使用git bash魔法上网的前提下 下载hugo https://github.com/gohugoio/hugo/releases/download/v0.127.0/hugo_extended_0.127.0_windows-amd64.zip解压到任意目录,然后将目录添加到系统环境变量 如图 (windows)打开cmd 输入 hugo …

[数据集][目标检测]胸部解剖检测数据集VOC+YOLO格式100张10类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;100 标注数量(xml文件个数)&#xff1a;100 标注数量(txt文件个数)&#xff1a;100 标注类别…

宿舍用电管理模块一进三出的升级改造

宿舍用电管理模块一进三出石家庄光大远通电气有限公司产品在高校日常管理工作中,宿舍管理是一项重要工作。宿舍管理内容复杂,而且涉及学生的日常生活,意义重大。其中,学生宿舍内漏电,超负荷用电,违规用电等现象一直是困扰后勤管理的普遍问题。随着学生日常生活方式以及生活用品…

第九届星华杯网络邀请赛

T1喵星人的身高 T2犇犇碑 T3嘤嘤词典 T4三角区间和

微服务feign组件学习

手写不易&#xff0c;对您有帮助。麻烦一键三连。也欢饮各位大料指正&#xff0c;交流。 微服务feign组件学习 1.概念1.1 feign 概念1.2 Ribbon概念 2.使用2.1 集成feign2.1.1 maven依赖2.1.2 项目结构 2.2 使用2.2.1 定义feign接口2.2.2 消费端服务调用2.2.3 消费端扫描feig…

Ubuntu 22.04 解决 firefox 中文界面乱码

问题复现 在为Ubuntu 22.04 Server安装完整的GNOME 42.01桌面后&#xff0c;将桌面语言设置为中文时&#xff0c;打开Firefox可能会出现中文乱码的问题。经过网上调查发现&#xff0c;这个问题是由Snap软件包引起的。 解决方案 为了避免在Ubuntu 22.04中文模式下的乱码问题…

Redis系列-4 Redis集群介绍

Redis集群 Redis提供了持久化能力&#xff0c;保证了重启不会丢失数据&#xff1b;但Redis重启至完全恢复期间&#xff0c;缓存不可用。另外&#xff0c;对于高并发场景下&#xff0c;单点Redis服务器的性能不能满足吞吐量要求&#xff0c;需要进行横向扩展。此时&#xff0c;…

mmdeploy环境部署流程

参考&#xff1a;mmdeploy/docs/zh_cn/01-how-to-build/linux-x86_64.md at main open-mmlab/mmdeploy (github.com) 从零入门《openmmlab》mmdeploy[1]环境安装及简单上手_哔哩哔哩_bilibili 我的环境&#xff1a; docker容器&#xff0c;ubuntu20.04&#xff0c;cuda11.7…

注解(Annotation)(一)

Java 注解&#xff08; Annotation &#xff09;又称 Java 标注&#xff0c;是 JDK5.0 引入的一种注释机制。 Java 语言中的类、 构造器、 方法、成员变量、参数等都可以被注解进行标注。 自定义注解 --- 格式 自定义注解就是自己做一个注解来使用。 public interface …

C++ | Leetcode C++题解之第140题单词拆分II

题目&#xff1a; 题解&#xff1a; class Solution { private:unordered_map<int, vector<string>> ans;unordered_set<string> wordSet;public:vector<string> wordBreak(string s, vector<string>& wordDict) {wordSet unordered_set(w…