Java 无法找出方向缩减问题错误

Java 无法找出方向缩减问题错误,java,arrays,Java,Arrays,我正在研究codewars中的一个方向缩减问题,但我无法找出它给我带来的错误。我知道也有类似的情况,但当我在VisualStudio代码上测试我的代码时,它工作得完美无缺,所以我不知道为什么codewars会给我这个错误。我得到的错误是:“北”、“南”、“南”、“东”、“西”、“北”:数组长度不同,应为。长度=0实际长度=6 这是我的密码。请记住,codewars会为您进行测试,因此实际上不需要我的主要方法: import java.lang.*; public class DirReduct

我正在研究codewars中的一个方向缩减问题,但我无法找出它给我带来的错误。我知道也有类似的情况,但当我在VisualStudio代码上测试我的代码时,它工作得完美无缺,所以我不知道为什么codewars会给我这个错误。我得到的错误是:“北”、“南”、“南”、“东”、“西”、“北”:数组长度不同,应为。长度=0实际长度=6

这是我的密码。请记住,codewars会为您进行测试,因此实际上不需要我的主要方法:

import java.lang.*;

public class DirReduction {

public static String[] dirReduc(String[] arr) {
    int directionNS = 0;
    int directionEW = 0;
    for(int i = 0; i < arr.length; i++){
        if(arr[i] == "NORTH"){
            directionNS++;
        } else if(arr[i] == "SOUTH"){
            directionNS--;
        } else if(arr[i] == "EAST"){
            directionEW++;
        } else if(arr[i] == "WEST"){
            directionEW--;
        } else {
            System.out.println("Invalid Direction.");
        }
    }


    String[] reducArray;
    if(directionNS == 0 && directionEW == 0){
        reducArray = new String[arr.length];
        System.arraycopy(arr, 0, reducArray, 0, arr.length);

    } else {
        reducArray = new String[Math.abs(directionNS + directionEW)];
        if(directionNS > 0){
            for(int i = 0; i < directionNS; i++){
                reducArray[i] = "NORTH";
            }
        } else if(directionNS < 0){
            for(int i = 0; i > directionNS; i--){
                reducArray[i] = "SOUTH";
            }
        } 


        if(directionEW > 0){
            for(int i = 0; i < directionEW; i++){
                reducArray[i] = "EAST";
            }
        } else if(directionEW < 0){
            for(int i = 0; i > directionEW; i--){
                reducArray[i] = "WEST";
            }
        } 
    }
    return reducArray;
}

public static void main(String[] args){
    String[] a = {"NORTH", "SOUTH", "SOUTH", "EAST", "WEST", "NORTH","WEST"};

    String[] result = dirReduc(a);
    for(int i = 0; i < result.length; i++){
        System.out.println(result[i]);
    }
}
}
import java.lang.*;
公共级降污{
公共静态字符串[]dirreduce(字符串[]arr){
int-directionNS=0;
int directionEW=0;
对于(int i=0;i0){
对于(int i=0;i方向;i--){
阵列[i]=“南”;
}
} 
如果(directionEW>0){
for(int i=0;idirectionEW;i--){
还原数组[i]=“西”;
}
} 
}
返回数组;
}
公共静态void main(字符串[]args){
字符串[]a={“北”、“南”、“南”、“东”、“西”、“北”、“西”};
字符串[]结果=dirreduce(a);
for(int i=0;i
我发现了四个错误

1) 案例“北”、“南”、“南”、“东”、“西”、“北”应该回到您开始的位置,因此数组长度应该是0,这是Codewars要求的。为了实现这一点,我去掉了两个方向计数均为0的特殊情况,并通过添加0和0来获得数组大小,让您的else情况处理它。[此错误就是您问题中提到的错误]

2) 你对数组大小的计算有点偏差。例如,对于“SOUTH”“EAST”,计算的大小为0,因为他们取消了。相反,您需要求和绝对值,而不是求和的绝对值

3) 缩小阵列中的东/西从位置0开始,因此覆盖了北/南。在执行这些操作之前,我确保偏移到数组中

4) 如果你喜欢南、东、南,那么你在for循环中变为负值的策略将尝试写入一个负值索引。我用Math.abs保持它为正

下面是结果方法

public static String[] dirReduc(String[] arr) {
    int directionNS = 0;
    int directionEW = 0;
    for (int i = 0; i < arr.length; i++) {
        if (arr[i] == "NORTH") {
            directionNS++;
        } else if (arr[i] == "SOUTH") {
            directionNS--;
        } else if (arr[i] == "EAST") {
            directionEW++;
        } else if (arr[i] == "WEST") {
            directionEW--;
        } else {
            System.out.println("Invalid Direction.");
        }
    }


    String[] reducArray;
    //removed special case for ending up back where one started, that will be made a 0 length array as it should be
    reducArray = new String[Math.abs(directionNS) + Math.abs(directionEW)]; //note have to take abs of each so one does not cancel out the other
    if (directionNS > 0) {
        for (int i = 0; i < directionNS; i++) {
            reducArray[i] = "NORTH";
        }
    } else if (directionNS < 0) {
        for(int i = 0; i < Math.abs(directionNS); i++){//keep the i's positive so they work in the array easily
            reducArray[i] = "SOUTH";
        }
    }


    if (directionEW > 0) {
        for (int i = 0; i < directionEW; i++) {
            reducArray[i + Math.abs(directionNS)] = "EAST"; //note have to start where north south left off
        }
    } else if (directionEW < 0) {
        for(int i = 0; i < Math.abs(directionEW); i++){
            reducArray[i + Math.abs(directionNS)] = "WEST";
        }
    }

    return reducArray;
}`
公共静态字符串[]dirreduce(字符串[]arr){
int-directionNS=0;
int directionEW=0;
对于(int i=0;i0){
对于(int i=0;i0){
for(int i=0;i
你太棒了!它在VisualStudio代码上运行得非常完美,并通过了所有Codewars示例测试。实际尝试失败了,但原因我不确定。它只把答案列为“东”,但即使按照指示逻辑,答案也应该是“北”、“东”。再次感谢!它失败的测试是什么?“东”、“东”、“西”、“北”、“西”、“东”、“东”、“南”、“北”、“西”:数组首先在元素[0]处不同;预期:但是是:他们想要按字母顺序排列吗?所以东北,但你给东北?它没有具体说明,所以我很困惑。我唯一能想到的另一件事是方向必须保持相同的顺序。所以,既然它先说东,后说北,那么它就必须保持这种状态。但问题再次没有具体说明这一点。。