【每日一题】CF1607 D. Blue-Red Permutation | 贪心 | 简单

题目内容

原题链接

给定一个长度为 n n n 的数组 a a a ,以及一个长度为 n n n 的字符串 s s s ,字符要么为 'B' 要么为 'R'

一次操作中,可以选择一个下标 i i i

  • 如果 s i s_i si'B' ,可以将 a i a_i ai 减少 1 1 1
  • 如果 s i s_i si'R' ,可以将 a i a_i ai 加上 1 1 1

执行若干次操作,问是否可以将数组 a a a 操作成一个 1 − n 1-n 1n 的排列。

数据范围

  • 3 ≤ n ≤ 2 ⋅ 1 0 5 3\leq n\leq 2\cdot 10^5 3n2105
  • 1 ≤ a i ≤ 1 0 9 1\leq a_i\leq 10^9 1ai109

题解

对于下标 i i i

  • 如果 s i s_i si'B' ,那么小于等于 a i a_i ai 的值都可以达到
    • 对于小于等于 0 0 0 a i a_i ai ,其可达值均不会在 1 − n 1-n 1n 之间,此时答案必然为 NO
    • 排除上面的情况,我们可以将 a i a_i ai 替换为 [ 1 , a i ] [1, a_i] [1,ai] 中的任意一个数
  • 如果 s i s_i si'R' ,那么大于等于 a i a_i ai 的值都可以达到
    • 对于大于等于 n + 1 n+1 n+1 a i a_i ai ,其可达值均不会在 1 − n 1-n 1n 之间,此时答案必然为 NO
    • 排除上面的情况,我们可以将 a i a_i ai 替换为 [ a i , n ] [a_i, n] [ai,n] 中的任意一个数

所以我们最终预处理出每个数可以变成 [ 1 , a i ] [1,a_i] [1,ai] 或者 [ a i , n ] [a_i,n] [ai,n]

贪心的考虑

  • 对于 [ 1 , a i ] [1,a_i] [1,ai] 的区间,我们先考虑 a i a_i ai 更小的数,依次将对应的数变成 1 , 2 , ⋯ , x 1,2,\cdots,x 1,2,,x
  • 对于 [ a i , n ] [a_i,n] [ai,n] 的区间,我们也先考虑 a i a_i ai 更小的数,依次将对应的数变成 x + 1 , x + 2 , ⋯ , n x+1,x+2,\cdots,n x+1,x+2,,n

如果最终我们不能将每个数都拿到,则说明无法操作为一个排列。

时间复杂度: O ( n log ⁡ n ) O(n\log n) O(nlogn) ,瓶颈在于排序

代码

#include <bits/stdc++.h>
using namespace std;void solve() {int n;cin >> n;vector<int> a(n);for (int i = 0; i < n; ++i) cin >> a[i];string s;cin >> s;vector<int> st, ed;for (int i = 0; i < n; ++i) {if (s[i] == 'B') {if (a[i] <= 0) {cout << "NO\n";return;}// 1 ~ a[i]st.push_back(a[i]);} else {if (a[i] > n) {cout << "NO\n";return;}// a[i] ~ nif (a[i] == 1) st.push_back(n);else ed.push_back(a[i]);}}sort(st.begin(), st.end());sort(ed.begin(), ed.end());// 先看 st 能拯救多少个int cur = 1;for (int u: st) {if (u >= cur) cur += 1;else break;}for (int u: ed) {if (u <= cur) cur += 1;else break;}if (cur > n) {cout << "YES\n";} else {cout << "NO\n";}
}int main()
{ios::sync_with_stdio(false);cin.tie(nullptr);int T = 1;cin >> T;while (T--) {solve();}return 0;
}

代码分析

在上述代码实现中,我们做了两部分考虑:

  • [ 1 , a i ] [1,a_i] [1,ai] 这样开头的,那么我们将其加入 st
  • [ a i , n ] [a_i,n] [ai,n] 这样开头的,那么我们将其加入 ed
  • 对于 [ 1 , n ] [1,n] [1,n] 的这个既属于 [ 1 , a i ] [1,a_i] [1,ai] 也属于 [ a i , n ] [a_i,n] [ai,n] 的,我们将其加入了 st ,是否有问题呢?

我们来思考下将其加入到 sted 的情况:

  • 加入到 st ,我们优先考虑 a i a_i ai 小的。
  • 先操作 [ 1 , a i ] [1,a_i] [1,ai] 的,其中 a i = n a_i=n ai=n 对应的 [ 1 , n ] [1,n] [1,n] 是在这部分最后的,然后是 [ a i , n ] [a_i,n] [ai,n]
  • 加入到 ed ,我们优先考虑 a i a_i ai 小的。先操作到 [ 1 , a i ] [1,a_i] [1,ai] 的,然后操作 [ a i , n ] [a_i,n] [ai,n] ,对于 [ a i , n ] [a_i,n] [ai,n] 这部分先考虑 [ 1 , n ] [1,n] [1,n] ,再考虑 a i > 1 a_i>1 ai>1 [ a i , n ] [a_i,n] [ai,n]

因此加入到哪部分都是一样的, [ 1 , n ] [1,n] [1,n] 总是在最中间被操作。

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

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

相关文章

App Inventor 2 SQLite 拓展

SQLite 拓展 此SQLite 拓展由中文网开发及维护&#xff0c;与 TaifunSQLite 功能类似&#xff0c;但TaifunSQLite是收费的&#xff0c;美刀。 文档及拓展下载地址&#xff1a; App Inventor 2 SQLite 拓展&#xff1a;超流行兼容主流SQL语法的迷你本地数据库引擎 App Invento…

018——红外遥控模块驱动开发(基于HS0038和I.MX6uLL)

目录 一、 模块介绍 1.1 简介 1.2 协议 二、 驱动代码 三、 应用代码 四、 实验 五、 程序优化 一、 模块介绍 1.1 简介 红外遥控被广泛应用于家用电器、工业控制和智能仪器系统中&#xff0c;像我们熟知的有电视机盒子遥控器、空调遥控器。红外遥控器系统分为发送端和…

python如何读取excel文件,并修改内容?

要在Python中读取和修改Excel文件&#xff0c;可以使用openpyxl库。这个库允许你处理Excel文件&#xff08;.xlsx格式&#xff09;&#xff0c;包括读取、修改单元格内容以及保存修改。以下是一个简单的示例&#xff0c;展示了如何使用openpyxl读取Excel文件、修改内容并保存文…

【SCI绘图】【热力图系列1 R】多特征相关性分析热力图R语言实现

SCI&#xff0c;CCF&#xff0c;EI及核心期刊绘图宝典&#xff0c;爆款持续更新&#xff0c;助力科研&#xff01; 本期分享&#xff1a; 【SCI绘图】【热力图系列1 R】多特征相关性分析热力图R语言实现 1.环境准备 library(gplots) library(RColorBrewer) 2.数据示例 ###…

宠物医院管理系统

文章目录 宠物医院管理系统一、系统演示二、项目介绍三、12000字论文参考四、系统部分页面展示五、部分代码展示六、底部获取项目源码和万字论文参考&#xff08;9.9&#xffe5;带走&#xff09; 宠物医院管理系统 一、系统演示 宠物医院管理系统 二、项目介绍 语言&#xf…

基于YOLOv8的GC10-DET缺陷检测系统(Python源码+Pyqt6界面+数据集)

&#x1f4a1;&#x1f4a1;&#x1f4a1;本文摘要&#xff1a;基于YOLOv8的GC10-DET缺陷检测系统&#xff0c;并阐述了整个数据制作和训练可视化过程&#xff0c;最后通过Pyside UI界面进行展示。 博主简介 AI小怪兽&#xff0c;YOLO骨灰级玩家&#xff0c;1&#xff09;YOL…

JAVA并发编程(二)_线程池

JAVA线程池 1.1Java 线程池之 Executor 框架 为了实现线程池和管理线程池&#xff0c;JDK 给我们提供了基于 Executor 接口的一系列接口、抽象类、实现类&#xff0c;我们把它称作线程池的 Executor 框架&#xff0c;Executor 框架本质上是一个线程池&#xff1b; ​ Java 线…

Python的基础知识学习路线1—python简介与环境配置(最全路线,每部分附有代码操作结果)

一、Python简介 &#xff08;1&#xff09;发展史 Python是由创始人贵铎范罗萨姆&#xff08;Guido van Rossum&#xff09;在阿姆斯特丹于1989年圣诞节期间&#xff0c;为了打发圣诞节的无趣&#xff0c;开发的一个新的解释型脚本语言。之所以选中Python&#xff08;大蟒蛇的…

免费SSL证书跟付费SSL证书有什么区别?

免费SSL证书与付费SSL证书的主要区别如下&#xff1a; 1. 类型与验证级别&#xff1a; - 免费SSL证书通常仅提供域名验证&#xff08;DV&#xff09;&#xff0c;这是一种最基本的验证级别&#xff0c;仅验证域名的所有权&#xff0c;确认申请者对所申请域名的有效控制。 - 付费…

AcWing 791. 高精度加法——算法基础课题解

AcWing 791. 高精度加法 题目描述 给定两个正整数&#xff08;不含前导 0&#xff09;&#xff0c;计算它们的和。 输入格式 共两行&#xff0c;每行包含一个整数。 输出格式 共一行&#xff0c;包含所求的和。 数据范围 1≤整数长度≤100000 输入样例&#xff1a; 1…

每天坚持做逆回购,一年下来,年化收益能达到多少?(附代码)

空口无凭&#xff0c;用数据说话&#xff0c;你可以自己检验各种逆回购策略的历史收益率。 比如说下面这段代码&#xff0c;可以自动进行沪深两市一天期国债逆回购的交易&#xff0c;在收盘之前&#xff0c;或下午 4 点钟之前&#xff0c;自动进行国债逆回购&#xff0c;用闲余…

怎样买国债逆回购最划算,国债逆回购手续费是多少?1折

国债逆回购是一种以国债作为抵押物的贷款&#xff0c;是一种能为投资者提高闲置资金增值能力的金融品种。国债逆回购的优势有&#xff1a; 安全性高&#xff0c;因为国债是信用等级最高、违约风险最低的金融资产&#xff0c;而且国债逆回购是在证券交易所进行的受监管的交易 …

【题解 | 二叉树】给定二叉树的后序遍历和中序遍历,求层序遍历结果

树的遍历 给定一棵二叉树的后序遍历和中序遍历&#xff0c;请你输出其层序遍历的序列。这里假设键值都是互不相等的正整数。 输入格式&#xff1a; 输入第一行给出一个正整数 N ( ≤ 30 ) N(≤30) N(≤30)&#xff0c;是二叉树中结点的个数。第二行给出其后序遍历序列。第三…

grep 和 pgrep

grep 和 pgrep 是两个不同的命令&#xff0c;它们在Linux和类Unix系统中用于搜索文本&#xff0c;但各自的应用场景和功能有所差异。 grep 全称&#xff1a;Global Regular Expression Print 用途&#xff1a;grep 主要用于在文件或者通过管道传递的输出中搜索与指定模式&…

深入探讨udevd:Linux中的设备管理守护进程

Linux操作系统的强大功能之一在于其对硬件的优秀支持。无论是新接入的USB设备还是系统内部的硬件变化&#xff0c;Linux都能够灵活地处理。这得益于udevd—一种设备管理守护进程。在本篇博客中&#xff0c;我们将详细探讨udevd的工作原理、配置和在系统中的重要性。 什么是ude…

深度学习500问——Chapter06: 循环神经网络(RNN)(2)

文章目录 6.4 CNN和RNN的区别 6.5 RNNs与FNNs有什么区别 6.6 RNNs训练和传统ANN训练异同点 6.7 为什么RNN训练的时候Loss波动很大 6.8 标准RNN前向输出流程 6.9 BPTT算法推导 6.9 RNN中为什么会出现梯度消失 6.10 如何解决RNN中的梯度消失问题 6.4 CNN和RNN的区别 类别特点描述…

博客系统实现

一.准备工作 1.创建项目&#xff0c;把前端写好的博客静态页面拷贝到webapp目录中 2.引入依赖&#xff0c;这里主要用到servlet&#xff0c;mysql5.1.47&#xff0c;jacson2.15.0 3.找到右上角的edit configurations->smartTomcat->进行配置 4.数据库设计&#xff1a…

2024年4月9号PMP每日三题含答案

2024年4月9号PMP每日三题含答案 1.在执行一个潜艇现代化项目期间&#xff0c;客户要求安装新的潜望镜。项目经理必须怎么做&#xff1f; A.检查可行性&#xff0c;准备预算&#xff0c;并获得变更请求批准 B.执行实施整体变更控制过程&#xff0c;获得预算批准&#xff0c;并执…

Java8 函数式编程 @FunctionInterface使用示例

FunctionInterface 是一个注解&#xff0c;用在接口上面。 接口内部只能有一个方法。 作用&#xff1a; 将函数作为参数传入其它方法。 背景 看如下代码&#xff0c; 发现send1 send2 send3 方法都有共同的代码用于获取参数&#xff0c;唯一不同的是消息发送逻辑不一样。 那…

吴恩达深度学习 (week1,2)

文章目录 1、神经网络监督学习2、深度学习兴起原因3、深度学习二元分类4、深度学习Logistic 回归5、Logistic 回归损失函数6、深度学习梯度下降法7、深度学习向量法8、Python 中的广播9、上述学习总结10、大作业实现:rocket::rocket:&#xff08;1&#xff09;训练初始数据&…