求救c语言高手!!!!!

2024-12-30 02:52:02
推荐回答(2个)
回答1:

//主函数声明了两个子函数fun1,fun2
//fun1初始化排列,即一天抓到的初始的老鼠排列
//fun2使用递归,获得最终活下来的那只老鼠的编号
main()
{int a[10000],n;
void fun1(int a[ ],int n);
int fun2(int a[ ],int n);
scanf("%d\n",&n); //输入一开始抓到的老鼠数目
fun1(a,n); //初始化老鼠排列
fun2(a,n); //吃掉单号的老鼠,返回最后一只老鼠编号
}
void fun1(int a[ ],int n)
{
int i,j=1;
//循环语句赋值,如a[1]=1,a[2]=2,...
/*初始化老鼠排列,数组的下标即为排列顺序,a[1,3,...]将会被吃掉;数组元素的具体数值即为老鼠的具体编号*/
for(i=1;i<=n;i++)
{a[i]=j;j++;}
printf("排列:\n"); //向屏幕输出初始排列
for(i=1;i<=n;i++)
{printf("%d\t",a[i]);}
}

int fun2(int a[ ],int n)
{int i,j,N,b[1000];
N=n/2; //每吃掉一轮,老鼠的数目就会剩n/2
//循环保留双号,即剔除单号老鼠(a[1,3,5,...])
for(i=2,j=1;i<=n,j<=N;i=i+2,j++)
{
b[j]=a[i];
//保留双号老鼠至新数组b[1,2,3...,N]=a[2,4,6...]
}
printf("\n排列:\n");
//向屏幕显示新数组b排列,即吃掉一轮后剩余的老鼠编号
for(j=1;j<=N;j++)
printf("%d\t",b[j]);
//如果新数组b长度N>1,调用fun2自身,即递归
//否则,N<=1,即只剩一只老鼠,输出这最后一只老鼠的编号
if(N>1)
return fun2(b,N);
else
{
printf("\n结果:\n%d",b[N]);
return b[N];
}
}
//递归调用中,fun2(b,N)的第二个参数N会不断减半,直到满足了N<=1,fun2将获得一个返回值,即最后一只老鼠的编号

回答2:

#include
void main()
{
int pos = 1;
int horseCount;

do
{
printf("Please Input The Count of The Horse,Count > 1:");
scanf("%d",&horseCount);
}while(horseCount<=1);

while(((pos = pos<<1)<<1) <= horseCount);

printf("The Position is %d\n",pos);
}

还是我来回答这个问题吧,不管你能不能理解,但是不能否定我这个解决方案的代码精简度和效率,不明白可以问,如果觉得我这个有点水平,把红旗给我就可以了。
其实解决问题的只有下边的While,上边的While只是控制输入的,怕不输入的数字小于1了没意义。
这个问题如果只在看表面不实际分析,上面各位的行行代码你就慢慢分析吧。