解题思路:
注意事项:
参考代码:
#include<stdio.h>
int main()
{
int a[51],b[49],k,flag,i,n,count,temp;
while(scanf("%d",&n)!=EOF)
{
temp=n;
count=n;
i=1;
while(i<=n)
{
a[i]=i;
i++;
}
k=0;
while(count!=2)
{
flag=0;n=count;
for(i=1;;i++)
{
if(a[i]!=0)
{
flag++;
if(flag==2)
{
b[k++]=a[i];
flag=0;
a[i]=0;
count--;
}
}
if(count==2)break;
if(count==(n-n/2))break;
}
}
for(i=0;i<temp-2;i++)
{
printf("%d",b[i]);
if(i!=temp-3)printf(" ");
}
printf("\n%d ",a[1]);
for(i=3;i<=temp;i++)
if(a[i]!=0){printf("%d\n",a[i]);break;}
}
return 0;
}
0.0分
0 人评分
C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:
一点编程也不会写的:零基础C语言学练课程
解决困扰你多年的C语言疑难杂症特性的C语言进阶课程
从零到写出一个爬虫的Python编程课程
只会语法写不出代码?手把手带你写100个编程真题的编程百练课程
信息学奥赛或C++选手的 必学C++课程
蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程
手把手讲解近五年真题的蓝桥杯辅导课程
发表评论 取消回复