设一个数组中有n个数,将前面各个数顺序向后移动m个位置,移出的数再从头开始移入;
编码如下:
/*将数组中的数向后移动n位,移出的部分再移入头部*/
void chapter1::moveArray(int a[], int alength, int moveLength)
{
for (int i =0;i<moveLength;i++)
{
int lastitem = a[alength-1];
for (int j = alength -1;j>0;j--)
{
a[j] = a[j - 1];
}
a[0] = lastitem;
}
}
/*有n个整数, 使前面各数顺序向后移m个位置, 移出的数再从开头移入。 编写一个函数实现以上功能, 在主函数中输入n个整数并输出调整后的n个数*/
void chapter1::moveN()
{
printf_s("移动数测试开始\r\n");
printf_s("输入数组大小n");
int n;
scanf_s("%d",&n);
int *arraydata = (int*)calloc(n, sizeof(int));
for(int i=0;i<n;i++)
{
printf_s("请输入第%d个数\r\n",i);
scanf_s("%d", &arraydata[i]);
}
printf_s("请输入移动位数\r\n");
int m;
scanf_s("%d", &m);
moveArray(arraydata, n, m);
for (size_t i = 0; i < n; i++)
{
printf_s("第%d个数:%d\r\n",i,arraydata[i]);
}
}
感兴趣的朋友可以关注下面的公众号,每天分享一点知识,成长看得见,感谢支持!!