3 回答
TA贡献1784条经验 获得超8个赞
我其实最先想到的是用集合来做,非常简单,易于理解。(可能度娘没有排版,自己copy下)
你把步骤细分下,就是在arr数组中移除最后个,在添加到arr数组的第一个位置。
import java.util.Arrays;
import java.util.LinkedList;
public class Test
{
public static void main(String[] args){
String[] arr={"a","b","c","d","e","f","g","h"};
System.out.println(Arrays.toString(transpose(arr,3)));
}
private static String[] transpose(String[] arr,int n){
LinkedList<String> originalList=new LinkedList<String>();
for(String s:arr)
originalList.add(s);
if(n<0)
throw new IllegalArgumentException("argument n: "+n +"is negative!");
if(n==0)
return arr;
for(int i=0;i<n;i++){
String e=originalList.pollLast();
originalList.offerFirst(e);
}
return originalList.toArray(new String[0]);
}
}
TA贡献1821条经验 获得超4个赞
public class change {
public static String[] change(String[] arry,int len){
String tar[] = new String[arry.length] ;
for(int i = arry.length-len,y=0;i<arry.length;i++){
tar[y++]=arry[i];
}
for(int i = len,y=0;i<arry.length;i++){
tar[i]=arry[y++];
}
return tar;
}
public static void main(String arg[]){
String[] ss = new String[]{"a","b","c","d"};
for(String s : ss){
System.out.print(s);
}
System.out.print("\n");
for(String s :change(ss,0) ){
System.out.print(s);
}
}
}
TA贡献1824条经验 获得超8个赞
建立一个中间数组保存下移除的元素,原数组元素右移以后再添上去不就行了。
按照你的题意做的:
public static void main(String[] args) {
String[] x1 = { "a", "b", "c", "d", "e", "f" };
int n = 2;
String[] x2 = new String[n];
int a = n - 1;
for (int i = x1.length - 1; i > x1.length - 1 - n; i--) {
x2[a] = x1[i];
a--;
}
int b = x1.length - 1;
for (int i = x1.length - 1 - n; i >= 0; i--) {
x1[b] = x1[i];
b--;
}
for (int i = 0; i < n; i++) {
x1[i] = x2[i];
}
for (String x : x1) {
System.out.print(x + " ");
}
}
添加回答
举报