6-6 数组循环右移 (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;

}

/* 你的代码将被嵌在这里 */
输入样例:
6 2
1 2 3 4 5 6
输出样例:
5 6 1 2 3 4

int ArrayShift( int a[], int n, int m )
{
m%=n;
int j=0,i,k,g=m;
int b[n];
for(i=n-m;i<n;i++,j++)//将a[n-m]到a[n]项转移到b数组的前m项中
{
b[j]=a[i];
}
for(k=0;k<=n-m-1;k++,g++)//将a[0]到a[n-m-1]项转移到b数组的第m+1项到第n//项中
{
b[g]=a[k];
}
for(i=0;i<n;i++)//将右移后的b数组重新放入a数组
a[i]=b[i];
return a[n];//返回a数组
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值