题目链接:http://codeforces.com/contest/602/problem/B

题意 :给出一个含有 n 个数的区间,要求找出一个最大的连续子区间使得这个子区间的最大值和最小值的差值不超过 1 ,最后输出这个子区间的长度。

分析 :我们可以根据区间的最值之差利用尺取的方法来找出答案=> if(差值>1) Left++; else Right++; 然后每一次右端点+1就更新一次答案直到右端点到达 n 。在这里我们需要找出区间最值,也就是经典的RMQ问题,可以利用ST算法模板进行O(nlogn)的预处理接下来进行尺取便不会超时。上述的过程完全可以使用multiset来替代,我们可以每一次把(Left, Right)区间内的数放到multiset里面,根据set容器的特性,我们能很方便得到(Left, Right)这个区间的最值,也能使用erase()在区间不满足题意进行Left++操作时将原来Left的元素在集合内剔除,也能用size()方便的得到区间的长度,但是两者都用到了尺取的思想。

瞎想 :当需要维护区间的时候需要获取最值或者获取区间长度的时候,不妨考虑能否借助set容器来实现。

Two pointers && RMQ :

#include<bits/stdc++.h>
#define LL long long
using namespace std;
;
], Min[maxn][];
inline void initialize(int & n)
{
    ; i<=n; i++) Max[i][] = arr[i], Min[i][] = arr[i];
    ; j<; j++){
        ; i<=n; i++){
            <<j) -  <= n){
                Min[i][j] = min(Min[i][j-], Min[i+(<<(j-))][j-]);
                Max[i][j] = max(Max[i][j-], Max[i+(<<(j-))][j-]);
            }
        }
    }
}
int RMQ(int L, int R)
{
    ;
    //while((1<<(k+1)) <= R-L+1) k++;
    k = log2(R-L+);
    <<k)+][k]);
    <<k)+][k]);
    return MAX - MIN;
}
int main(void)
{
    int n;
    scanf("%d", &n);
    ; i<=n; i++) scanf("%d", &arr[i]);
    initialize(n);
    , R = ;
    ;
    while(R <= n){
        int temp = RMQ(L, R);
        ){
            ans = max(R-L+, ans);
            R++;
        }
        else{
            L++;
        }
    }
    printf("%d\n", ans);
    ;
}

Two pointers && multiset :

#include<bits/stdc++.h>
using namespace std;
;
int arr[maxn];
int main(void)
{
    int n;
    scanf("%d", &n);
    ; i<=n; i++) scanf("%d", &arr[i]);
    multiset<int> s;
    s.insert(arr[]);
    ];
    ];
    , ed = ;//双指针记录Left 和 Right
    ;
    ; i<=n; i++){
        Max = max(Max, arr[i]);
        Min = min(Min, arr[i]);
        s.insert(arr[i]);
        ){
            ans = max(ans, (int)s.size());
        }else{
             && Max - Min > ){//相当于Left++操作
                set<int>::iterator it = s.find(arr[st]);
                s.erase(it);
                st++;
                set<int>::iterator it_Max = --s.end();
                set<int>::iterator it_Min = s.begin();
                Max = *it_Max;
                Min = *it_Min;
            }
            ans = max(ans, (int)s.size());
        }
    }
    printf("%d\n", ans);
    ;
}

#333 Div2 Problem B Approximating a Constant Range (尺取 && RMQ || 尺取 && multiset)的更多相关文章

  1. #333 Div2 Problem B Approximating a Constant Range(尺取法)

    题目:http://codeforces.com/contest/602/problem/B 题意 :给出一个含有 n 个数的区间,要求找出一个最大的连续子区间使得这个子区间的最大值和最小值的差值不超 ...

  2. Codeforces Round #333 (Div. 2) B. Approximating a Constant Range st 二分

    B. Approximating a Constant Range Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com ...

  3. Codeforces Round #333 (Div. 2) B. Approximating a Constant Range

    B. Approximating a Constant Range Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com ...

  4. Codeforces 602B Approximating a Constant Range(想法题)

    B. Approximating a Constant Range When Xellos was doing a practice course in university, he once had ...

  5. FZU 2016 summer train I. Approximating a Constant Range 单调队列

    题目链接: 题目 I. Approximating a Constant Range time limit per test:2 seconds memory limit per test:256 m ...

  6. cf602B Approximating a Constant Range

    B. Approximating a Constant Range time limit per test 2 seconds memory limit per test 256 megabytes ...

  7. codeforce -602B Approximating a Constant Range(暴力)

    B. Approximating a Constant Range time limit per test 2 seconds memory limit per test 256 megabytes ...

  8. 【32.22%】【codeforces 602B】Approximating a Constant Range

    time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...

  9. 【CodeForces 602C】H - Approximating a Constant Range(dijk)

    Description through n) and m bidirectional railways. There is also an absurdly simple road network — ...

随机推荐

  1. Linux下用Java获取本机IP

    可能有多个网卡包括虚拟网卡,需要进行排除 String ip = ""; try { Enumeration<?> e1 = NetworkInterface.getN ...

  2. C语言课程程序设计

    项目名称和目标 项目为基于EasyX库的RPG游戏,目标能实现控制游戏主角自由移动,能与NPC对话交互. 我组目前还未确定具体项目名称 项目主体功能 项目的主体功能具有一个游戏所拥有的完整功能,包括但 ...

  3. 使用注解方式搭建SpringMVC

    1.以前搭建Spring MVC 框架一般都使用配置文件的方式进行,相对比较繁琐.spring 提供了使用注解方式搭建Spring MVC 框架的方式,方便简洁.使用Spring IOC 作为根容器管 ...

  4. Mybatis(二) SQL映射文件

    SQL映射文件 单条件查询 1. 在UserMapper接口添加抽象方法 //根据用户名模糊查询 List<User> getUserListByName(); 2. 在UserMappe ...

  5. Spark RDD理解-总结

    1.spark是什么 快速.通用.可扩展的分布式计算引擎. 2. 弹性分布式数据集RDD RDD(Resilient Distributed Dataset),是Spark中最基本的数据抽象结构,表示 ...

  6. appium+python自动化项目实战(二):项目工程结构

    废话不多说,直接上图: nose.cfg配置文件里,可以指定执行的测试用例.生成测试报告等.以后将详细介绍.

  7. 微信小程序里多出来的奇怪宽度

    最近在看微信小程序相关的东西,写页面的时候,因为一直以Iphone6作为标准调试(微信官方建议以Iphone6调试),下面以实际的案例讲解以rpx会引发的问题 wxml: <view class ...

  8. 移动端 h5 适配之必知必会

    建议大家先去看看这篇文章 https://juejin.im/post/5cddf289f265da038f77696c?utm_source=gold_browser_extension(来自掘金: ...

  9. 10个用Java谋生非常有趣的方式

    令我惊讶的是,有些人觉得编程并不令人兴奋——只将它当作是一份枯燥的工作.不过,虽然可能的确有很多无聊的编程工作,但这并不意味着你不得不接受这些工作中的一个.程序员有各种各样的机会,运用他们的技能去做一 ...

  10. centos python environment

    3. 在Centos7的docker里装好了httpd,运行报错: $ systemctl start httpd.service Failed to get D-Bus connection: Op ...