一个数组循环右移K位, java版本

本文介绍了一种将数组中的元素循环右移K位的有效方法。通过三次逆序操作实现目标,详细展示了每一步骤的执行过程及代码实现。
 腾讯面试: 如何把一个数组循环右移K位
   如:12345678 右移2位  78123456
      思路如下:
         1:首先逆序123456,那么数组变为65432178
         2:再逆序78,那么数组变为65432187
         3:最后逆序整个数组:65432187 ,那么数组变为78123456
     那么如何逆序呢?
         定义两个变量,begin和end,分别指向需要逆序的数组的起始位置,
         通过临时变量temp,进行交换,直到begin>=end 结束
 
[java]  view plain  copy
  1. package datastruct.usearray;  
  2.   import java.util.Scanner;  
  3.   
  4. public class Shift_k {  
  5.        private static void shift_method(int array[],int k) {  
  6.           int n=array.length-1;  
  7.           k=k%n; //为了防止k>n ,右移K位和右移k%n的结果是一样的  
  8.           shift_method(array, 0, n-k);  
  9.           shift_method(array, n-k+1, n);  
  10.           shift_method(array, 0, n);  
  11.           System.out.println("右移"+k+"位的结果为:");  
  12.         for (int i : array) {  
  13.             System.out.print(i+" ");  
  14.         }  
  15.     }  
  16.        private static void shift_method(int array[],int begin,int end) {  
  17.            int temp;  
  18.            while (begin=end 结束  
  19.               temp=array[begin];  
  20.               array[begin]=array[end];  
  21.               array[end]=temp;  
  22.               begin++;  
  23.               end--;  
  24.         }  
  25.           
  26.     }  
  27.        public static void main(String[] args) {  
  28.         Scanner sc=new Scanner(System.in);  
  29.         System.out.println("输入数组元素个数:");  
  30.         int n=sc.nextInt();  
  31.         int array[]=new int[n];  
  32.         System.out.println("输入"+n+"个数组元素:");  
  33.         for (int i = 0; i < n; i++) {  
  34.             array[i]=sc.nextInt();            
  35.         }  
  36.         System.out.println("输入移动的位数:");  
  37.         int k=sc.nextInt();  
  38.         shift_method(array, k);  
  39.     }  
  40. }  

运行结果如下:


               

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值