士兵

有简单方法 但是我懒得写了 可以只定义一个变量
题目
4357建立了好多好多个兵团,一共X个,编号从1 到 X ,每个兵团的内部又按照各个兵团的人数从一开始编号,
每个兵团的人数跟该兵团的编号相同
第一个兵团的内部只有一个士兵编号一号
第二个兵团的内部只有两个士兵编号一号,二号

第X个兵团的内部有X个士兵编号一号,二号…X号
现在将兵团按照升序排列,兵团内部按照降序排列,排成一排,那么第Z个位置是哪个兵团的几号士兵
输入
多组输入
第一行有两个数字 X Z(1<= X <= 10000 )
样例输入
5 2
样例输出
2 2
#include<stdio.h>
int main()
{
int i,j,s,x,z;
while(~scanf("%d %d",&x,&z))
{int a[x+1];
s=1;
for(i=1; i<=x; i++)
for(j=i,s=s; j<=i&&j>=1; j–,s++)
{
a[j]=s;
if(a[j]==z)
printf("%d %d\n",i,j);
}
}
return 0;
}

猜你喜欢

转载自blog.csdn.net/weixin_43589396/article/details/83661379