Description
调用自定义后移函数move(int *a, int n, int m)来进行循环移位,对n(n<20)个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面m个数,如下: n=10, m=3时:输入:1 2 3 4 5 6 7 8 9 10,输出:8 9 10 1 2 3 4 5 6 7
Input
输入多组测试数据,每组先输入n(n < 20)和m(m < n),再输入n个整数。
Output
输出循环移动m个数后的序列,数据间空格隔开。
Sample Input
10 4
1 2 3 4 5 6 7 8 9 10
7 2
1 2 3 4 5 6 7
Sample Output
7 8 9 10 1 2 3 4 5 6
6 7 1 2 3 4 5
#include<stdio.h>
int move(int *a,int n,int m)
{
int t[100];
int i;
for(i=0;i<n;i++)
{
t[i]=a[i];
}
for(i=0;i<m;i++)
{
a[i]=t[n-m+i];
}
for(i=m;i<n;i++)
{
a[i]=t[i-m];
}
}
int main()
{
int a[20];
int n,m;
int i;
while(scanf("%d%d",&n,&m)!=EOF)
{
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
move(a,n,m);
for(i=0;i<n-1;i++)
{
printf("%d ",a[i]);
}
printf("%d\n",a[i]);
}
}