原题链接:有趣的跳跃
解题思路:
1.标记flag为1
2.输入数字 ,存放在一个数组中
3.进行相邻数相减,并取绝对值,存放在另一个数组中
4.对另一个数组进行从小到大排序
5.判断,如果出现了第i个差的值不等于i的情况,这flag标为0
6.判断,输出
注意事项:
参考代码:
#include<stdio.h>
#include<math.h>
int main()
{
long long int n,i,j,t;
int flag=1;//标记flag为1
scanf("%lld",&n);
int a[n],b[n-1];
for(i=0;i<n;i++)
scanf("%lld",&a[i]);//输入数字,存放在一个数组中
for(i=0;i<n-1;i++)
b[i]=abs(a[i+1]-a[i]);//进行相邻数相减,并取绝对值,存放在另一个数组中
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n-1;j++)
{
if(b[j]<b[i])
{
t=b[i];
b[i]=b[j];
b[j]=t;//对另一个数组进行从小到大排序
}
}
}
for(i=0;i<n-1;i++)//判断
{
if(b[i]!=i+1)
{
flag=0;
break;//如果出现了第i个差的值不等于i的情况,这flag标为0
}
}
if(flag)//判断,输出
printf("Jolly");
else
printf("Not jolly");
return 0;
}0.0分
3 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复