原文链接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逆问题 其他的更多相关文章

  1. 51nod 1336 RMQ逆问题

    RMQ问题是一类区间最值问题,这里给出一个特殊的RMQ问题,初始给定一个n长的排列P,注:n长排列是指有1~n这n个整数构成的一个序列每个整数恰好出现一次.并对这个排列P进行M次查询操作,每次查询形如 ...

  2. BZOJ 3489: A simple rmq problem

    3489: A simple rmq problem Time Limit: 40 Sec  Memory Limit: 600 MBSubmit: 1594  Solved: 520[Submit] ...

  3. UVA 11235Frequent values(RMQ)

    训练指南P198 题意:给出一个非降序排列的整数数组a1, a2…… an,你的任务是对于一系列询问(i,j),回答ai, ai+1 ……aj 中出现的次数最多的次数 这题不仅学到了rmq的应用还学到 ...

  4. 51nod1174(RMQ)

    题目链接:https://www.51nod.com/onlineJudge/questionCode.html#!problemId=1174 题意:中文题诶- 思路:RMQ模板题 关于RMQ: h ...

  5. 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 ...

  6. 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 ...

  7. (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[ ...

  8. 洛谷P2412 查单词 [trie树 RMQ]

    题目背景 滚粗了的HansBug在收拾旧英语书,然而他发现了什么奇妙的东西. 题目描述 udp2.T3如果遇到相同的字符串,输出后面的 蒟蒻HansBug在一本英语书里面找到了一个单词表,包含N个单词 ...

  9. POJ3368Frequent values[RMQ 游程编码]

    Frequent values Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 17581   Accepted: 6346 ...

随机推荐

  1. 3-html 缩写-地址-文字方向-引用块-题注的格式

    HTML Quotation and Citation Elements Tag Description <abbr> Defines an abbreviation or acronym ...

  2. jquery日常使用总结

    1.如何跳出each循环 用 return false, 不是 break. $.each(resArray, function(j, n) { if (1 == n) { return false; ...

  3. Django 配置(一)开启服务

    注:这里使用的是命令行创建,当然也可以用 pycharm 自带的 django 项目创建更加简便. 安装django pip install django 创建项目 django-admin star ...

  4. 监听本机tcp和udp的端口

    #!/bin/bash #tcp part port1=`netstat -an|grep LISTEN|egrep "0.0.0.0|:::"|awk '/^tcp/ {prin ...

  5. Bootstrap 固定底部导航栏菜单

    直接上代码: <!DOCTYPE html> <html> <head> <meta http-equiv="content-type" ...

  6. 20)django-session使用

    一:目录 1)session原理 2)cookie与session对比 3)session配置 4)session使用 5)示例 二:session原理 Django的Session机制会向请求的浏览 ...

  7. httprouter与 fasthttp 的性能对比

    关于协议: 本打算接入层使用gRPC,虽然基于HTTP 2.0 效率比较高,而且使用protobuf 能进行高效的序列化.但是本次系统需要和 JAVA进行对接,考虑到gRPC对JAVA的支持性不是很好 ...

  8. 关于如何实现Android透明状态栏的总结

    开门见山. 原来做的效果,如下图(顶部有一条明显的橙色状态栏):   a1.gif 改过之后(顶部状态栏是透明的):   p2.gif 我发现网上写的一些文章,不够简洁明了,我整理了一下,复制粘贴一下 ...

  9. c# 操作Word总结(车)

    在医疗管理系统中为保存患者的体检和治疗记录,方便以后的医生或其他人查看.当把数据保存到数据库中,需要新建很多的字段,而且操作很繁琐,于是想到网页的信息创建到一个word文本中,在显示的时,可以在线打开 ...

  10. centos 7.3 设置静态IP

    注:本文来源:张亮博客  的 <centos 7.3 设置静态IP或ping 报name or service not known> 首先把虚拟机配置为桥接模式,然后开启再你打算修改虚拟机 ...