LeetCode113 记录一次因为提前return而导致的错误

LeetCode113 记录一次因为提前return而导致的错误

首先贴上错误的截图

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-STbqYzaa-1592814427200)(C:\Users\zhao\Desktop\1.jpg)]

这里 我认为这个错误原因还是有必要记录和分析一下的

我们发现 在我们的输出测试中 多了1个4,也就是说4并没有被remove掉 通过分析发现 这里因为我在红框选中的地方提前return了

正常情况下 当我们找到一条5 4 11 2 这个路径之后 我们要在temp数组当中把2 remove掉 可是根据我的错误的代码 在找到5 4 11 2 这个路径之后 我却直接把他return了 我们看这个图 这个图展示了正确的情况

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-y1wo6xhF-1592814427205)(C:\Users\zhao\Desktop\2.jpg)]

可是 我犯的错误就是在这里直接return了 我们来看直接return的后果

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-egMCDubM-1592814427208)(C:\Users\zhao\Desktop\3.jpg)]

这样造成的后果就是 该remove11 的时候 我remove了2 该remove 4的 时候 我才remove11 这样就把4剩下了

于是造成了第一张错误贴图的结果

正确代码如下

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public List<List<Integer>> pathSum(TreeNode root, int sum) {
        List<List<Integer>> result=new ArrayList<>();
        if(root==null)
            return result;
        return DFS(root,sum,new ArrayList<>(),result);
    }

    public List<List<Integer>> DFS(TreeNode node,int sum,List<Integer> temp,List<List<Integer>> result){   
        if(node==null)
            return result;

        temp.add(node.val);

        if(node.left==null&&node.right==null&&sum==node.val){
            result.add(new ArrayList<Integer>(temp));
        }

        DFS(node.left,sum-node.val,temp,result);
        DFS(node.right,sum-node.val,temp,result);
    
        temp.remove(temp.size()-1);
        return result;
    }
}


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章