题目链接:
习题8-3 数组循环右移 (20分)
#include <stdio.h>
#define MAXN 10
int ArrayShift( int a[], int n, int m );
int main()
{
int a[MAXN], n, m;
int i;
scanf("%d %d", &n, &m);
for ( i = 0; i < n; i++ ) scanf("%d", &a[i]);
ArrayShift(a, n, m);
for ( i = 0; i < n; i++ ) {
if (i != 0) printf(" ");
printf("%d", a[i]);
}
printf("\n");
return 0;
}
/* 你的代码将被嵌在这里 */
int ArrayShift( int a[], int n, int m ){
int b[m],i;
if(m>=n){
if(m%n!=0){
m=m%n;
}else{
m=n;
}
}
for(i=0;i<n-m;i++){
b[i]=a[i];
}
for(i=0;i<m;i++){
a[i]=a[n-m+i];
}
for(i=m;i<n;i++){
a[i]=b[i-m];
}
}