【贪心】CF1779 D

news2025/1/21 13:59:26

不会1700

Problem - 1779D - Codeforces

题意:

 

思路:

首先手推样例,可以发现一些零碎的性质:

 

 然后考虑如何去计算贡献

难点在于,当一个区间的两端是区间max时,怎么去计算贡献

事实上,只需要考虑这个数上次出现的最近位置即可

用pre数组记录这个数上次出现的最近位置,用st表判断是否为区间max

如果是,就统计这个元素需要被染色次数,然后比较颜料是否足够即可

还有一点细节就是,不能漏统计最后一段

Code:

#include <bits/stdc++.h>

#define int long long

using i64 = long long;

constexpr int N = 2e5 + 10;
constexpr int mod = 998244353;

int n;
int a[N], b[N], c[N];
int f[N][33];

void F_init() {
	for (int i = 1; i <= n; i ++) {
		f[i][0] = b[i];
	}

	for (int j = 1; j <= 30; j ++) {
		for (int i = 1; i + (1 << (j - 1)) <= n; i ++) {
			f[i][j] = std::max(f[i][j - 1], f[i + (1 << (j - 1))][j - 1]);
		}
	}
}
int query_mx(int l, int r) {
	int k = r - l + 1;
	int lg = std::log2(k);
	return std::max(f[l][lg], f[r - (1 << lg) + 1][lg]);
}
void solve() {
	std::cin >> n;

	for (int i = 1; i <= n; i ++) {
		a[i] = b[i] = c[i] = 0;
		for (int j = 0; j <= 30; j ++) {
			f[i][j] = 0;
		}
	}
	for (int i = 1; i <= n; i ++) {
		std::cin >> a[i];
	}
	
	for (int i = 1; i <= n; i ++) {
		std::cin >> b[i];
	}

	std::map<int,int> mp, mp2, pre;

	int m;
	std::cin >> m;

	for (int i = 1; i <= m; i ++) {
		std::cin >> c[i];
		mp[c[i]] ++;
	}

	for (int i = 1; i <= n; i ++) {
		if (b[i] > a[i]) {
			std::cout << "NO" << "\n";
			return;
		}
	}

	F_init();

	for (int i = 1; i <= n; i ++) {
		if (a[i] == b[i]) continue;
		if (!pre[b[i]]) {
			pre[b[i]] = i;
			continue;
		}
		if (query_mx(pre[b[i]], i) > b[i]) {
			mp2[b[i]] ++;
		}
		pre[b[i]] = i;
	}
	for (auto v : pre) {
		if (v.second) {
			mp2[v.first] ++;
		}
	}
	for (auto v : mp2) {
		if (v.second > mp[v.first]) {
			std::cout << "NO" << "\n";
			return;
		}
	}

	std::cout << "YES" << "\n";
}

signed main() {
    std::ios::sync_with_stdio(false);
    std::cin.tie(nullptr);
    
    int t = 1;

    std::cin >> t;
    
    while (t--) {
        solve();
    }
    
    return 0;
}

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

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

相关文章

input输入框自动填充后消除背景色

一般自动填充后会有一个突出的浅蓝色背景&#xff0c;一定也不好看&#xff0c;所以想把它去掉&#xff1a; 这个时候&#xff0c;就要用到浏览器的样式设置了&#xff1a; input:-webkit-autofill {background: transparent;transition: background-color 50000s ease-in-ou…

浅谈5G技术会给视频监控行业带来的一些变革情况

5G是第五代移动通信技术&#xff0c;能够提供更高的带宽和更快的传输速度&#xff0c;这将为视频技术的发展带来大量机会。随着5G技术的逐步普及与商用&#xff0c;人们将能够享受到更加流畅的高清视频体验&#xff0c;并且5G技术还拥有更低的延迟和更高的网络容量。这些优势不…

Android Shape 的使用

目录 什么是Shape? shape属性 子标签属性 corners &#xff08;圆角&#xff09; solid &#xff08;填充色&#xff09; gradient &#xff08;渐变&#xff09; stroke &#xff08;描边&#xff09; padding &#xff08;内边距&#xff09; size &#xff08;大小…

校园外卖小程序怎么做

校园外卖小程序是为满足校园内学生和教职员工的外卖需求而开发的一种应用程序。它涵盖了从用户端、商家端、骑手端、电脑管理员到小票打印、多商户入驻等多个方面的功能&#xff0c;以下将逐一介绍。 1. 用户端功能&#xff1a;校园外卖小程序为用户提供了便捷的订餐和外卖服务…

谦卦-六爻皆吉

前言&#xff1a;满招损&#xff0c;谦受益&#xff0c;谦卦在六十四卦是唯一的六爻皆吉的卦&#xff0c;今天学习谦卦的卦辞和爻辞。 卦辞 亨&#xff0c;君子有终。 序卦&#xff1a;有大者不可以盈&#xff0c;故受之以谦 篆曰&#xff1a;谦&#xff0c;亨&#xff0c;天…

解读注解@Value占位符替换过程

之前写过一篇关于介绍Spring占位符替换原理的博客&#xff0c;传送门 &#xff1a;Spring的占位符是怎么工作的 在这篇文章基础上&#xff0c;再介绍一下Value替换原理&#xff0c;两篇文章有一定的相关性。 继续以上一篇的工程为例&#xff0c;项目结构一样&#xff0c;这里就…

微波雷达感应模块XBG-M556

一、概括 XBG-M556是一款采用多普勒雷达技术,专门检测物体移动的微波感应模块。采用2.9G微波信号检测&#xff0c;该模块具有灵敏度高&#xff0c;可靠性强&#xff0c;感应角度大&#xff0c;工作电压宽等特点。高电平输出&#xff0c;可直接驱动外部 LED灯或负载。输入电压高…

Linux中执行一个Sheel脚本/系统重启后自动执行脚本

Linux中执行一个Sheel脚本 一&#xff1a;编写一个重启Java服务的.sh脚本 Windows中创建一个restart.sh文件 将一下脚本内容copy中restart.sh文件中 #!/bin/bashJAR_NAME"cloud.jar" LOG_FILE"restart.log"# 进入目录 cd /opt/server/cloudRecord/# 检查…

探索API接口的奥秘:解析与应用

什么是API接口&#xff1f;为什么它如此重要&#xff1f; 在现代技术和互联网时代&#xff0c;API接口是互联网服务之间实现数据传输和交流的关键链接。 API&#xff08;应用程序编程接口&#xff09;是一组定义了不同软件组件之间交互的规则和约定。 它允许不同的软件系统之间…

通过Git使用GitHub

目录 一、建立个人仓库 二、配置SSH密钥 三、克隆仓库代码 四、推送代码到个人仓库 五、代码拉取 一、建立个人仓库 1.建立GitHub个人仓库&#xff0c;首先注册GitHub用户。注册好了之后&#xff0c;打开用户的界面 然后就是配置问题 配置好后拉到最下方点击create repos…

day9 STM32 I2C总线通信

I2C总线简介 I2C总线介绍 I2C&#xff08;Inter-Integrated Circuit&#xff09;总线&#xff08;也称IIC或I2C&#xff09;是由PHILIPS公司开发的两线式串行总线&#xff0c;用于连接微控制器及其外围设备&#xff0c;是微电子通信控制领域广泛采用的一种总线标准。 它是同步通…

MFA多因素认证和TOTP认证逻辑解析

MFA多因素认证与TOTP认证逻辑解析 在今天的数字时代&#xff0c;隐私和安全变得尤为重要。用户越来越需要确保他们的在线账户和敏感信息不会落入不法分子之手。为此&#xff0c;多因素认证&#xff08;Multi-Factor Authentication&#xff0c;MFA&#xff09;应运而生&#x…

Linux系统编程:采用管道的方式实现进程间通信

目录 一. 进程间通信概述 二. 管道的概念 三. 通过管道实现进程间通信 3.1 实现原理 3.2 匿名管道创建系统接口pipe 3.3 管道通信的模拟实现 3.4 管道通信的访问控制规则 3.5 管道通信的特点 四. 通过匿名管道实现进程池 4.1 进程池的概念 4.2 进程池的模拟实现 五…

Android 广播发送流程分析

在上一篇文章中Android 广播阻塞、延迟问题分析方法讲了广播阻塞的分析方法&#xff0c;但是分析完这个问题&#xff0c;自己还是有一些疑问&#xff1a; 广播为啥会阻塞呢&#xff1f;发送给接收器就行了&#xff0c;为啥还要等着接收器处理完才处理下一个&#xff1f;由普通…

分布式文件系统(FastDFS)

&#x1f353; 简介&#xff1a;java系列技术分享(&#x1f449;持续更新中…&#x1f525;) &#x1f353; 初衷:一起学习、一起进步、坚持不懈 &#x1f353; 如果文章内容有误与您的想法不一致,欢迎大家在评论区指正&#x1f64f; &#x1f353; 希望这篇文章对你有所帮助,欢…

吐血整理,接口自动化测试-接口依赖/上传接口处理(项目实例)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 常见的两种接口依…

Docker容器与虚拟化技术:Docker资源控制、数据管理

目录 一、理论 1.资源控制 2.Docker数据管理 二、实验 1.Docker资源控制 2.Docker数据管理 三、问题 1.docker容器故障导致大量日志集满&#xff0c;造成磁盘空间满 2、当日志占满之后如何处理 四、总结 一、理论 1.资源控制 (1) CPU 资源控制 cgroups&#xff0…

什么是前端框架?怎么学习? - 易智编译EaseEditing

前端框架是一种用于开发Web应用程序界面的工具集合&#xff0c;它提供了一系列预定义的代码和结构&#xff0c;以简化开发过程并提高效率。 前端框架通常包括HTML、CSS和JavaScript的库和工具&#xff0c;用于构建交互式、动态和响应式的用户界面。 学习前端框架可以让您更高效…

Centos8安装docker并配置Kali Linux图形化界面

鉴于目前网上没有完整的好用的docker安装kali桌面连接的教程&#xff0c;所以我想做一个。 准备工作 麻了&#xff0c;这服务器供应商提供的镜像是真的纯净&#xff0c;纯净到啥都没有。 问题一&#xff1a;Centos8源有问题 Error: Failed to download metadata for repo ap…

Redis基础概念和数据类型详解

目录 1.什么是Redis&#xff1f; 2.为什么要使用Redis&#xff1f; 3.Redis为什么这么快&#xff1f; 4.Redis的使用场景有哪些&#xff1f; 5.Redis的基本数据类型 5.1 5种基础数据类型 5.1.1 String字符串 5.1.2 List列表 5.1.3 Set集合 5.1.4 Hash散列 5.1.5 Zset有序集…