我有这个枚举:
public enum Direction {
NORTH, WEST, SOUTH, EAST;
}
和这个方法:
public void turn(int n){
for (int i = 0; i < n; i++){
//Change compass direction n times
}
}
我需要做的是逆时针方向将方向改变90度并输入“n”次。我设置枚举,以便它按正确的顺序,我只是不知道我怎么能这样做所以当前值compassDirection可以通过迭代枚举“n”次来改变。
答案 0 :(得分:2)
如果我理解正确,您希望迭代enum
成员。
为了做到这一点,每个enum
都有一个.values()
方法,它以定义的顺序返回一个包含所有有效值的数组。
所以用
public void turn(int n){
for (int i = 0; i < n; i++){
for (Direction direction : Direction.values()) {
// Do something with direction
}
}
}
你基本上达到了你想要的目标。
编辑:在澄清之后,我认为你宁愿在
之后public void turn(int n){
Direction[] directions = Direction.values()
for (int i = 0; i < n; i++) {
int direction_index = i % directions.length;
Direction direction = directions[direction_index];
// Do something with direction
}
}
或
public void turn(int n){
int i = 0;
while (true) {
for (Direction direction : Direction.values()) {
if (i==n) return;
i++
// Do something with direction
}
}
}
答案 1 :(得分:1)
我认为你不需要迭代。 你可以实现这样的转变:
public Direction turn(Direction initial, int turns)
{
Direction[] dirs = Direction.values();
return dirs[(initial.ordinal()+turns) % dirs.length];
}
在此代码中,您将获得枚举中当前元素的索引,并根据转数获得结果的索引。通过结果索引,您可以生成枚举值。
答案 2 :(得分:1)
public static void main(String[] args) {
turn(6);
}
public static Direction turn(int n){
Direction result = null;
Direction[] values = Direction.values();
for(int i = 0; i < n; i++){
result = values[i % values.length];
System.out.println(i + " " + result);
}
return result;
}