PATB1008数组元素循环右移问题(20分)(C语⾔实现)
PAT B1008数组元素循环右移问题 (20 分)(C语⾔实现)
问题描述
⼀个数组A中存有N(>0)个整数,在不允许使⽤另外数组的前提下,将每个整数循环向右移M(≥0)个位置,即将A中的数据由(A[0] A[1]…A[N−1])变换为(A[N−M]…A[N−1] A[0] A[1] …A[N−M−1])(最后M个数循环移⾄最前⾯的M个位置)。如果需要考虑程序移动数据的次数尽量少,要如何设计移动的⽅法?
输⼊格式:
每个输⼊包含⼀个测试⽤例,第1⾏输⼊N(1≤N≤100)和M(≥0);第2⾏输⼊N个整数,之间⽤空格分隔。
输出格式:
在⼀⾏中输出循环右移M位以后的整数序列,之间⽤空格分隔,序列结尾不能有多余空格。
输⼊样例:
6 2
1 2 3 4 5 6
输出样例:
5 6 1 2 3 4
思路
1. 审查题⽬中,对于输出的要求不在于要获取变动之后的变量,在这⾥选择直接输出;
2. 确定变动点,分为两个部分输出
3. 格式重点不要忘记
代码
#include <stdio.h>
int main()
{
int N, M, numbers[100];
scanf("%d %d", &N, &M);
scanf输入整型数组M %= N;
for(int i = 0; i < N; i++)
scanf("%d", &numbers[i]);
for(int i = N - M; i < N; i++)
printf("%d ", numbers[i]);
for(int i = 0; i <N - M - 1; i++)
printf("%d ", numbers[i]);
printf("%d",numbers[N-M-1]);
return 0;
}
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论