有趣的跳跃
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;
}
一个长度为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;
}
相关文章推荐
- AC日记——有趣的跳跃 openjudge 1.6 07
- 有趣的跳跃
- 07_有趣的跳跃
- 1-6-07:有趣的跳跃
- 有趣的跳跃
- 07:有趣的跳跃
- 有趣的算法问题12——跳跃游戏1(贪心算法)
- noi-1577-有趣的跳跃
- 07:有趣的跳跃
- 前几天遇到一道有趣的题目 一座楼有10层,兔子可以跳跃的层数可以为1,2或者3,那么兔子到达10层有多少种跳法并列出各种情况。
- 人物控制,沿墙滑动跳跃的实现
- 一个与小球碰撞有关的有趣问题
- 从许霖案和soff案中发现的有趣问题
- 【题】【数学(卡特兰数)】NKOJ3798 有趣的数列
- 有趣Logo图片: TuxMachines
- 通过一个有趣的例子说明线程的工作机制
- 有趣Logo图片: tux-pcbypaul和tux-ondolphin
- bzoj1485:[HNOI2009]有趣的数列
- moto List一个有趣的问题
- Java学习(让我记录下这有趣的故事:2016/10/14)