-1

我编写了一个合并两个链表的程序,所以我首先创建了一个 dummyHead。但是编译器返回给我一个错误:unreachable statement。我在互联网上搜索了它,但仍然不明白为什么会这样。

代码是:

/**
 * class ListNode {
 *   public int value;
 *   public ListNode next;
 *   public ListNode(int value) {
 *     this.value = value;
 *     next = null;
 *   }
 * }
 */
public class Solution {
  public ListNode merge(ListNode one, ListNode two) {
    if(one == null && two != null){
      return two;
    }else if(one != null && two == null){
      return one;
    }else{
      return null;
    }
    
    ListNode dummyHead = new ListNode(-1);
    ListNode cur_one = one;
    ListNode cur_two = two;
    ListNode dummyCur = dummyHead;
    while(cur_one.next == null || cur_two.next == null){
      if(cur_one.value <= cur_two.value){
        dummyCur.next = cur_one;
        cur_one = cur_one.next;
      }else{
        dummyCur.next = cur_two;
        cur_two = cur_two.next;
      }
      dummyCur = dummyCur.next;
    }
    
    if(cur_one.next != null){
      dummyCur.next = cur_one.next;
    }
    if(cur_two.next != null){
      dummyCur.next = cur_two.next;
    }
    
    return dummyHead.next;
  }
}

错误信息是:

错误:java.io.IOException:/Solution.java:21:错误:无法访问的语句

ListNode dummyHead = new ListNode(-1);

感谢你的回复。

4

3 回答 3

2

由于您的 if/else if/else 条件,该行永远不会执行:

if(one == null && two != null){
  return two;
} else if(one != null && two == null){
  return one;
} else{
  return null;
}

基于此条件,在执行第 21 行之前返回 2、1 或 null。

您需要删除 else 以允许该方法继续执行。

于 2019-03-02T22:49:52.467 回答
1

在您的第一个 if 语句中,由于最后一个 else 块,您在所有可能的情况下都会提前退出该方法。这就是为什么以下语句都不会被执行的原因。

于 2019-03-02T22:51:16.680 回答
1

else { return null; } 最后一个 else 条件在该行之前返回 null。如果您希望使用其余功能,请删除最后一个 else 条件。

于 2019-03-02T23:01:39.607 回答