关于使用void递归解决移除链表元素问题

关于使用void递归解决移除链表元素问题

http://img1.sycdn.imooc.com//climg/600a81900971ed7213351010.jpg

老师这是我看这门课第二遍,这里还是有点不清楚,关于把返回值改成void的递归我这么写自己测试好像是对的,但是代码一上传leetcode就通不过显示没有移除那个元素。想请教一下老师怎么回事。



正在回答 回答被采纳积分+1

登陆购买课程后可参与讨论,去登陆

1回答
liuyubobobo 2021-01-23 15:56:39

把你提交给 Leetcode 的代码完整贴出来。不要图片。

  • 提问者 慕前端5229000 #1
    /**
     * Definition for singly-linked list.
     * public class ListNode {
     *     int val;
     *     ListNode next;
     *     ListNode() {}
     *     ListNode(int val) { this.val = val; }
     *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
     * }
     */
    class Solution {
        public ListNode removeElements(ListNode head, int val) {
          ListNode dummyHead = new ListNode(-1);
          dummyHead.next = head;
          remove(dummyHead, val);
          return dummyHead.next;
        }
        private void remove(ListNode node, int val) {
          if (node.next == null) {
            return;
          }
          if (node.next.val == val) {
            node.next = node.next.next;
            return;
          }
          remove(node.next,val);
        }
    }

    代码是这样的,就是移除元素那题


    2021-01-23 16:03:38
  • liuyubobobo 回复 提问者 慕前端5229000 #2

    这个逻辑只能删除一个元素。这个问题要求把所有等于 val 的元素都删除。继续加油!:)

    2021-01-23 16:10:55
  • 提问者 慕前端5229000 回复 liuyubobobo #3

    多谢老师指正!

    2021-01-23 16:28:53
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
算法与数据结构
  • 参与学习       2638    人
  • 解答问题       1106    个

慕课网算法名师Liuyubobobo,5年集大成之作 从0到工作5年,算法与数据结构系统解决方案

了解课程
请稍等 ...
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师