Java 无法找出方向缩减问题错误
我正在研究codewars中的一个方向缩减问题,但我无法找出它给我带来的错误。我知道也有类似的情况,但当我在VisualStudio代码上测试我的代码时,它工作得完美无缺,所以我不知道为什么codewars会给我这个错误。我得到的错误是:“北”、“南”、“南”、“东”、“西”、“北”:数组长度不同,应为。长度=0实际长度=6 这是我的密码。请记住,codewars会为您进行测试,因此实际上不需要我的主要方法:Java 无法找出方向缩减问题错误,java,arrays,Java,Arrays,我正在研究codewars中的一个方向缩减问题,但我无法找出它给我带来的错误。我知道也有类似的情况,但当我在VisualStudio代码上测试我的代码时,它工作得完美无缺,所以我不知道为什么codewars会给我这个错误。我得到的错误是:“北”、“南”、“南”、“东”、“西”、“北”:数组长度不同,应为。长度=0实际长度=6 这是我的密码。请记住,codewars会为您进行测试,因此实际上不需要我的主要方法: import java.lang.*; public class DirReduct
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]处不同;预期:但是是:他们想要按字母顺序排列吗?所以东北,但你给东北?它没有具体说明,所以我很困惑。我唯一能想到的另一件事是方向必须保持相同的顺序。所以,既然它先说东,后说北,那么它就必须保持这种状态。但问题再次没有具体说明这一点。。