其他分享
首页 > 其他分享> > NOI.6.07有趣的跳跃

NOI.6.07有趣的跳跃

作者:互联网

首先了解一下冒泡排序

        冒泡排序算法,C语言冒泡排序算法详解 

描述

一个长度为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

#include<stdio.h>
#include<math.h>
int main()
{
    int a[3000],b[3000];
    int i,j,n;
    int flag=0,min=0;
    scanf ("%d%d",&n,&a[0]);
    if(n==1)
    {
        printf("Jolly");
        return 0;
    }
    for(i=1; i<n; i++)
    {
        scanf("%d",&a[i]);
        b[i-1]=abs(a[i]-a[i-1]);    //得到两个相邻的数的差的绝对值

    }
    for (i=0; i<n-1; i++)
    {
        for(j=1; j<n-1; j++)
        {
            if(b[j]<b[j-1])    //对所得到的数据进行从小到大排序,采用冒泡排序法
            {
                min=b[j];
                b[j]=b[j-1];
                b[j-1]=min;

            }
        }

    }
    for(i=1; i<n-1; i++)
    {
        if(b[i]-b[i-1]==1)    //确保相邻两个数之差为一
            flag++;
        else
            break;
    }

    if(flag==n-2&&b[0]==1)
        //要注意是n-2并且确保相邻元素的差的绝对值经过排序后正好是从1到(n-1)
        printf("Jolly");
    else
        printf("Not jolly");
    return 0;
}

标签:07,NOI.6,int,冒泡排序,Jolly,序列,跳跃,有趣
来源: https://blog.csdn.net/m0_62300761/article/details/121063940