第 360 场 LeetCode 周赛题解

news2024/11/16 12:43:27

A 距离原点最远的点

在这里插入图片描述

串中的 “_” 处要么都向左走要么都向右走

class Solution {
public:
    int furthestDistanceFromOrigin(string moves) {
        int t = 0;
        for (auto x: moves)
            if (x != 'R')
                t--;
            else
                t++;
        int res = abs(t);
        t = 0;
        for (auto x: moves)
            if (x != 'L')
                t++;
            else
                t--;
        res = max(res, abs(t));
        return res;
    }
};

B 找出美丽数组的最小和

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

贪心:升序枚举正数,用集合维护当前数组中已有的数

class Solution {
public:
    long long minimumPossibleSum(int n, int target) {
        long long res = 0;
        set<int> vis;
        for (int i = 1; vis.size() != n; i++)
            if (!vis.count(target - i)) {
                res += i;
                vis.insert(i);
            }
        return res;
    }
};

C 使子序列的和等于目标的最少操作次数

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

贪心:首先只有 n u m s nums nums 的数组和小于 t a r g e t target target 才无解,若有解则从低位到高位枚举 t a r g e t target target 的二进制表示的各位,设当前位对应 2 i 2^i 2i ,且 t a r g e t target target i i i 位为 1 1 1,有两种情况:

  • n u m s nums nums中不超过 2 i 2^i 2i 的数的和 ≥ \ge 2 i 2^i 2i :则一定存在若干个不超过 2 i 2^i 2i 的数之和恰好为 2 i 2^i 2i
  • n u m s nums nums中不超过 2 i 2^i 2i 的数的和 < < < 2 i 2^i 2i :需要把 n u m s nums nums 中一个最小的大于 2 i 2^i 2i 的数 2 j 2^j 2j 操作若干次来生成一个 2 i 2^i 2i

第二种情况会产生操作数,枚举过程种注意维护不超过 2 i 2^i 2i 的数的和。

class Solution {
public:
    int minOperations(vector<int> &nums, int target) {
        if (accumulate(nums.begin(), nums.end(), 0LL) < target)
            return -1;
        unordered_map<int, int> cnt;
        for (auto x: nums)
            cnt[x]++;
        int res = 0;
        long long ps = 0;//nums中不超过2^i的数之和
        for (int i = 0, e = 1; i < 31; i++, e <<= 1) {//逐位枚举
            ps += 1LL * cnt[e] * e;
            if (!(target >> i & 1))
                continue;
            if (ps >= e) {
                ps -= e;
                continue;
            }
            int j = i + 1;
            while (cnt[1 << j] <= 0)//找nums中大于2^i的最小的2^j
                j++;
            res += j - i;//记录操作数
            cnt[1 << j]--;
            for (int k = i + 1; k < j; k++)
                cnt[1 << k] = 1;
            ps += e;
        }
        return res;
    }
};

D 在传球游戏中最大化函数值

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

倍增:设 g [ i ] [ j ] g[i][j] g[i][j] 为球最初在 i i i 手里,传 2 j 2^j 2j 次球的过程中每次接触球玩家的编号之和。设 v [ i ] [ j ] v[i][j] v[i][j] 表示球最初在 i i i 手里,传 2 j 2^j 2j 次球后球在 v [ i ] [ j ] v[i][j] v[i][j]手里。预处理求处理 g g g v v v,之后枚举 i ∈ [ 0 , n ) i \in [0,n) i[0,n),然后枚举 k k k 二进制各位来求 f [ i ] f[i] f[i]

class Solution {
public:
    long long getMaxFunctionValue(vector<int> &receiver, long long k) {
        int n = receiver.size();
        long long g[n][35], v[n][35];
        for (int j = 0; j < 35; j++)
            for (int i = 0; i < n; i++)
                if (j != 0) {
                    g[i][j] = g[i][j - 1] + g[v[i][j - 1]][j - 1] - v[i][j - 1];
                    v[i][j] = v[v[i][j - 1]][j - 1];
                } else {
                    g[i][j] = i + receiver[i];
                    v[i][j] = receiver[i];
                }
        long long res = 0;
        for (int i = 0; i < n; i++) {
            long long cur = 0;
            int last = i;
            for (long long j = 0; j < 35; j++)
                if (k >> j & 1) {//枚举k二进制各位
                    cur += g[last][j] - last;
                    last = v[last][j];
                }
            res = max(res, i + cur);
        }
        return res;
    }
};

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

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

相关文章

土豆叶病害识别(Python代码,pyTorch框架,深度卷积网络模型,很容易替换为其它模型,视频识别)

效果视频&#xff1a;土豆叶病害识别&#xff08;Python代码&#xff0c;pyTorch框架&#xff0c;视频识别&#xff09;_哔哩哔哩_bilibili 代码运行要求&#xff1a;Torch库>1.13.1&#xff0c;其它库无版本要求 1..土豆叶数据集主要包好三种类别&#xff08;Early_Bligh…

集丰照明|汽车美容店设计,装修色彩灯光搭配方法

正确处理好店面的空间设计。 店铺各个功能区设计要合理&#xff0c;衔接合理&#xff0c;这样既能提高员工的工作效率也能提高顾客的满意度。合理安排店铺的空间分配&#xff0c; 要给顾客一种舒适度&#xff0c;既不能让顾客感觉到过于拥挤&#xff0c;又不能浪费店铺的有限空…

邂逅JavaScript

前言&#xff1a;前端三大核心 前端开发最主要需要掌握的是三个知识点&#xff1a;HTML、CSS、JavaScript 一、认识编程语言 1.计算机语言 前面我们已经学习了HTML和CSS很多相关的知识: 在之前我们提到过, HTML是一种标记语言, CSS也是一种样式语言; 他们本身都是属于计算…

Android JNI系列详解之ndk编译工具环境变量配置

一、前提 之前是只介绍了CMake编译工具的使用&#xff0c;现在介绍另一种原生&#xff08;NDK自带的脚本工具&#xff09;自带的编译方式&#xff1a;ndk-build&#xff0c;想要使用ndk-build编译工程&#xff0c;我们需要配置全局的环境变量。 二、配置环境变量 找到ndk在电脑…

HRS--人力资源系统(Springboot+vue)--打基础升级--(六)分页查询 + 重置按钮

一&#xff1a;先弄个简单的重置按钮 1.界面设计就放在搜索框同一列的位置 2. 在点击重置按钮时&#xff0c;清空搜索框内的内容&#xff0c;同时触发一次无条件查询(这个写法有bug&#xff0c;下面会有说明) 二&#xff1a;做分页 在MyBatis中&#xff0c;有多种方法可以实现分…

【报错记录】疯狂踩坑之RockyLinux创建Raid1镜像分区,Raid分区在重启后消失了!外加华硕主板使用Raid模式后,硬盘在系统中无法找到问题

前言 为了摆脱对于专业NAS的依赖&#xff0c;我决定专门使用一台Linux服务器安装NAS程序的方式实现NAS功能&#xff0c;这里就需要用到Raid功能&#xff0c;由于目前我只有3块SSD&#xff08;256G500G500G&#xff09;&#xff0c;在ChatGPT的推荐下还是使用一个256G系统盘2块…

HTTP 框架修炼之道 | 青训营

Powered by:NEFU AB-IN 文章目录 HTTP 框架修炼之道 | 青训营 走进 HTTP 协议HTTP 框架的设计与实现应用层中间件层路由设计协议层 传输层&#xff08;网络层&#xff09;1. BIO&#xff08;Blocking I/O&#xff09;:2. NIO&#xff08;Non-blocking I/O&#xff09;:区别&…

【 Python 全栈开发 - 人工智能篇 - 45 】集成算法与聚类算法

文章目录 一、集成算法1.1 概念1.2 常用集成算法1.2.1 Bagging1.2.2 Boosting1.2.2.1 AdaBoost1.2.2.2 GBDT1.2.2.3 XgBoost 1.2.3 Stacking 二、聚类算法2.1 概念2.2 常用聚类算法2.2.1 K-means2.2.2 层次聚类2.2.3 DBSCAN算法2.2.4 AP聚类算法2.2.5 高斯混合模型聚类算法 一、…

39、springboot的前端静态资源的WebJar支持(bootstrap、jquery等)及自定义图标和首页

★ WebJar支持 Spring Boot支持加载WebJar包中的静态资源&#xff08;图片、JS、CSS&#xff09;&#xff0c; WebJar包中的静态资源都会映射到/webjars/**路径。——这种方式下&#xff0c;完全不需要将静态资源复制到应用的静态资源目录下。只要添加webjar即可。假如在应用的…

145. 二叉树的后序遍历

题目来源&#xff1a;力扣 题目描述&#xff1a; 给你一棵二叉树的根节点 root &#xff0c;返回其节点值的 后序遍历 。 示例 1&#xff1a; 输入&#xff1a;root [1,null,2,3] 输出&#xff1a;[3,2,1]示例 2&#xff1a; 输入&#xff1a;root [] 输出&#xff1a;[]…

C#---第二十: partial修饰类的特性及应用

0.知识背景 局部类型适用于以下情况&#xff1a; 类型特别大&#xff0c;不宜放在一个文件中实现。一个类型中的一部分代码为自动化工具生成的代码&#xff0c;不宜与我们自己编写的代码混合在一起。需要多人合作编写一个类 局部类型的限制: 局部类型只适用于类、接口、结构&am…

信息化发展1

信息的定义 1 、信息论的奠基者香农认为&#xff1a; 信息是用来消除随机不定性的东西。 2 、信息的目的是用来“消除不确定的因素” 。信息是抽象于物质的映射集合。 3 、香农用概率来定量描述信息的公式如下&#xff1a; 信息的特征 客观性&#xff1a;信息是客观事物在人…

PostgreSQL分区表

什么是分区表 数据库分区表将表数据分成更小的物理分片&#xff0c;以此提高性能、可用性、易管理性。分区表是关系型数据库中比较常见的对大表的优化方式&#xff0c;数据库管理系统一般都提供了分区管理&#xff0c;而业务可以直接访问分区表而不需要调整业务架构&#xff0c…

QT版权查询

文章目录 QT工具版权QT模块版权查询 根据条件自动筛选&#xff1a; Qt Features, Framework Essentials, Modules, Tools & Add-Ons QT工具版权 Licensing QT模块版权查询 在 All Modules 中点击进入每个模块&#xff0c;在详细内容中一般有Lisence相关内容。 Licens…

c语言练习题35:求两个数二进制中不同位的个数

求两个数二进制中不同位的个数 //编程实现&#xff1a;两个int&#xff08;32位&#xff09;整数m和n的二进制表达中&#xff0c;有多少个位(bit)不同&#xff1f; //输入例子 : //1999 2299 //输出例子 : 7 //int calc_diff_bit(int m, int n) 思路&#xff1a; 1. 先将m和n…

Mybatis中的缓存机制(一文带你弄懂)

Mybatis中的缓存机制 Mybatis中的缓存机制概述项目结构MyBatis 一级缓存一级缓存原理代码测试什么时候一级缓存失效? Mybatis二级缓存测试代码⼆级缓存的失效⼆级缓存的相关配置 MyBatis集成EhCache Mybatis中的缓存机制 概述 缓存的作⽤&#xff1a;通过减少IO的⽅式&#…

数据结构--树4.2.1(二叉树)

目录 一、二叉树的存储结构 二、二叉树的遍历 一、二叉树的存储结构 顺序存储结构&#xff1a;二叉树的顺序存储结构就是用一维数组存储二叉树中的各个结点&#xff0c;并且结点的存储位置能体现结点之间的逻辑关系。 链式存储结构&#xff1a;二叉树每个结点最多只有两个孩…

英国选校8.27

目录 IC帝国理工学院 UCL伦敦大学学院 爱丁堡 曼彻斯特 KCL伦敦国王学院 Bristol布里斯托 华威 南安普顿 IC帝国理工学院 UCL伦敦大学学院 爱丁堡 曼彻斯特 KCL伦敦国王学院 24qs专业位置双非con雅思气候备注40 移动&个人通信 24fall不要双非&#xff1f; 24fall新…

通俗理解DDPM到Stable Diffusion原理

代码1&#xff1a;stabel diffusion 代码库代码2&#xff1a;diffusers 代码库论文&#xff1a;High-Resolution Image Synthesis with Latent Diffusion Models模型权重&#xff1a;runwayml/stable-diffusion-v1-5 文章目录 1. DDPM的通俗理解1.1 DDPM的目的1.2 扩散过程1.3 …

【数据结构】二叉树篇|超清晰图解和详解:二叉树的序列化和反序列化

博主简介&#xff1a;努力学习的22级计算机科学与技术本科生一枚&#x1f338;博主主页&#xff1a; 是瑶瑶子啦每日一言&#x1f33c;: 你不能要求一片海洋&#xff0c;没有风暴&#xff0c;那不是海洋&#xff0c;是泥塘——毕淑敏 目录 一、核心二、题目2.1:前序遍历2.2&…