• 题解 CF27C 【Unordered Subsequence】


    思路:推理


    首先我们知道,如果一个数列长度 (lenle 2),那么这个数列肯定不是无序的,证明显然。

    题目中要求求最短的序列,那么只要题目有解,我们肯定能找到一个 (len=3) 的无序序列。

    对于这个题,有一种简便方法,就是只枚举 i ,如果这个序列是有解的,那么肯定能找到 (a[1],a[i],a[i+1]) 是无序的情况。

    证明一下:

    1. 如果(a[i]>a[i+1])
      1. 如果(a[1])是三者最大,呈降序,不符合条件,舍去。
      2. 如果(a[1])居中,满足“小大小”无序。
      3. 如果(a[1])是三者最小,同上。
    2. 如果(a[i]<a[i+1])
      1. 如果(a[1])是三者最大,满足“大小大”无序。
      2. 如果(a[1])居中,同上。
      3. 如果(a[1])是三者最小,呈升序,不符合条件,舍去。

    除了这些情况的,一定无解。

    代码奉上:

    #include<iostream>
    #include<cstdio>
    #include<cstring>
    using namespace std;
    const int N=100005;
    int a[N],n;
    int main() {
    	scanf("%d",&n);
    	for(int i=1;i<=n;i++)
    		scanf("%d",&a[i]);
    	for(int i=2;i<n;i++) {//注意越界问题
    		if((a[i+1]>a[i]&&a[i]<a[1])||(a[i+1]<a[i]&&a[i]>a[1])) {
    			printf("3
    1 %d %d
    ",i,i+1);
    			return 0;//找到答案直接输出结束。
    		}
    	}
    	printf("0
    ");//非要无解我莫得办法
    	return 0;
    }
    
  • 相关阅读:
    边界值分析
    等价类划分
    手工检测SQL注入(安全性测试)
    Web安全性测试
    Jmeter使用流程及简单分析监控
    使用可视化工具redisclient连接redis
    Java ThreadLocal的使用
    jvm中的新生代Eden和survivor区
    策略模式和工厂模式的区别
    java将一数组乱序排列
  • 原文地址:https://www.cnblogs.com/ahawzlc/p/13429475.html
Copyright © 2020-2023  润新知