您的位置:首页 > 其它

有趣的跳跃

2018-01-31 18:32 891 查看
描述

一个长度为n(n>0)的序列中存在“有趣的跳跃”当前仅当相邻元素的差的绝对值经过排序后正好是从1到(n-1)。

例如,1 4 2 3存在“有趣的跳跃”,因为差的绝对值分别为3,2,1。当然,任何只包含单个元素的序列

一定存在“有趣的跳跃”。你需要写一个程序判定给定序列是否存在“有趣的跳跃”。

输入

一行,第一个数是n(0 < n < 3000),为序列长度,接下来有n个整数,依次为序列中各元素,

各元素的绝对值均不超过1,000,000,000。

输出

一行,若该序列存在“有趣的跳跃”,输出"Jolly",否则输出"Not jolly"。

样例输入

4 1 4 2 3

样例输出

Jolly

思路:将两个相邻的数相减取绝对值,再将得到的数进行排序,排序后在检查相邻的两数之间的差是否为零,如果为零,则继续,若不为零,则停止循环,判断i的值,if(i==n-1)则输出Jolly,否则则输出Not jolly。当然,当输入的n==1时,也应当输出Jolly。

#include <stdio.h>

#include <math.h>

int main()

{

    int n,i,j,a[3005],b[3005],temp;

    scanf("%d",&n);

    if(n==1)

    {

        printf("Jolly");

        return 0;

    }

    for(i=0;i<n;i++)

        scanf("%d",&a[i]);

    for(i=0;i<n-1;i++)

        b[i]=fabs(a[i]-a[i+1]);

    for(i=0;i<n-1;i++)

    {

        for(j=i;j<n-1;j++)

        {

            if(b[i]>b[j])

            {

                temp=b[i];

                b[i]=b[j];

                b[j]=temp;

            }

        }

    }

    for(i=0;i<n-2;i++)

    {

        if(b[i+1]-b[i]==1)

            continue;

        else break;

    }

    if(i==n-2)printf("Jolly");

    else printf("Not jolly");

    return 0;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  简单题