【链接】 我是链接,点我呀:)

【题意】

在这里输入题意

【题解】

枚举N[q]和N[r]的位置
因为N[q]是最大值,且N[r]是最小值。
且它们是中间的两个。
枚举这两个可以做到不重复枚举。

然后假设我们枚举了q和r的位置分别为i和j

(a[i]>a[j]

那么我们接下来需要得到两个东西。

1.在j的右边找到一个尽可能大的且小于a[i]的数字dp[0][i][j];

2.在i的左边找到一个尽可能小且大于a[j]的数字dp[1][i][j]。

然后判断一下dp[0][i][j]> a[j] && dp[1][i][j]< a[i] && dp[0][i][j] > dp[1][i][j]

是否成立就好

还要考虑a[i]<a[j]的情况(有两种情况之一成立都是弱键。

方便起见。

直接把原数组翻转一下。

就会发现用上面说的思路重新做一遍就可以了。

dp[0..1][i][j]这两个数组可以用一个set.在\(O(N^2*log_2N)\)的复杂度下得到。

【代码】

/*
dp1[i][j] 表示 j右边 大于a[j]且小于a[i]的
最大数字
->小于a[i]的最大数字 dp2[i][j] 表示i左边 大于a[j]且最小的数字 for (int j = n;j >= 1;j--){ }
*/
#include <bits/stdc++.h>
#define ll long long
#define rep1(i,a,b) for (int i = a;i <= b;i++)
#define rep2(i,a,b) for (int i = a;i >= b;i--)
#define all(x) x.begin(),x.end()
#define pb push_back
#define ls l,mid,rt<<1
#define rs mid+1,r,rt<<1
using namespace std; const double pi = acos(-1);
const int dx[4] = {0,0,1,-1};
const int dy[4] = {1,-1,0,0};
const int N = 5e3; set<int> myset;
int n,a[N+10],dp[2][N+10][N+10]; bool solve(){
myset.clear();
rep2(j,n,1){
rep2(i,j-1,1)
if (a[i]>a[j]){
auto temp = myset.upper_bound(a[i]);
if (temp==myset.begin()) {
dp[0][i][j] = 0;
continue;
}
temp--;
dp[0][i][j] = (*temp);
}
myset.insert(a[j]);
}
myset.clear();
rep1(i,1,n){
rep1(j,i+1,n)
if (a[i]>a[j]){
auto temp = myset.upper_bound(a[j]);
if (temp==myset.end()) {
dp[1][i][j] = 0;
continue;
}
dp[1][i][j] = (*temp);
}
myset.insert(a[i]);
}
rep1(i,1,n)
rep1(j,i+1,n)
if (a[i]>a[j]){
if (dp[0][i][j]==0 || dp[1][i][j]==0) continue;
if (dp[0][i][j]>a[j] && dp[1][i][j]<a[i] &&
dp[0][i][j]>dp[1][i][j]){
return true;
}
}
return false;
} int main(){
#ifdef LOCAL_DEFINE
freopen("rush_in.txt", "r", stdin);
#endif
ios::sync_with_stdio(0),cin.tie(0);
int T;
cin >> T;
while (T--){
cin >> n;
rep1(i,1,n) cin >> a[i];
if (solve()){
cout<<"YES"<<endl;
continue;
}
reverse(a+1,a+1+n);
if (solve()){
cout<<"YES"<<endl;
continue;
}
cout<<"NO"<<endl;
}
return 0;
}

【习题 8-16 UVA - 1618】Weak Key的更多相关文章

  1. UVa - 1618 - Weak Key

    Cheolsoo is a cryptographer in ICPC(International Cryptographic Program Company). Recently, Cheolsoo ...

  2. UVA - 1618 Weak Key(RMQ算法)

    题目: 给出k个互不相同的证书组成的序列Ni,判断是否存在4个证书Np.Nq.Nr.Ns(1≤p<q<r<s≤k)使得Nq>Ns>Np>Nr或者Nq<Ns&l ...

  3. 紫书 习题 8-16 UVa 1618 (中途相遇法)

    暴力n的四次方, 然而可以用中途相遇法的思想, 分左边两个数和右边两个数来判断, 最后合起来判断. 一边是n平方logn, 合起来是n平方logn(枚举n平方, 二分logn) (1)两种比较方式是相 ...

  4. Java50道经典习题-程序16 在控制台上打印九九乘法表

    题目:输出9*9口诀.分析:利用双重for循环进行输出,分行与列考虑,共9行9列,i控制行,j控制列. public class Prog16 { public static void main(St ...

  5. 弱键(Weak Key, ACM/ICPC Seoul 2004, UVa1618)

    I think: 给出k(4≤k≤5000)个互不相同的整数组成的序列Ni,判断是否存在4个整数Np.Nq.Nr和Ns(1≤p<q<r<s≤k),使得Nq>Ns>Np&g ...

  6. shell习题第16题:查用户

    [题目要求] 写个shell,看看你的Linux系统中是否有自定义的用户(普通用户),如有有的话统计个数 [核心要点] CentOS6,uid>=500 CentOS7,uid>=1000 ...

  7. UVA1618-Weak Key(RMQ)

    Problem UVA1618-Weak Key Accept: 103  Submit: 588Time Limit: 3000 mSec Problem Description Cheolsoo ...

  8. MySQL完整性约束foreign key与表操作。

    一  MySQL中表的完整性约束: 我们首先知道约束条件跟类型的宽度一样,都是可选的,也就是说,我们在创建表的时候可以不指定,但是为了创建的表更加的完整,我们一般会加一些约束条件,name下面我们讲一 ...

  9. C++primer习题--第1章

    本文地址:http://www.cnblogs.com/archimedes/p/cpp-primer-chapter1-ans.html,转载请注明源地址. [习题 1.3] 编一个程序,在标准输出 ...

随机推荐

  1. Struts1、Struts2、Hibernate、Spring框架工作原理介绍

    Struts1工作原理 Struts1工作原理图 1.初始化:struts框架的总控制器ActionServlet是一个Servlet,它在web.xml中配置成自动启动的Servlet,在启动时总控 ...

  2. win10关闭更新

    计算机--管理: 找到windows update 服务关闭:

  3. KVO VS isa : KVO 建立在 KVC 之上

    Key-Value Observing (KVO) 建立在 KVC 之上,它通过重写 KVC 和监听 setter 方法,向外发送通知. https://blog.csdn.net/y55091811 ...

  4. 前端换行显示,后端返回<br>

  5. luogu 4844 LJJ爱数数 (莫比乌斯反演+数学推导)

    题目大意:求满足gcd(a,b,c)==1,1/a+1/b=1/c,a,b,c<=n的{a,b,c}有序三元组个数 因为题目里有LJJ我才做的这道题 出题人官方题解https://www.cnb ...

  6. Eclipse配置class文件输出目录

    1, Eclipse选中项目名称,邮件选中“Build Path”,然后选择“Configure Build Path”--->选择“Source” Tab---->修改"Def ...

  7. Object-C,NSSet,不可变集合

    又到晚上了,继续码代码. 正在此时,老爸一个电话"海阔凭鱼跃,天高任鸟飞",老爸不在为老问题烦我了. 自由了,突然感觉压力好大啊. 将来混的太惨,可咋办啊- 第1个例子是,不可变集 ...

  8. Python seed() 函数--每次产生一样的随机数系列

    import random random.seed( 10 ) print("Random number with seed 10 : ", random.random()) #0 ...

  9. 【codeforces 335A】Banana

    [题目链接]:http://codeforces.com/contest/335/problem/A [题意] 让你构造一个长度为n的字符串; 每次你可以从这个字符串中任意取走字符; 让你求出取的次数 ...

  10. 北京联通光猫WO-36(HG220GS-U)改为桥接模式

    家里弄了个极路由,想在公司里去操作路由器,交换文件.提前下载电影什么的,因此需要光猫改为桥接模式,让路由器拨号 由于WO-36(HG220GS-U)这个型号的光猫固件升级后(我的是3.x)不能用工程账 ...