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

一个数组A中存有N(>)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(≥)个位置,即将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)和M(≥);第2行输入N个整数,之间用空格分隔。

输出格式:

在一行中输出循环右移M位以后的整数序列,之间用空格分隔,序列结尾不能有多余空格。

输入样例:

6 2
1 2 3 4 5 6

输出样例:

5 6 1 2 3 4

C++实现:

分析:

实现数组右移分3步:

(1)将数组颠倒(2)将数组 [ 0, m ) 颠倒(3)将数组 [ m, length) 颠倒

注意:

(1)右移位数 M 可能会比元素个数 N 大,要先进行 M % N 的操作

(2)判断 M 是否为 0

 #include <iostream>
#include <vector>
#include <algorithm>
using namespace std; int main()
{
//先将数组倒置,然后再将数组后的M位再倒置
int N, M;
cin >> N >> M; //元素个数,后移位数
vector<int> v(N);
for (int i = ; i < N; ++i)
{
cin >> v[i];
} M %= N; //防止M比N大
if (M != )
{
reverse(v.begin(), v.begin() + N); //第一次将所有数组倒置
//由1-2-3-4-5-6变成6-5-4-3-2-1 reverse(v.begin(), v.begin() + M); //第二次将部分数组倒置
//由6-5-4-3-2-1变成5-6-4-3-2-1 reverse(v.begin() + M, v.end()); //第三次将部分数组倒置
//由6-5-4-3-2-1变成5-6-1-2-3-4
}
vector<int>::iterator it; for (it = v.begin(); it != v.end() - ; ++it)
{
cout << *it << " "; }
cout << *it;
return ;
}

Java实现:

 import java.util.Scanner;

 public class Main {
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
int n = input.nextInt();
int m = input.nextInt();
int a[] = new int[n];
int i = 0;
for (i = 0; i < n; i++) {
a[i] = input.nextInt();
}
if (n < m) {
m = m % n;
}
if (n == m) {
for (i = 0; i < n; i++) {
if (i != 0) {
System.out.print(" ");
}
System.out.print(a[i]);
}
} else {
for (int j = n - m; j < n; j++) {
System.out.print(a[j] + " ");
}
for (int j = 0; j < n - m; j++) {
if (j != 0) {
System.out.print(" ");
}
System.out.print(a[j]);
}
}
}
}

最新文章

  1. Xcode8新特性和iOS10新特性
  2. mac下 ssh免密码登陆设置
  3. ALV详解:Function ALV(一)
  4. python 运行 hadoop 2.0 mapreduce 程序
  5. Scope and Namespace
  6. java基础解析系列(四)---LinkedHashMap的原理及LRU算法的实现
  7. Ipython的安装/ipython notebook的简单使用
  8. Netty ByteBuf梳理
  9. AGC010 - A: Addition
  10. ffdshow 源代码分析 6: 对解码器的dll的封装(libavcodec)
  11. Myeclipse Db Browser使用
  12. 深入了解webpack前,可以了解的小知识点。
  13. Kafka笔记6(数据传递的可靠性)
  14. [转]c# System.IO.Ports SerialPort Class
  15. Centos6.8 安装spark-2.3.1 以及 scala-2.12.2
  16. js中setTimeout和clearTimeout的使用
  17. 【SqlServer】SqlServer索引的创建、查看、删除
  18. 2018/03/10 每日一个Linux命令 之 cksum
  19. 解决input和button错位(不齐)问题
  20. D3 data()

热门文章

  1. 数据分析,R语言
  2. JMeter扩展插件实现对自定义协议进行支持 转
  3. jmeter 获取总的线程数
  4. 贪心 + 计算几何 --- Radar Installation
  5. 什么是 Shell?
  6. Django 路由name使用
  7. The instance of entity type &#39;Menu&#39; cannot be tracked because another instance with the same key value for {&#39;Id&#39;} is already being tracked.
  8. EntityFramework执行Add-Miragtion或者Update-Database出闲ScriptHalted
  9. .Net Core2.2 在IIS发布
  10. SpringBoot 入门篇(二) SpringBoot常用注解以及自动配置