习题8-3 数组循环右移(20 分)
本题要求实现一个对数组进行循环右移的简单函数:一个数组a中存有$n(\gt 0)$个整数,将每个整数循环向右移$m(\geq 0)$个位置,即将a中的数据由$\left(a_{0} a_{1} \cdots a_{n-1}\right)$变换为$\left(a_{n-m} \cdots a_{n-1} a_{0} a_{1} \cdots a_{n-m-1}\right)$(最后m个数循环移至最前面的m个位置)。
函数接口定义:
1 | int ArrayShift( int a[], int n, int m ); |
其中a[]
是用户传入的数组;n
是数组的大小;m
是右移的位数。函数ArrayShift
须将循环右移后的数组仍然存在a[]
中。
裁判测试程序样例:
1 | #include <stdio.h> |
输入样例:
1 | 6 2 |
输出样例:
1 | 5 6 1 2 3 4 |