解题思路:
如果人数为偶数i个,可以化归为两个i/2的人只能单向换顺序,我们已知将a个人排成长队逆序需要(a-1)*a/2次,所以共需要(i/2-1)*(i/2)次;
如果人数为奇数i个,化归为i-1个人排完之后再将最后一个人移位,((i-1)/2-1)*((i-1)/2)+(i-1)/2;
图例:
偶数个以6个为例:
|
6 | 1
5 | 2
4 | 3
|
从中间分开,将两侧分别看做排成长队之后的结果,则 1 2 3变为3 2 1需要(3-1)*3/2次,共需要(3-1)*3次
奇数以七个为例:
1
|
7 | 2
6 | 3
5 | 4
|
对下面几个操作完之后结果为:
1
|
5 | 4
6 | 3
7 | 2
|
再经过(7-1)/2次将1移到最下面即可
|
5 | 4
6 | 3
7 | 2
|
1
注意事项:
参考代码:
注:a[i]表示i+1个人换位置的时间
#include<stdio.h>
int main(void)
{
int i;
int n;
int m;
int a[32767]={0};
a[0]=0;
a[1]=0;
a[2]=1;
for(i=3;i<32767;i++)
{
if(i%2)
{
a[i]=((i+1)/2-1)*((i+1)/2);
}
else
{
a[i]=i*i/4;
}
}
scanf("%d",&n);
{
for(i=0;i<n;i++)
{
scanf("%d",&m);
printf("%d\n",a[m-1]);
}
}
return 0;
}
0.0分
2 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复