leetcode 1649. 通过指令创建有序数组

题目:1649. 通过指令创建有序数组 - 力扣(LeetCode)

经典线段树问题

struct Node {Node* lc = nullptr;Node* rc = nullptr;int l;int r;int v = 0;Node(int l, int r) {this->l = l;this->r = r;}~Node() {if (lc) {delete lc;}if (rc) {delete rc;}}
};
class Solution {
public:static const int MAX = 1000000007;void BuildTree(Node* node) {int l = node->l;int r = node->r;if (l == r) {return;}int m = (l + r) / 2;node->lc = new Node(l, m);node->rc = new Node(m + 1, r);BuildTree(node->lc);BuildTree(node->rc);}int Sum(Node* t, int l, int r) {if (l <= t->l && r >= t->r) {return t->v;}if (l > t->r || r < t->l) {return 0;}int64_t ret = 0;if (l <= t->lc->r) {ret += Sum(t->lc, l, r);}if (r >= t->rc->l) {ret += Sum(t->rc, l, r);}if (ret >= MAX) ret %= MAX;return (int) ret;}void Add(Node* t, int p) {if (p >= t->l && p <= t->r) {++t->v;if (t->lc && p <= t->lc->r) {Add(t->lc, p);return;}if (t->rc && p >= t->rc->l) {Add(t->rc, p);}}}int createSortedArray(vector<int>& instructions) {if (instructions.size() <= 2) {return 0;}size_t n = instructions.size();int limL = instructions[0];int limR = instructions[0];for (int i = 0; i < n; i++) {int val = instructions[i];if (val < limL) limL = val;if (val > limR) limR = val;}Node* root = new Node(limL, limR);BuildTree(root);int64_t ret = 0;int64_t ls, rs;int min = instructions[0];int max = instructions[0];for (int i = 0; i < n; i++) {int val = instructions[i];if (val < min) {min = val;Add(root, val);continue;}if (val > max) {max = val;Add(root, val);continue;}if (val > limL) {ls = Sum(root, limL, val - 1);} else {ls = 0;}if (val < limR) {rs = Sum(root, instructions[i] + 1, limR);} else {rs = 0;}if (ls <= rs) {ret += ls;} else {ret += rs;}if (ret >= MAX) ret %= MAX;Add(root, val);}delete root;return (int) ret;}
};

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

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

相关文章

7.若依参数设置、通知公告、日志管理

参数设置 对系统中的参数进行动态维护。 关闭验证码校验功能 打开页面注册功能 需要修改前端页面代码 通知公告 促进组织内部信息传递 若依只提供了一个半成品&#xff0c;只实现了管理员可以添加通知公告。 日志管理 追踪用户行为和系统运行状况。 登录日志 和操作日志…

修改网络ip地址方法有哪些?常用的有这四种

在数字时代&#xff0c;IP地址作为网络设备的唯一标识&#xff0c;对于网络连接和通信至关重要。然而&#xff0c;有时候我们可能需要修改设备的IP地址&#xff0c;以满足特定的网络需求或解决网络问题。本文将为您详细介绍几种修改网络IP地址的常用方法&#xff0c;无论是对于…

【Java项目】基于SpringBoot的【外卖点餐系统】

【Java项目】基于SpringBoot的【外卖点餐系统】 技术简介&#xff1a;本系统使用JSP技术&#xff0c;采用B/S架构、Spring Boot框架、MYSQL数据库进行开发设计。 系统简介&#xff1a;管理员&#xff1b;首页、个人中心、用户管理、商家管理、菜品分类管理、骑手管理、系统管理…

Spring Boot教程之三十九: 使用 Maven 将 Spring Boot 应用程序 Docker 化

如何使用 Maven 将 Spring Boot 应用程序 Docker 化&#xff1f; Docker是一个开源容器化工具&#xff0c;用于在隔离环境中构建、运行和管理应用程序。它方便开发人员捆绑其软件、库和配置文件。Docker 有助于将一个容器与另一个容器隔离。在本文中&#xff0c;为了将Spring B…

计算机网络|数据流向剖析与分层模型详解

文章目录 一、网络中的数据流向二、计算机网络通信模型1.OSI 模型2.TCP/IP 模型3.TCP/IP五层模型3.1 分层架构描述3.2各层地址结构3.3UDP数据包报头结构 三、总结 一、网络中的数据流向 在计算机网络中&#xff0c;数据的流向是指数据从发送端到接收端的传输路径。数据流向涉及…

uniapp——微信小程序,从客户端会话选择文件

微信小程序选择文件 文章目录 微信小程序选择文件效果图选择文件返回数据格式 API文档&#xff1a; chooseMessageFile 微信小程序读取文件&#xff0c;请查看 效果图 选择文件 /*** description 从客户端会话选择文件* returns {String} 文件路径*/ const chooseFile () &g…

vue3+vite+nginx打包

在开发环境下&#xff0c;已经可以正常地运行一个有增删改查功能的页面了&#xff0c;但如何把它发布到运行服务器呢&#xff1f;仍有许多的问题需要探索。 网上很多文章给了很大的帮助&#xff0c;但总是没有说明原理&#xff0c;对于像我这样的初学者来说&#xff0c;不知其…

CAN201 Introduction to Networking(计算机网络)Pt.2 传输层

文章目录 3. Transport Layer&#xff08;传输层&#xff09;3.1 Multiplexing and demultiplexing&#xff08;多路复用和多路分解&#xff09;3.2 Connectionless transport&#xff1a;UDP3.3 Principles of reliable data transfer3.4 Pipelined communication3.5 TCP: con…

JVM 详解

一. JVM 内存区域的划分 1. 程序计数器 程序计数器是JVM中一块比较小的空间, 它保存下一条要执行的指令的地址. [注]: 与CPU的程序计数器不同, 这里的下一条指令不是二进制的机器语言, 而是Java字节码. 2. 栈 保存方法中的局部变量, 方法的形参, 方法之间的调用关系. 栈又…

Docker--Docker Network(网络)

Docker为什么需要网络管理 容器的网络默认与宿主机及其他容器之间是隔离的,但有时也需要与宿主机和容器进行通信。 容器间及容器与外部通信的需求 容器间通信&#xff1a;在Docker环境中&#xff0c;容器默认与宿主机及其他容器是相互隔离的。然而&#xff0c;在实际应用中&…

深入浅出 MyBatis | CRUD 操作、配置解析

3、CRUD 3.1 namespace namespace 中的包名要和 Dao/Mapper 接口的包名一致&#xff01; 比如将 UserDao 改名为 UserMapper 运行发现抱错&#xff0c;这是因为 UserMapper.xml 中没有同步更改 namespace 成功运行 给出 UserMapper 中的所有接口&#xff0c;接下来一一对…

UE5材质节点Panner

Panner节点可以让贴图动起来&#xff0c;快捷键是P&#xff0c;Speed的数值大小就是贴图移动的快慢&#xff0c;x和y是方向 这个节点可以用来做&#xff0c;传送带&#xff0c;护盾&#xff0c;河流&#xff0c;岩浆&#xff0c;瀑布等 制作岩浆流动效果 创建材质&#xff0c;…

Kimi进行学术方向选择精讲!

目录 1.文献搜索 2.辅助选题 3.选题判断 在我们之前的文章中&#xff0c;小编都强调了选题在文章价值中的核心作用。一篇优秀的文章背后&#xff0c;肯定有一个精心挑选的选题。选题的好坏直接影响着文章能够发表的期刊等级。许多宝子们却采取了相反的做法&#xff0c;将大量…

Google Veo AI 视频生成工具评测:AI视频生成的未来已来

近年来&#xff0c;AI技术的迅猛发展使得我们对虚拟现实的认知不断发生改变&#xff0c;尤其是在视频生成领域。Google 最新推出的 Veo AI 视频生成工具&#xff0c;无疑为这一领域带来了前所未有的突破。通过与其他知名工具如 OpenAI 的 Sora 进行对比&#xff0c;Veo 显示出令…

idea 8年使用整理

文章目录 前言idea 8年使用整理1. 覆盖application配置2. 启动的时候设置编辑空间大小&#xff0c;并忽略最大空间3. 查询类的关系4. 查看这个方法的引用关系5. 查看方法的调用关系5.1. 查看被调用关系5.2. 查看调用关系 6. 方法分隔线7. 选择快捷键类型8. 代码预览插件9. JReb…

3.微服务灰度发布落地实践(组件灰度增强)

文章目录 前言调用链示图dubbo服务之间的的调链cloud 服务之间的调用链 网关servlet容器: 标签续传1.定义插件2.实现灰度增强拦截 线程池: 标签续传1.拦截Runnable或Callable,接口增强实现标签续传;Callable 插件定义Runnable 插件定义拦载Callabl或Runnable构造(可共用)拦载ru…

java基础知识22 java的反射机制

一 java反射机制 1.1 概述 Java反射&#xff0c;程序在运行时&#xff0c;动态获取类信息&#xff08;类元数据&#xff09;&#xff0c;获取字段属性&#xff0c;动态创建对象和调用方法。Spring框架正是基于反射机制&#xff0c;通过我们的配置文件&#xff0c;在项目运行时…

[羊城杯 2024]Check in

下载附件&#xff0c;解压的时候发现注释&#xff1a;5unVpeVXGvjFah 解压得到的flag.txt文件内容如下&#xff1a; 注释5unVpeVXGvjFah放到随波逐流中一键解码发现base58解码得出一个正常点的字符串&#xff1a;Welcome2GZ&#xff0c;应该是某个key&#xff1f; 去hex解码&am…

C++Primer 控制流

欢迎阅读我的 【CPrimer】专栏 专栏简介&#xff1a;本专栏主要面向C初学者&#xff0c;解释C的一些基本概念和基础语言特性&#xff0c;涉及C标准库的用法&#xff0c;面向对象特性&#xff0c;泛型特性高级用法。通过使用标准库中定义的抽象设施&#xff0c;使你更加适应高级…

RJ45网口模块设计

1、以太网概述及RJ45实物 2、常用网口信号介绍 3、RJ45网口布局布线要点分析 4、总结 1、变压器下面需要进行挖空处理&#xff0c;以免底下的铜引入干扰&#xff0c;&#xff08;将多边形挖空区域的所在层设置为Multi-Layer多层&#xff09; 2、为了更直观的看一个类中线的长…