您的位置:首页 > 其它

1008 数组元素循环右移问题 (20分)

2020-03-28 20:02 141 查看

一个数组AAA中存有NNN(>0>0>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移MMM(≥0\ge 0≥0)个位置,即将AAA中的数据由(A0A1⋯AN−1A_0 A_1 \cdots A_{N-1}A​0​​A​1​​⋯A​N−1​​)变换为(AN−M⋯AN−1A0A1⋯AN−M−1A_{N-M} \cdots A_{N-1} A_0 A_1 \cdots A_{N-M-1}A​N−M​​⋯A​N−1​​A​0​​A​1​​⋯A​N−M−1​​)(最后MMM个数循环移至最前面的MMM个位置)。如果需要考虑程序移动数据的次数尽量少,要如何设计移动的方法?输入格式:每个输入包含一个测试用例,第1行输入NNN(1≤N≤1001\le N \le 1001≤N≤100)和MMM(≥0\ge 0≥0);第2行输入NNN个整数,之间用空格分隔。输出格式:在一行中输出循环右移MMM位以后的整数序列,之间用空格分隔,序列结尾不能有多余空格。输入样例:6 2
1 2 3 4 5 6

输出样例:5 6 1 2 3 4
#include<iostream>
using namespace std;
int main()
{
int N,M,T;
int num[100];
cin>>N;
cin>>T;
M = T%N;//这一步的取余很重要,最开始就错在这个地方,一直没明白。
for(int i=0;i<N;i++){
cin>>num[i];
}
for(int i=N-M;i<N;i++){
cout<<num[i]<<" ";
}
for(int i=0;i<N-M-1;i++)
{
cout<<num[i]<<" ";
}
cout<<num[N-M-1];
return 0;
}
  • 点赞
  • 收藏
  • 分享
  • 文章举报
清晨粥 发布了13 篇原创文章 · 获赞 0 · 访问量 120 私信 关注
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: