A sequence of n > 0 integers is called a jolly jumper if the absolute values of the difference between successive elements take on all the values 1 through n-1. For instance,
1 4 2 3
is a jolly jumper, because the absolutes differences are 3, 2, and 1 respectively. The definition implies that any sequence of a single integer is a jolly jumper. You are to write a program to determine whether or not each of a number of sequences is a jolly jumper.
Each line of input contains an integer n < 3000 followed by n integers representing the sequence. For each line of input, generate a line of output saying "Jolly" or "Not jolly".
Input
Output
Sample Input
Sample Output
#include<iostream>
#include<cstring>
#include<string>
#include<cstdio>
#include<vector>
#include<algorithm>
using namespace std;
int f[10010];
int main()
{
int t,a,flag,b,i,c;
while(~scanf("%d",&t))
{
flag=0;
memset(f,0,sizeof(f));
scanf("%d",&a);
for(i=0;i<t-1;i++)
{
scanf("%d",&b);
if(abs(a-b)<=t-1&&abs(a-b)>=1)//判断是不是在这个范围内
{
c=abs(a-b);
if(f[c]==0)
f[c]=1;
else
flag=1;//有重复的元素也不行
}
else//不在这个范围内就标记为1
{
flag=1;
}
a=b;
}
for(i=1;i<t-1&&flag==0;i++)/*判断是否在这个区间内都有
并且没有重复的*/
{
if(f[i]==0)
{
flag=1;
break;
}
}
if(flag==0)
{
printf("Jolly\n");
}
else
{
printf("Not jolly\n");
}
}
return 0;
}