美文网首页
CUC-SUMMER-CONTEST-1-F

CUC-SUMMER-CONTEST-1-F

作者: Nioge | 来源:发表于2017-08-08 19:38 被阅读0次
    F - Unimodal Array
    CodeForces - 831A

    Array of integers is unimodal, if:

    it is strictly increasing in the beginning;
    after that it is constant;
    after that it is strictly decreasing.
    The first block (increasing) and the last block (decreasing) may be absent. It is allowed that both of this blocks are absent.

    For example, the following three arrays are unimodal: [5, 7, 11, 11, 2, 1], [4, 4, 2], [7], but the following three are not unimodal: [5, 5, 6, 6, 1], [1, 2, 1, 2], [4, 5, 5, 6].

    Write a program that checks if an array is unimodal.

    Input
    The first line contains integer n (1 ≤ n ≤ 100) — the number of elements in the array.

    The second line contains n integers a1, a2, ..., an (1 ≤ ai ≤ 1 000) — the elements of the array.

    Output
    Print "YES" if the given array is unimodal. Otherwise, print "NO".

    You can output each letter in any case (upper or lower).

    Example

    Input
    6
    1 5 5 5 4 2
    Output
    YES

    Input
    5
    10 20 30 20 10
    Output
    YES

    Input
    4
    1 2 1 2
    Output
    NO

    Input
    7
    3 3 3 3 3 3 3
    Output
    YES

    Note
    In the first example the array is unimodal, because it is strictly increasing in the beginning (from position 1 to position 2, inclusively), that it is constant (from position 2 to position 4, inclusively) and then it is strictly decreasing (from position 4 to position 6, inclusively).


    题意:如果一个序列,开始是递增然后不变然后递减,则输出yes,否则输出no

    解法:用三个bool类型来表示现在是递增不变还是递减的状态。然后遍历序列,看每个数是否符合现在的状态。

    代码:

    #include<iostream>
    using namespace std;
    int a[105];
    int main()
    {
        int n;
        while(cin>>n){
        for(int i=0;i<n;i++)
            cin>>a[i];
        int incs=1,decs=0,eq=0,flag=1;
        for(int i=1;i<n;i++){
            if(a[i]>a[i-1]){
                if(decs==1||eq==1){
                    flag=0;
                    break;
                }
            }
            if(a[i]==a[i-1]){
                if(decs==1){
                    flag=0;
                    break;
                }
                if(eq==0)
                    eq=1;
            }
            if(a[i]<a[i-1]){
                if(decs==0){
                    decs=1;
                }
            }
        }
        if(flag==1)
            cout<<"Yes"<<endl;
        else
            cout<<"No"<<endl;
        }
    
    }
    

    相关文章

      网友评论

          本文标题:CUC-SUMMER-CONTEST-1-F

          本文链接:https://www.haomeiwen.com/subject/clrxrxtx.html