1600*C. Binary String Copying

https://codeforces.com/problemset/problem/1849/C

Binary String Copying - 洛谷

解析:

对于某个区间x,y,他排序之后,最左侧的连续0和最右侧的连续1是不影响排序结果的。

假设左侧连续a个0,右侧b个1,那么对于 [x,y]排序,和对于[x+a,y-b]排序是一样的。

所以我们记录每个位置最近的右侧1的坐标和最左侧的0的坐标,每次将范围映射到更小的唯一区间里里面即可。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=2e5+5;
int t,n,m,a[N],l[N],r[N],k;
int main(){
	scanf("%d",&t);
	while(t--){
		scanf("%d%d",&n,&m);
		k=0;
		for(int i=1;i<=n;i++){
			scanf("%1d",&a[i]);
			if(a[i]==0) k=i;
			l[i]=k;
		}
		k=n+1;
		for(int i=n;i>=1;i--){
			if(a[i]==1) k=i;
			r[i]=k;
		}
		set<pair<int,int>>res;
		for(int i=1;i<=m;i++){
			int x,y;
			scanf("%d%d",&x,&y);
			x=r[x];
			y=l[y];
			if(x>y) x=1,y=1;
			res.insert({x,y});
		}
		printf("%d\n",res.size());
	}
	return 0;
}
相关推荐
颜酱13 分钟前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱1 小时前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法
CoovallyAIHub18 小时前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉
CoovallyAIHub20 小时前
实时视觉AI智能体框架来了!Vision Agents 狂揽7K Star,延迟低至30ms,YOLO+Gemini实时联动!
算法·架构·github
CoovallyAIHub20 小时前
开源:YOLO最强对手?D-FINE目标检测与实例分割框架深度解析
人工智能·算法·github
CoovallyAIHub20 小时前
OpenClaw:从“19万星标”到“行业封杀”,这只“赛博龙虾”究竟触动了谁的神经?
算法·架构·github
刀法如飞20 小时前
程序员必须知道的核心算法思想
算法·编程开发·算法思想
徐小夕1 天前
pxcharts Ultra V2.3更新:多维表一键导出 PDF,渲染兼容性拉满!
vue.js·算法·github