CSP-X2024解题报告(T3)

C. [CSP-X 2024 -- T3] 翻硬币

内存限制:256 MiB时间限制:1000 ms输入文件:coin.in输出文件:coin.out

题目类型:传统评测方式:文本比较

题目描述

枚硬币从左到右依次排成一排,编号依次为 1 到 n。硬币的正面朝上用 0 表示,背面朝上用 1 表示,一开始所有的硬币都是正面朝上。

现进行 m 次操作,每次操作是把一个区间内的所有硬币翻过来:原来正面朝上的变为反面朝上,原来反面朝上的变为正面朝上。

第 次操作的区间 [l[i],r[i]] :表示把从第 l 到第 r 枚之间的所有硬币都翻过来。

求 次操作后所有硬币从左到右依次组成的 数字序列

输入格式

输入文件 coin.in

第一行整数 n 和整数 m,表示一共有 n 枚硬币和 m 次操作。

以下 行,每行两个正数数 l[ i ] , r[ i ] ,依次表示每次操作区间。

输出格式

输出文件 coin.out

m 次操作结束后 n 枚硬币从左到右依次组成的 01 数字序列。

样例

输入样例 #1

复制代码
5 3
2 4
1 3
3 5

输出样例 #1

复制代码
10101

输入样例 #2

复制代码
10 5
1 6
8 10
3 7
4 6
2 5

输出样例 #2

复制代码
1010011111
数据范围与提示

60% 的数据 1 ≤ n, m ≤ 1000;

100% 的数据 1 ≤ n, m ≤ 200000

差分模板题

一个一维数组,将每两个数的差做差分数组。

如果将l~r的数组同时加上x,就将a[l]+x,a[r+1]-x。

操作后求前缀和就是结果。

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
int b[200005];
int main(){
	freopen("coin.in","r",stdin);
	freopen("coin.out","w",stdout);
	int n,m,l,a[200005],r;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		a[i]=0;
	}
	while(m--){
		cin>>l>>r;
		b[l]++;
		b[r+1]--;
	}
	for(int i=1;i<=n;i++){
		b[i]+=b[i-1];
	}
	for(int i=1;i<=n;i++){
		cout<<b[i]%2;
	}
	return 0;
}
相关推荐
CoovallyAIHub3 分钟前
为你的 2026 年计算机视觉应用选择合适的边缘 AI 硬件
深度学习·算法·计算机视觉
汉克老师3 分钟前
GESP2025年12月认证C++六级真题与解析(单选题8-15)
c++·算法·二叉树·动态规划·哈夫曼编码·gesp6级·gesp六级
刘立军7 分钟前
程序员应该熟悉的概念(8)嵌入和语义检索
人工智能·算法
hk112419 分钟前
【Architecture/Refactoring】2026年度企业级遗留系统重构与高并发架构基准索引 (Grandmaster Edition)
数据结构·微服务·系统架构·数据集·devops
im_AMBER23 分钟前
Leetcode 95 分割链表
数据结构·c++·笔记·学习·算法·leetcode·链表
Boilermaker199231 分钟前
[算法基础] FooldFill(DFS、BFS)
算法·深度优先·宽度优先
leiming638 分钟前
c++ find 算法
算法
CoovallyAIHub40 分钟前
YOLOv12之后,AI在火场如何进化?2025最后一篇YOLO论文揭示:要在浓烟中看见关键,仅靠注意力还不够
深度学习·算法·计算机视觉
梭七y40 分钟前
【力扣hot100题】(121)反转链表
算法·leetcode·链表
qq_4335545442 分钟前
C++字符串hash
c++·算法·哈希算法