有趣的跳跃

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

 

#include<stdio.h>
#include <math.h>
int main()
{
int n,a[3000],b[3000],i,k,j,d=1,s=0;
scanf("%d",&n);
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-2;i++){//由小到大排序
for(j=i+1;j<=n-2;j++){
if(b[i]>b[j]) {
k=b[i];
b[i]=b[j];
b[j]=k;
}
}
} /*验证printf(" %d %d ",i,j);
for(i=0;i<n-1;i++){
printf("%d",b[i]);
}*/
for(i=0;i<n-1;i++){//依次验证
if(b[i]!=d){
s=1;break;
}d++;
}
if(s==0) printf("Jolly");
else printf("Not jolly");
return 0;
}

上一篇:数据结构基础


下一篇:股价浮动范围 - Box Pattern - Indexed Tree