Educational Codeforces Round 89 (Rated for Div. 2) B. Shuffle (数学,区间)

题意:有长为\(n\)的排列,其中\(x\)位置上的数为\(1\),其余位置全为\(0\),询问\(m\)次,每次询问一个区间,在这个区间内可以交换任意两个位置上的数,问\(1\)最后出现在不同位置的次数.
题解:维护区间即可,如果某个区间包含了\(1\),更新最大的答案区间,(每次更新后说明这整个区间都能取到\(1\)).
代码:
#include <iostream>
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
#include <stack>
#include <queue>
#include <vector>
#include <map>
#include <set>
#include <unordered_set>
#include <unordered_map>
#define ll long long
#define fi first
#define se second
#define pb push_back
#define me memset
const int N = 1e6 + 10;
const int mod = 1e9 + 7;
const int INF = 0x3f3f3f3f;
using namespace std;
typedef pair<int,int> PII;
typedef pair<ll,ll> PLL; int t;
int l,r;
int n,x,m; int main() {
ios::sync_with_stdio(false);cin.tie(0);
cin>>t;
while(t--){
cin>>n>>x>>m;
int mi=x;
int mx=x;
for(int i=1;i<=m;++i){
cin>>l>>r;
if(l<=mi&&r>=mi){
mi=l;
}
if(l<=mx&&r>=mx){
mx=r;
}
}
printf("%d\n",mx-mi+1);
} return 0;
}
Educational Codeforces Round 89 (Rated for Div. 2) B. Shuffle (数学,区间)的更多相关文章
- Educational Codeforces Round 89 (Rated for Div. 2) B. Shuffle(数学/双指针)
		
题目链接:https://codeforces.com/contest/1366/problem/B 题意 大小为 $n$ 的数组 $a$,除了 $a_x = 1$,其余 $a_i = 0$,依次给出 ...
 - Educational Codeforces Round 89 (Rated for Div. 2) C. Palindromic Paths(贪心)
		
题目链接:https://codeforces.com/contest/1366/problem/C 题意 有一个 $n \times m$ 的 $01$迷宫,要使从 $(1,1)$ 到 $(n,m) ...
 - Educational Codeforces Round 89 (Rated for Div. 2) A. Shovels and Swords(贪心/数学)
		
题目链接:https://codeforces.com/contest/1366/problem/A 题意 有两个数 $a$ 和 $b$,每次可以选择从一个数中取 $2$,另一个数中取 $1$,问最多 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)    C   Palindromic Paths
		
题目链接:Palindromic Paths 题意: 给你一个n行m列的矩阵,这个矩阵被0或者1所填充,你需要从点(1,1)走到点(n,m).这个时候会有很多路径,每一条路径对应一个01串,你可以改变 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)   A  Shovels and Swords   B、Shuffle
		
题目链接:A.Shovels and Swords 题意: 你需要一个木棍和两个钻石可以造出来一把剑 你需要两个木棍和一个钻石可以造出来一把铁锹 你现在有a个木棍,b个钻石,问你最多可以造出来几件东西 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)D. Two Divisors   线性筛质因子
		
题目链接:D:Two Divisors 题意: 给你n个数,对于每一个数vi,你需要找出来它的两个因子d1,d2.这两个因子要保证gcd(d1+d2,vi)==1.输出的时候输出两行,第一行输出每一个 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)   A. Shovels and Swords  (贪心)
		
题意:你有\(a\)个树枝和\(b\)个钻石,\(2\)个树枝和\(1\)个钻石能造一个铁铲,\(1\)个树枝和\(2\)个钻石能造一把剑,问最多能造多少铲子和剑. 题解:如果\(a\le b\),若 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)  D. Two Divisors  (数学)
		
题意:有\(n\)组数,对于每组数,问是否能找到两个因子\(d_{1},d{2}\),使得\(gcd(d_{1}+d_{2},a_{i}=1)\),如果有,输出它们,否则输出\(-1\). 题解:对于 ...
 - Educational Codeforces Round 89 (Rated for Div. 2)   C. Palindromic Paths  (思维)
		
题意:有一个\(n\)x\(m\)的矩阵,从\((1,1)\)出发走到\((n,m)\),问最少修改多少个数,使得所有路径上的数对应相等(e.g:\((1,2)\)和\((n-1,m)\)或\((2, ...
 
随机推荐
- Linux 安装JDK配置环境(rpm安装和压缩版安装)
			
jdk安装 (rpm安装) jdk下载地址: https://www.oracle.com/cn/java/technologies/javase/javase-jdk8-downloads.html ...
 - 【Linux】zabbix4.0服务器搭建,agent搭建,及邮件使用方法
			
zabbix默认的 服务端监听端口为10051,而被监控端即Zabbix--agents代理程序监控10050端口. 更新yum源: yum clean all yum makecache 需要配置网 ...
 - CTF实验吧-WEB题目解题笔记(1)简单的登陆题
			
1.简单的登陆题 解题链接: http://ctf5.shiyanbar.com/web/jiandan/index.php Burp抓包解密 乱码,更换思路.尝试id intruder 似乎也没什 ...
 - Redis中哈希分布不均匀该怎么办
			
前言 Redis 是一个键值对数据库,其键是通过哈希进行存储的.整个 Redis 可以认为是一个外层哈希,之所以称为外层哈希,是因为 Redis 内部也提供了一种哈希类型,这个可以称之为内部哈希.当我 ...
 - Golang应用性能问题排查分析
			
背景 公司有一个使用golang开发的采集模块,负责调用多个外部系统采集数据:最近做了一次架构上的调整,将采集模块分成api.job两个子模块,并部署到容器中,拆分前部署在虚机上. 现象 部分采集任务 ...
 - sap alv grid 中的delete按键问题
			
今天发先一个问题,在使用ALV输出的时候,如果有字段设置为可编辑状态,则会在前面出现选择条,并且,当我们选择一行或者多行的时候,可以用键盘上的DELETE键将行删除!呵呵
 - HTML基础复习1
			
网页:HTML(超文本标记语言) 网页分为静态网页和动态网页,区别:动态网页中可以加入脚本代码,还可以动态的引入数据库中的信息. HTML的结构 <html> <head>头信 ...
 - thinkphp如何实现伪静态
			
去掉 URL 中的 index.php ThinkPHP 作为 PHP 框架,是单一入口的,那么其原始的 URL 便不是那么友好.但 ThinkPHP 提供了各种机制来定制需要的 URL 格式,配合 ...
 - 4、剑指offer——从尾到头打印链表java实现
			
**题目描述** **输入一个链表,按链表从尾到头的顺序返回一个ArrayList.** 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ 32M,其他语言64M 思路: 1.如果链 ...
 - https://twistedmatrix.com/documents/current/core/howto/defer.html
			
https://twistedmatrix.com/documents/current/core/howto/defer.html