关闭

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

456人阅读 评论(2) 收藏 举报
分类:

一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置,即将A中的数据由(A0 A1……AN-1)变换为(AN-M …… AN-1 A0 A1……AN-M-1)(最后M个数循环移至最前面的M个位置)。如果需要考虑程序移动数据的次数尽量少,要如何设计移动的方法?

输入格式:每个输入包含一个测试用例,第1行输入N ( 1<=N<=100)、M(M>=0);第2行输入N个整数,之间用空格分隔。

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

输入样例:
6 2
1 2 3 4 5 6
输出样例:
5 6 1 2 3 4

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner in = new Scanner(System.in);
        int n = in.nextInt();
        int m = in.nextInt();
        m = n - m % n;
        int flag = 0;
        int[] a = new int[n];
        for ( int i = 0 ; i < n ; i++  ){
            a[i] = in.nextInt();
        }
        for ( int i = m ; i < n ; i++ ){
            if ( flag == 1 ){
                System.out.print(" "+a[i]);
            }
            else{
                System.out.print(a[i]);
                flag = 1;
            }
        }
        for ( int i = 0 ; i < m ; i++ ){
            if ( flag == 1){
                System.out.print(" "+a[i]);
            }
            else{
                System.out.print(a[i]);
                flag =1;
            }

        }
        in.close();
    }

}

这里写图片描述

1
0
查看评论

Java - PAT - 1008. 数组元素循环右移问题 (20)

一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置,即将A中的数据由(A0A1……AN-1)变换为(AN-M …… AN-1 A0 A1……AN-M-1)(最后M个数循环移至最前面的M个位置)。如果需要...
  • qq_34594236
  • qq_34594236
  • 2016-06-18 22:23
  • 1370

PAT Basic 1008. 数组元素循环右移问题 (20)(C语言实现)

题目 一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置,即将A中的数据由(A0 A1……A_N-1)变换为(A_N-M …… A_N-1 A_0 A_1……A_N-M-1)(最后M个数循环移至最前面的M个位置)。如果需要考虑程序...
  • Oliver__Lew
  • Oliver__Lew
  • 2017-05-18 23:44
  • 258

1008. 数组元素循环右移问题 (20)(Java实现)

没有写出最优解... 继续努力  最优解->http://blog.csdn.net/u012860063/article/details/39505497 1008. 数组元素循环右移问题 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度...
  • cswoniu111
  • cswoniu111
  • 2017-03-28 13:02
  • 250

【PAT】(乙级)1008. 数组元素循环右移问题(20)

1008. 数组元素循环右移问题 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 一、题目一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置,即将A中的数据由(A...
  • R3lish
  • R3lish
  • 2016-08-07 12:50
  • 548

PAT Basic 1008. 数组元素循环右移问题 (20)

一个数组A中存有N(N>0)个整数,在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置,即将A中的数据由(A0A1……AN-1)变换为(AN-M …… AN-1 A0 A1……AN-M-1)(最后M个数循环移至最前面的M个位置)。如果需要...
  • xtzmm1215
  • xtzmm1215
  • 2014-08-06 22:18
  • 4471

PAT乙级:1008. 数组元素循环右移问题 (Java)

如果只是输出正确的结果我认为移动的应该不是元素,而是指针。只需要记录一下从什么地方开始向后遍历即可。 import java.util.Scanner;public class Main { public static void main(String[] args) { in...
  • hengbao4
  • hengbao4
  • 2016-08-08 06:59
  • 566

PAT乙级真题及训练集(6)--1008. 数组元素循环右移问题 (20)

1008. 数组元素循环右移问题 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 一个数组A中存有N(N>0)个整...
  • u011662320
  • u011662320
  • 2017-06-15 21:48
  • 166

PATBasic——1008. 数组元素循环右移问题 (20)

1008. 数组元素循环右移问题 (20) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 一个数组A中存有N(N>0)个整...
  • fynjy
  • fynjy
  • 2015-06-19 16:15
  • 359

PAT乙级1008. 数组元素循环右移问题 (20)

这道题写的有点投机取巧,题目本来要求 “在不允许使用另外数组的前提下,将每个整数循环向右移M(M>=0)个位置” “需要考虑程序移动数据的次数尽量少” 我则干脆不变序数组,直接用移出点进行输出。。。 一开始总是部分正确,后来发现题目里有陷阱 “第1行输入N ( 1=0);” 所以M是有可能...
  • TimVan1596
  • TimVan1596
  • 2017-02-22 02:27
  • 234

00-自测3. 数组元素循环右移问题 (20)

题目链接:http://www.patest.cn/contests/mooc-ds/00-%E8%87%AA%E6%B5%8B3 00-自测3. 数组元素循环右移问题 (20) 时间限制 400 ms 内存限制 65536 kB ...
  • ice_camel
  • ice_camel
  • 2015-02-21 20:11
  • 791
    个人资料
    • 访问:155109次
    • 积分:4924
    • 等级:
    • 排名:第6846名
    • 原创:329篇
    • 转载:0篇
    • 译文:0篇
    • 评论:80条
    博客专栏
    最新评论