请各位老师进来瞧个小问题!
我才接触C语言,在做c语言经典100例的时候 碰到一个题目。我没看的太懂意思!请大家帮我指正下思路闭塞的地方。也许是你们一看都会笑死的题目,但是真的恳请大家多多指点!
题目:有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数
#include<stdio.h>
main()
{
int number[20],n,m,i;
printf("the total numbers is:");
scanf("%d",&n);
printf("back m:");
scanf("%d",&m);
for(i=0;i<n-1;i++)
scanf("%d,",&number[i]);
scanf("%d",&number[n-1]);
move(number,n,m);
for(i=0;i<n-1;i++)
printf("%d,",number[i]);
printf("%d",number[n-1]);
}
move(array,n,m)
int n,m,array[20];
{
int *p,array_end;
array_end=*(array+n-1);
for(p=array+n-1;p>array;p--)
*p=*(p-1);
*array=array_end;
m--;
if(m>0) move(array,n,m);
}
我这里大概的思路能看懂,但是move(array,n,m)这个是个什么函数啊?我这段没看的太懂。
move(array,n,m)
int n,m,array[20];
{
int *p,array_end;
array_end=*(array+n-1);
for(p=array+n-1;p>array;p--)
*p=*(p-1);
*array=array_end;
m--;
if(m>0) move(array,n,m);
}
整个这断也许是因为我对move(array,n,m) 这个不理解,所以我看的很不理解。
希望你们帮我做个稍微的解释行嘛? 真的是初学者,希望不要见笑 :)~~~