例76:有n个整数,使前面各数顺序向后移动m个位置,最后m个数变成最前面m个数,C语言写一函数实现以上功能,在主函数中输入n个整数和输出调整后的n个数,要求用指针。
解题思路:读者看着道题的时候,首先要明白题意,要用函数和指针来做,读者如果嫌麻烦的话可以先不用指针,函数也可以先不抽取出来,就在主函数中写,然后按照题意修改下自己的代码。
C语言源代码演示:
#include<stdio.h>//头文件
int main()//主函数
{
void move(int [20],int n,int m); //函数声明
int number[20],n,m,i;//定义整型变量和整型数组
printf("共有多少个数:");//提示语句
scanf("%d",&n);//键盘输入
printf("输入这%d个数\n",n);//提示语句
for(i=0;i<n;i++)
{ scanf("%d",&number[i]); //键盘录入n个数
}
printf("向后移动多少个数:");//提示语句
scanf("%d",&m);//键盘输入
move(number,n,m); //move函数调用
for(i=0;i<n;i++)//输出结果
{ printf("%d ",number[i]);
}
printf("\n");//换行
return 0;//主函数返回值为0
}
void move(int array[20],int n,int m)//move函数功能的实现
{ 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);//递归调用,当循环次数m减至为0时,停止调用
}
}
编译运行结果如下:
共有多少个数:8
输入这8个数
12 43 65 67 8 2 1 11
向后移动多少个数:4
8 2 1 11 12 43 65 67
--------------------------------
Process exited after 17.88 seconds with return value 0
请按任意键继续. . .
以上,如果你看了觉得对你有所帮助,就给小林点个赞,分享给身边的人叭,这样小林也有更新下去的动力,跪谢各位父老乡亲啦~
C语言学习路线 推荐收藏 | 开发工具文章来源: zhuanlan.zhihu.com,作者:小林C语言,版权归原作者所有,如需转载,请联系作者。
原文链接:zhuanlan.zhihu.com/p/349176108