描述
一个长度为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>
#define max 3001 //定义一个最大值;
int main()
{
int n,i,j,k;
int a[max],b[max];
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] = abs(a[i]-a[i+1]);
}
for(i=0;i<n-1;i++) //选择法排序;
{ //将最小的置于前端
for(j=i;j<n-1;j++)
{
if(b[i] > b[j])
{
k = b[i];
b[i] = b[j];
b[j] = k;
}
}
}
for(i=0;i<n-2;i++) //判断数组是否为公差为1的等差数列
{
if(b[i+1]-b[i]==1)
continue;
else break; //只要有一个不是就退出;
}
if(i == n-2) //上面循环执行到最后一步;
printf("Jolly");
else printf("Not jolly");
return 0;
}
谢谢浏览!