移动数组元素一定数量?

时间:2012-09-12 18:56:52

标签: java arrays encryption

我遇到一个问题,我有一个包含字母表中字母的数组。我想知道将数组元素移动一定数量的最佳方法是什么。例如,如果键是2,

array = "A,B,C,D,E.."

我怎样才能使转型后

array = "C,D,E,F,G..."

最简单的解决方案是if声明吗?

谢谢

4 个答案:

答案 0 :(得分:3)

您是否必须使用数组,集合如何...

List<?> list = Arrays.asList('A', 'B', 'C', 'D', 'E');
Collections.rotate(list, -2);
System.out.println(list);

输出

[C, D, E, A, B]

替代方案,使用一组主要类包装器...例如字符,整数等。这仍然允许通过直写Arrays.asList()方法使用集合....

    final Character[] array = { 'A', 'B', 'C', 'D', 'E' };
    Collections.rotate(Arrays.asList(array), -2);
    System.out.println(Arrays.toString(array));

输出

[C, D, E, A, B]

答案 1 :(得分:0)

这应该这样做:

char[] input = ...
char[] result = new char[input.length];
int shift = 2;

for(int i = 0; i < input.length; i++)
{
    result[i] = input[(i + shift) % input.length];
}

如您所见,您需要for循环。 if不会这样做。它会将所有char的两个向左移动。

结果将是:['C', 'D', ..., 'Z', 'A', 'B']

此方法称为circular shift

答案 2 :(得分:0)

char[] newArray = Arrays.copyRange(oldArray, shiftValue, oldArray.length);

http://docs.oracle.com/javase/6/docs/api/java/util/Arrays.html#copyOfRange(char[], int, int)

编辑:如果您需要旋转数组,请查看以下方法:

http://docs.oracle.com/javase/7/docs/api/java/util/Collections.html#rotate(java.util.List, int)

或者:

Character[] arr = {'a', 'b', 'c', 'd'};
List<Character> chars = Arrays.asList(arr);
Collections.rotate(chars, -2);
arr = chars.toArray(new Character[0]);

答案 3 :(得分:0)

您是否尝试过Collections.rotate

final Character[] vals = { 'A', 'B', 'C', 'D', 'E' };
final List<Character> list = Arrays.asList(vals);
Collections.rotate(list, -2);
/* vals will be rotated */
System.out.println(Arrays.toString(vals));

...产生(见ideone paste):

  

[C,D,E,A,B]