题目:有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数。写一函数:实现以上功能,在主函数中输入n个数和输出调整后的n个数。
我的代码:
#include
void fun(int a[])
{
int num[100];
int i,n,m;
int* p = &n;
int* q = &m;
for (i = *p+*q-1; i >=0; i--)
{
num[i ] = num[i-*q];
}
for (i = *p - 1; i < *p + *q; i++)
{
num[i - *p + 1] = num[i];
}
}
int main()
{
int n, m;
scanf_s("%d %d", &n, &m);
int num[100];
for (int i = 0; i < n; i++)
{
scanf_s("%d", &num[i]);
}
fun(num);
for (int i = 0; i < n; i++)
{
printf("%d ", num[i]);
}
return 0;
}
fun函数中的num数组,和main函数中的num数组不是一个数组对象啊,你修改函数中的数组值没啥用。把fun函数中的int num[100]删掉,其它num都改为参数a
然后这n和m也一样,函数内的n和m,不是main中的n和m,要用参数传递进去
=========
另外函数实现思路也不对。加入输入5个数,1,2,3,4,5,然后n=5,m=1的话,你把1到4向后移动1位,这样5就被覆盖掉了啊