P9221 「TAOI-1」Pentiment(珂朵莉树,颜色段均摊,ODT)

news2025/1/10 16:41:48

洛谷 P9221 「TAOI-1」Pentiment

题解区说这题同类型,先码住,有时间做一下。


思路:

这题是个动态规划,如何动规在洛谷题解区第一篇题解中讲的非常详细了,不赘述了。

这里主要考虑如何快速实现求解,假设现在第 i − 1 i-1 i1 行的 d p dp dp 值已经算出来了了,现在要算第 i i i 行的 d p dp dp 值,先不看第 i i i 行上的障碍,那么形状差不多像下面:
在这里插入图片描述

假设第一,二行就是第 i i i i − 1 i-1 i1 行。那么第 i i i 行的区间 1 1 1 上的每个位置都相当于第 i − 1 i-1 i1 行的区间 1 1 1 中的元素之和(也就是区间长度乘以一个元素值),同理其他对应的区间。障碍上面位置答案值就是0。现在加入障碍:
在这里插入图片描述
放入障碍的地方答案被清零。其他地方的答案值不变。

这样递推的过程就分析结束了。考虑到区间长度可能会很大,但是区间个数本身很小,因此考虑将每个区间压成一个点,这就和珂朵莉树的思想相似了。尝试用珂朵莉树维护一行的信息。

一开始有区间123以及两个障碍点,如果我们对第 i i i 行边界到蓝色障碍这一块去找珂朵莉树中的区间12并计算答案之和会很麻烦,而且也不能使用split对区间进行拆开。求和之后也不能覆盖到珂朵莉树中。

考虑到我们可以先把答案算出来,然后再放入障碍。假设我们算出了第 i − 1 i-1 i1 行区间1,2,3分别的区间和并保存在珂朵莉树中,这就相当于算出了第 i i i 行中对应区间1,2,3上的每个元素值。现在直接加入蓝色障碍,并对前一个障碍或边界到加入的蓝色障碍这一段区间进行求和并用assign函数把它缩成一个点,这样得到的就是第 i i i 行这一段上的区间和。算出所有的区间和后。问题就又回到了开头——我们算出了第 i i i 行的每段区间的区间和,问第 i + 1 i+1 i+1 行的每段的区间和。

但是这样还是会超时,因为 n n n 太大了,而 q q q 相对来说就很小。因此会出现很多空行,考虑对空行进行合并,发现如果经过了 k k k 个空行,其实就相当于对整段上的区间和乘以 m k − 1 m^{k-1} mk1。所以在枚举第 c o l col col 行的障碍时,如果发现障碍在第 s s s 行,那么中间会经过 s − c o l s-col scol 个空行,区间和乘上 m s − c o l − 1 m^{s-col-1} mscol1 即可。或者后面没有障碍了,直接到第 n n n 行会有 n − c o l + 1 n-col+1 ncol+1 个空行,区间和乘上 m n − c o l m^{n-col} mncol

颜色段均摊是一种思想,说白了就是把一段性质相同的区间压成一个点。这个广义的颜色段其实就是具有某一性质的一段区间。实现颜色段均摊的思想用珂朵莉树相当合适。因为珂朵莉树就是把值相同的区间合并成一个结点保存在 set 里面。

code:

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <vector>
#include <set>
using namespace std;
typedef long long ll;
const int maxn=1e5+5;
const ll mod=998244353;

ll n,m,q;

ll qpow(ll a,ll b){
	ll base=a%mod,ans=1;
	while(b){
		if(b&1){
			ans*=base;
			ans%=mod;
		}
		base*=base;
		base%=mod;
		b>>=1;
	}
	return ans;
}

struct ODT{
	#define SIT set<Node>::iterator
	
	struct Node{
		int l,r;
		mutable ll val;
		Node(int l,int r=0,ll val=0):l(l),r(r),val(val){};
		bool operator<(const Node x)const{return l<x.l;}
	};
	set<Node> s;
	
	void print(){
		for(auto x:s)printf("[%d,%d] %lld\n",x.l,x.r,x.val);
		printf("\n");
	}
	void build(int n){
		s.insert(Node(1,n,1));
		s.insert(Node(n+1,n+1,0));
	}
	SIT split(int pos){
		SIT it=s.lower_bound(pos);
		if(it!=s.end() && it->l==pos)return it;
		it--;
		int l=it->l,r=it->r;
		ll val=it->val;
		s.erase(it);
		s.insert(Node(l,pos-1,val));
		return s.insert(Node(pos,r,val)).first;
	}
	SIT assign(int l,int r,ll v){
		SIT it2=split(r+1),it1=split(l);
		s.erase(it1,it2);
		return s.insert(Node(l,r,v)).first;
	}
	ll query(int l,int r){
		SIT it2=split(r+1),it1=split(l);
		ll ans=0;
		for(;it1!=it2;it1++)
			ans=(ans+(it1->r-it1->l+1)*it1->val%mod)%mod;
		return ans;
	}
	
	#undef SIT
}tr;

pair<ll,ll> bar[maxn];

int main(){
	cin>>n>>m>>q;
	for(int i=1;i<=q;i++)cin>>bar[i].first>>bar[i].second;
	tr.build(m);
	for(int p=1,col=1,l;col<=n;col++){
		if(p>q){
			ll line=n-col;
			tr.assign(1,m,tr.query(1,m)*qpow(m,line)%mod);
			break;
		}
		if(bar[p].first>col){
			ll line=bar[p].first-col-1;
			tr.assign(1,m,tr.query(1,m)*qpow(m,line)%mod);
			col=bar[p].first;
		}
		
		l=1;
		while(bar[p].first==col){
			int r=bar[p].second;
			if(l<r){
				tr.assign(l,r-1,tr.query(l,r-1));
			}
			tr.assign(r,r,0);
			l=r+1;
			p++;
		}
		if(l<=m){
			tr.assign(l,m,tr.query(l,m));
			l=m+1;
		}
	}
	cout<<tr.query(1,m)<<endl;
	
	return 0;
}

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

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

相关文章

【STM32备忘录】【STM32WB系列的BLE低功耗蓝牙】一、测试广播配置搜不到信号的注意事项

一、预备知识&#xff1a; WB系列是双核单片机&#xff0c;用户写M4&#xff0c;无线协议栈使用M0新买到手的单片机&#xff0c;需要自己刷入使用的无线协议栈刷入无线协议栈的途径是通过一个叫FUS的东东&#xff0c;类似于bootloader&#xff0c;这个FUS新买的芯片通常已经刷…

v65.二维数组

int num[100];//表示有100个空&#xff1a;从num[0]到num[99] 一维数组&#xff08;一个下标&#xff09;这样放置的好处是刚好和线性代数中矩阵的理解是一样的。所以 坐标 的思想是挺必要的在一维数组中&#xff0c;遍历数组只需要一重循环&#xff1b;但在二维数组中&#xf…

ElementUI组件的安装和使用

Element UI 是一款基于 Vue 2.0 的桌面端组件库&#xff0c;主要用于快速构建网站的前端部分。它提供了丰富的组件&#xff0c;如按钮、输入框、表格、标签页等&#xff0c;以及一些布局元素&#xff0c;如布局容器、分割线等。Element UI 的设计风格简洁&#xff0c;易于上手&…

web基础及http协议 (二)----------Apache相关配置与优化

一、httpd 安装组成 http 服务基于 C/S 结构 1 .常见http 服务器程序 httpd apache&#xff0c;存在C10K&#xff08;10K connections&#xff09;问题 nginx 解决C10K问题lighttpd IIS .asp 应用程序服务器 tomcat .jsp 应用程序服务器 jetty 开源的servlet容器&#xf…

MYSQL-入门

一.安装和连接 1.1 安装 mysql安装教程&#xff1a; 2021MySql-8.0.26安装详细教程&#xff08;保姆级&#xff09;_2021mysql-8.0.26安装详细教程(保姆级)_mysql8.0.26_ylb呀的博客-cs-CSDN博客 workbench安装&#xff1a; MySQL Workbench 安装及使用-CSDN博客 1.2 配…

关于不同文件传输协议的笔记

几种不同的文件传输协议&#xff0c;在个人局域网的搭建中起到重要的作用。 原文地址&#xff1a;关于不同文件传输协议的笔记 - Pleasure的博客 下面是正文内容&#xff1a; 前言 最近正在搭建个人的局域网络&#xff0c;所以不同系统间文件的共享功能是必不可少的。 而自己…

左手“兑抵接”,右手债务逾期,华夏幸福离“上岸”还有多远?

撰稿|行星 来源|贝多财经 进入2024年&#xff0c;华夏幸福仍不太“幸福”。 近日&#xff0c;华夏幸福基业股份有限公司&#xff08;SH: 600340&#xff0c;下称“华夏幸福”&#xff09;发布了关于债务逾期、债务重组进展等事项的公告。内容显示&#xff0c;华夏幸福截至1月…

基于SpringBoot的CSGO赛事管理系统源码和论文

CSGO赛事管理系统是针对CSGO赛事管理方面必不可少的一个部分。在CSGO赛事管理的整个过程中&#xff0c;CSGO赛事管理系统担负着最重要的角色。为满足如今日益复杂的管理需求&#xff0c;各类的管理系统也在不断改进。本课题所设计的CSGO赛事管理系统&#xff0c;使用java进行开…

(3)(3.6) 用于OpenTX的Yaapu遥测脚本

文章目录 前言 1 安装和操作 2 参数说明 前言 这是一个开源 LUA 脚本&#xff0c;用于在使用 OpenTX 2.2.3 的 Horus X10、X12、Jumper T16、T18、Radiomaster TX16S、Taranis X9D、X9E、QX7 和 Jumper T12 无线电设备上显示 FrSky 的直通遥测数据(FrSky passthrough telem…

单元测试、系统测试、集成测试详解

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 关注公众号【互联网杂货铺】&#xff0c;回复 1 &#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 一、单元测试的概念 单元测试是对软件基本组成单元进行的测试&…

5.iframe

iframe 经典真题 iframe 框架有哪些优缺点&#xff1f;iframe 用来干什么的 iframe 介绍 iframe 称之为嵌入式框架&#xff0c;嵌入式框架可以把一个完整的网页内容嵌入到现有的网页中。 下面是一个 iframe 的简单示例&#xff1a; <body><p>iframe 示例<…

基于Spring Boot+Mybatis+Shiro+EasyUI的宠物医院管理系统

项目介绍 本系统前台面向的用户是客户&#xff0c;客户可以进行预约、浏览医院发布的文章、进入医院商城为宠物购物、如有疑问可以向官方留言、还可以查看关于自己的所有记录信息&#xff0c;如&#xff1a;看病记录、预约记录、疫苗注射记录等。后台面向的用户是医院人员&…

2024年小白搭建雾锁王国Enshrouded服务器搭建教程

雾锁王国游戏服务器怎么创建&#xff1f;阿里云雾锁王国服务器搭建教程是基于计算巢服务&#xff0c;3分钟即可成功创建Enshrouded游戏服务器&#xff0c;阿里云8核32G雾锁王国专用游戏服务器90元1个月、271元3个月&#xff0c;阿里云百科aliyunbaike.com亲自整理雾锁王国服务器…

【Oracle】玩转Oracle数据库(四):SQL语言

前言 嘿&#xff0c;各位数据达人们&#xff01;准备好迎接新的挑战了吗&#xff1f;今天&#xff0c;我们要探索的是数据库世界的魔法咒语——SQL语言&#xff01;&#x1f52e;&#x1f4bb; 在这篇博文【Oracle】玩转Oracle数据库&#xff08;四&#xff09;&#xff1a;SQL…

Puppeteer 使用实战:如何将自己的 CSDN 专栏文章导出并用于 Hexo 博客(三)

文章目录 往期效果将文章信息导出适配 hexo 的文章模板导出的文章路径问题终端控制执行脚本代码整理结尾 往期 Puppeteer 使用实战&#xff1a;如何将自己的 CSDN 专栏文章导出并用于 Hexo 博客&#xff08;二&#xff09; 效果 写了一个 node 脚本用来批量处理 md 文件 本期…

Jenkins 中部署Nodejs插件并使用,并构建前端项目(3)

遇到多个版本nodeJS需要构建的时候 1、第一种就是一个配置安装&#xff0c;然后进行选中配置 2、第二种就是插件&#xff1a;nvm-wrapper&#xff0c;我们还是选用NodeJS插件&#xff1a; &#xff08;1&#xff09;可以加载任意npmrc文件&#xff1b; &#xff08;2&#x…

【DAY03 软考中级备考笔记】存储系统,总线系统,输入输出系统和可靠性

存储系统&#xff0c;总线系统&#xff0c;输入输出系统和可靠性 2月22日 – 天气&#xff1a;阴转晴 济南下大雪&#xff0c;居家办公两天。 1. 计算机存储器的分类 根据存储位置划分&#xff1a; 内存/主存&#xff1a;用来保存当前正在运行的程序所需要的数据&#xff0c…

远程连接 vscode 出错 “远程主机可能不符合 glibc 和 libstdc++ VS Code 服务器的先决条件”

原因&#xff1a; vscode 版本是 1.86&#xff0c;服务器上的 glibc 和 libstdc 版本不满足 要求(2.28 和 3.4.25)。 解决&#xff1a; 1、下载 1.85.2&#xff0c;解压直接运行 Code.exe。 2、回退 Remote-ssh 到 0.107.1。 参考&#xff1a; vscode 1.86版本远程ssh不兼容旧…

开源图表库Echarts 简介与基本使用

ECharts 是一个使用 JavaScript 实现的开源可视化图表库&#xff0c;由百度团队开发。它提供了丰富的图表类型&#xff0c;如折线图、柱状图、饼图、地图、雷达图等&#xff0c;并且可以轻松地与其他前端框架和库集成。ECharts 的设计目的是为了满足复杂数据的可视化需求&#…

CleanMyMac X2024破解版Mac系统优化和清理软件

CleanMyMac X2024全面介绍作为一名软件分析师&#xff0c;我深入研究了CleanMyMac X这款Mac系统优化和清理软件。CleanMyMac X以其丰富的功能、独特的特点、显著的优势以及广泛的适用场景&#xff0c;赢得了市场和用户的青睐。 CleanMyMac X2024绿色永久全新版下载如下: https…