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 ...
随机推荐
- Maven安装与配置及使用
下载及安装 官方下载地址:直达官网下载页面 进入下载页面后,根据你电脑所装jdk版本选择对应版本的maven进行下载. 我们可以看到该页上边红框内写明了,maven3.3版以上支持的是JDK1.7+的 ...
- Android:双击退出应用的实现
1 需求效果 为了防止用户点击返回键就直接退出APP,通常会加入一个双击退出的要求. 如果用户在两秒之内重复点击了返回键,则执行退出操作:如果用户点击了一次返回键之后,超过两秒未再次点击,则不响应退出 ...
- Codeforces 446C DZY Loves Fibonacci Numbers [线段树,数论]
洛谷 Codeforces 思路 这题知道结论就是水题,不知道就是神仙题-- 斐波那契数有这样一个性质:\(f_{n+m}=f_{n+1}f_m+f_{n}f_{m-1}\). 至于怎么证明嘛-- 即 ...
- Linux下Oracle 12c的卸载
注:本文来源于:<Linux下Oracle 12c的卸载> 与Windows下Oracle的安装容易卸载麻烦相反,Linux下Oracle的安装麻烦下载简单. 1.关闭Oracle数据库 ...
- Confluence 6 "Duplicate Key" 相关问题解决
如果你遇到了下面的错误信息,例如: could not insert: [bucket.user.propertyset.BucketPropertySetItem#bucket.user.prope ...
- Confluence 6 配置 workbox 通知
你可以在你的 Confluence workbox 中查看和管理应用内的通知和任务.更多的,你可以在 Confluence workbox 中从接收到从 JIRA 和其他 Confluence 服务器 ...
- nginx(一)之默认配置文件
首先是nginx.conf vim /etc/nginx/nginx.conf user nginx; // 设置nginx服务的系统使用用户 worker_processes 1; // 工作进程数 ...
- clock gen sdk 代码笔记
int ClockConfig(void) { u32 DIVCLK_DIVIDE = 10; u32 CLKFBOUT_MULT = 53; u32 CLKFBOUT_FRAC = 625; u32 ...
- 【scapy】读取pcap
scapy读取pcap包 假设有pcap包test.pcap,读取其中的分层流量信息 代码: import scapy_http.http try: import scapy.all as scapy ...
- linux 源码安装PHP
解压: 解压完: configure: configure成功: make: make完成: 安装完成!!! 测试: 需要./bin/php来运行php 想要任何目录输入PHP就能使用php 方法一: ...