其他分享
首页 > 其他分享> > ?Good Bye 2019 B. Interesting Subarray

?Good Bye 2019 B. Interesting Subarray

作者:互联网

https://codeforces.com/contest/1270/problem/B

思路:由样例发现公差为1的等差数列不满足条件

           对于∀的l,r   max(a)-min(a)=|r-l|<r-l+1

           由此想到若任意相邻两项差的绝对值为1 则不满足条件

           反过来若存在相邻两项差的绝对值大于1 这两项组成的子串就满足条件

           只要改变任意相邻两项差的绝对值为1的序列中的某一项,使得不满足任意相邻两项差的绝对值为1 就必存在字串满足条件

官方:不失一般性 max>min?

 

 

 总共max-(min+1)+1=max-min项 故至少有一项大于等于2

 

 

 

#include<bits/stdc++.h>
#define ll long long
using namespace std;
const int N=2e5+5 ;
int a[N];
int main(){
    int T;
    ios::sync_with_stdio(false);cin.tie(0);
    cin>>T;
    while(T--){
        int n,flag1=0,flag2=0,pos1=0,pos2=0,flag=0;
        cin>>n;
        for(int i=1;i<=n;i++) cin>>a[i];
    /*    for(int i=2;i<=n;i++)
        if(a[i]!=a[i-1]+1){flag1=1;pos1=i;break;}
            for(int i=2;i<=n;i++)
        if(a[i]!=a[i-1]-1){flag2=1;pos2=i;break;
        }*/
        for(int i=2;i<=n;i++){
            if(abs(a[i]-a[i-1])>=2){cout<<"YES"<<endl;cout<<i-1<<' '<<i<<endl;flag=1;break;
            }
        }
    //    cout<<pos1<<' '<<pos2<<endl;
        if(!flag)cout<<"NO"<<endl;
    /*    else {
            cout<<"YES"<<endl;
            for(int i=1;i<n;i++){
                if(flag) break;
                int m1=a[i],m2=a[i];
            for(int j=i+1;i<=n;i++){
                m1=min(m1,a[j]);m2=max(m2,a[j]);
                if(m2-m1>=j-i+1){
                    cout<<i<<' '<<j<<endl;flag=1;break;
                }
            }
        }
        /*    int m1=a[pos1],m2=a[pos1];
            for(int i=pos1+1;i<=n;i++){
                m1=min(m1,a[i]);m2=max(m2,a[i]);
                if(m2-m1>=i-pos1+1){
                    cout<<pos1<<' '<<i<<endl;flag=1;break;
                }
            }
            if(!flag){
            
             m1=a[pos2],m2=a[pos2];
            for(int i=pos2+1;i<=n;i++){
                m1=min(m1,a[i]);m2=max(m2,a[i]);
                if(m2-m1>=i-pos2+1){
                    cout<<pos2<<' '<<i<<endl;flag=1;break;
                }
            }
        }
            if(!flag){
            
             m1=a[1],m2=a[1];
            for(int i=2;i<=n;i++){
                m1=min(m1,a[i]);m2=max(m2,a[i]);
                if(m2-m1>i){
                    cout<<1<<' '<<i<<endl;flag=1;break;
                }
            }
            }
            if(!flag){
            
             m1=a[n],m2=a[n];
            for(int i=n-1;i>=1;i--){
                m1=min(m1,a[i]);m2=max(m2,a[i]);
                if(m2-m1>n-i+1){
                    cout<<i<<' '<<n<<endl;flag=1;break;
                }
            }
            }*/
    /*    }*/
          
    
    
        
    }
    return 0;
    
}

标签:满足条件,Good,cout,min,int,Interesting,绝对值,max,Bye
来源: https://www.cnblogs.com/wyh447154317/p/12164383.html