/*
烟台大学计算机学院 2016
作者:张威
完成日期:2016年12月10日
问题描述:有n个整数,使前面各数顺序向后移m个位置,最后m个数变成前面m个数,见图。写一函数:实现以上功能,在主函数中输入n个数和输出调整后的n个数。
*/
#include<stdio.h>
void mv(int a[],int n ,int m);
int main()
{
int a[80];
int m,i,n;
scanf("%d",&n);
for(i=0; i<n; i++)
scanf("%d",&a[i]);
scanf("%d",&m);
mv(a,n,m);
for(i=0; i<n; i++)
printf("%d ",a[i]);
return 0;
}
void mv(int a[],int n,int m)
{
int i,j,k;
for(i=n-1;i>=0;i--)
a[i+m]=a[i];
for(j=0,k=n;j<m;j++,k++)
a[j]=a[k];
}
运行结果: