51Nod1336 RMQ逆问题 其他
原文链接https://www.cnblogs.com/zhouzhendong/p/51Nod1336.html
题目传送门 - 51Nod1336
题意

题解
我们将输入的一个区间的答案称为 V 。
我们考虑存在排列的两个充分必要条件:
1. 一个值 V 只会出现在 询问结果为 V 的区间 的 交 中。
2. 对于任意一个 V ,所有询问结果不大于 V 的区间的并中,只可能出现不大于 V 的值。
于是我们只需要按照询问区间的 V 从小到达排序,然后依次处理即可。
代码
#include <bits/stdc++.h>
using namespace std;
const int N=205;
int read(){
int x=0;
char ch=getchar();
while (!isdigit(ch))
ch=getchar();
while (isdigit(ch))
x=(x<<1)+(x<<3)+ch-48,ch=getchar();
return x;
}
struct HashTable{
int v[N],n;
void clear(){n=0;}
void push(int x){v[++n]=x;}
void Hash(){sort(v+1,v+n+1);n=unique(v+1,v+n+1)-v-1;}
int find(int x){return lower_bound(v+1,v+n+1,x)-v;}
}p,v;
int T,n,m;
vector <int> vs[N];
struct Seg{
int L,R,v;
Seg(){}
Seg(int _L,int _R,int _v){
L=_L,R=_R,v=_v;
}
}s[N],t[N];
bool Getline(){
for (int i=1;i<=m;i++){
s[i].L=read();
s[i].R=read();
s[i].v=read();
p.push(s[i].L),p.push(s[i].L+1);
p.push(s[i].R),p.push(s[i].R+1);
v.push(s[i].v);
}
p.Hash();
v.Hash();
for (int i=1;i<=v.n;i++)
vs[i].clear();
for (int i=1;i<=m;i++){
s[i].L=p.find(s[i].L);
s[i].R=p.find(s[i].R);
s[i].v=v.find(s[i].v);
vs[s[i].v].push_back(i);
}
for (int i=1;i<=v.n;i++){
int L=-1,R=p.n+1;
for (vector <int> :: iterator p=vs[i].begin();p!=vs[i].end();p++){
L=max(L,s[*p].L);
R=min(R,s[*p].R);
}
if (L>R)
return 0;
t[i]=Seg(L,R,v.v[i]);
}
return 1;
}
int cover[N];
void solve(){
p.clear(),v.clear();
n=read(),m=read();
if (!Getline()){
puts("Impossible");
return;
}
memset(cover,0,sizeof cover);
for (int i=1;i<=v.n;i++){
int cnt=0,L=t[i].L,R=t[i].R,val=v.v[i];
for (int j=L;j<=R;j++)
if (!cover[j])
cnt+=p.v[j+1]-p.v[j];
for (vector <int> :: iterator P=vs[i].begin();P!=vs[i].end();P++)
for (int j=s[*P].L;j<=s[*P].R;j++)
cover[j]=1;
int tot=0;
for (int j=1;j<=p.n;j++)
if (cover[j])
tot+=p.v[j+1]-p.v[j];
if (cnt==0||tot>v.v[i]){
puts("Impossible");
return;
}
}
puts("Possible");
}
int main(){
T=read();
while (T--)
solve();
return 0;
}
51Nod1336 RMQ逆问题 其他的更多相关文章
- 51nod 1336 RMQ逆问题
RMQ问题是一类区间最值问题,这里给出一个特殊的RMQ问题,初始给定一个n长的排列P,注:n长排列是指有1~n这n个整数构成的一个序列每个整数恰好出现一次.并对这个排列P进行M次查询操作,每次查询形如 ...
- BZOJ 3489: A simple rmq problem
3489: A simple rmq problem Time Limit: 40 Sec Memory Limit: 600 MBSubmit: 1594 Solved: 520[Submit] ...
- UVA 11235Frequent values(RMQ)
训练指南P198 题意:给出一个非降序排列的整数数组a1, a2…… an,你的任务是对于一系列询问(i,j),回答ai, ai+1 ……aj 中出现的次数最多的次数 这题不仅学到了rmq的应用还学到 ...
- 51nod1174(RMQ)
题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1174 题意:中文题诶- 思路:RMQ模板题 关于RMQ: h ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1008 Function 二分+RMQ
Time Limit: 7000/3500 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Submissio ...
- Gym 100646 F Tanks a Lot RMQ
Problem F: Tanks a Lot Imagine you have a car with a very large gas tank - large enough to hold what ...
- (RMQ版)LCA注意要点
inline int lca(int x,int y){ if(x>y) swap(x,y); ]][x]]<h[rmq[log[y-x+]][y-near[y-x+]+]])? rmq[ ...
- 洛谷P2412 查单词 [trie树 RMQ]
题目背景 滚粗了的HansBug在收拾旧英语书,然而他发现了什么奇妙的东西. 题目描述 udp2.T3如果遇到相同的字符串,输出后面的 蒟蒻HansBug在一本英语书里面找到了一个单词表,包含N个单词 ...
- POJ3368Frequent values[RMQ 游程编码]
Frequent values Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 17581 Accepted: 6346 ...
随机推荐
- python bytes/str
http://eli.thegreenplace.net/2012/01/30/the-bytesstr-dichotomy-in-python-3/
- C++编程题
1.不用系统提供的字符串转int的功能,将一个字符串转换为对应的值 #include <iostream> using namespace std; static int StringTo ...
- Laravel-Excel 导入 Excel 文件----为什么只获取到最后一行数据?
### 今天使用了Laravel-Excel 到类文件,想做一个excel 文件到导入和导出,但是看了 官方到文档示例,自己做了一下,发现 只取到到最后一行到数据, 有点摸不着头脑! 网上找了一下, ...
- js-DOM事件
var EventUtil = { addHandler:function(elm,type,handler){//添加事件 if(elm.addEventListener){ elm.addEven ...
- 学习promise
总概括 promise是js异步编程的一种解决方案 我对promise的认识(通俗):给一个承诺promise,如果未来发生的事情(异步操作)是符合满足相应条件,则接受resolve,否则失败reje ...
- 谷歌被爆秘密研发新系统 欲5年内取代Android
谷歌2年多来有一群工程师秘密研发新系统,希望最终能取代手机操作系统安卓.安卓日前遭欧盟以反垄断为由重罚. 谷歌的新研发计划Fuchsia是从零开始,希望在更多个人装置和各式小巧装置联机上网的情况下,能 ...
- swift 学习- 11 -- 属性
// '属性'将值跟特定的类, 结构体或枚举关联, 存储属性常量或变量作为实例的一部分,而计算属性计算(不是存储) 一个值, 计算属性可以用于 类, 结构体, 枚举, 存储属性只能用于 类 和 结构体 ...
- PID控制器开发笔记之二:积分分离PID控制器的实现
前面的文章中,我们已经讲述了PID控制器的实现,包括位置型PID控制器和增量型PID控制器.但这个实现只是最基本的实现,并没有考虑任何的干扰情况.在本节及后续的一些章节,我们就来讨论一下经典PID控制 ...
- error: js/dist/app.js from UglifyJs Unexpected token: name (Dom7)
What you did I have installed Swiper as normal dependency in my Project and import it to my scripts ...
- CentOS 7 安装JDK环境
1.JDK下载地址:https://www.oracle.com/technetwork/java/javase/downloads/java-archive-javase8-2177648.html ...