单链表2(删除与修改)

本文档介绍了如何在单链表中实现删除节点、修改节点值以及定位特定值节点的操作,包括删除具有特定值的节点、更新节点的val值和查找第一次出现的特定值节点。通过示例代码展示了如何在Java中使用MyselfLinkedList类进行这些操作。
摘要由CSDN通过智能技术生成

删除
删除节点:(将val为val的节点删除)
思路:
1.head不能动,因此我们需要一个辅助节点temp找到待删除节点的上一个节点
2.我们在比较时 要用 temp.next.val和需要删除的节点的val作比较
代码如下:

 /*
    删除节点:(将val为val的节点删除)
    思路:
    1.head不能动,因此我们需要一个辅助节点temp找到待删除节点的上一个节点
    2.我们在比较时 要用 temp.next.val和需要删除的节点的val作比较
     */
    public void delete(int val) {
        if (head.next == null) {
            System.out.println("链表为空,不能删除");
        }
        Node temp = head;
        boolean flag = false;//表示是否找到待删除节点
        while (true) {
            if (temp.next == null) {//表示已经到了链表的最后
                break;
            }
            if (temp.next.val == val) {//表示找到待删除节点的前一个节点
                flag = true;
                break;
            }
            temp = temp.next;
        }
        if (flag) { //说明找到要删除的节点
            temp.next = temp.next.next;
        } else {  //说明没有找到要删除的节点不存在
            System.out.println("要删除的节点不存在");
        }
    }

修改
修改节点的信息,根据节点的val值来修改();
注意:只能修改val为某值的第一次出现的节点!

//修改节点的信息,根据节点的val值来修改()
    //注意:只能修改val为某值的第一次出现的节点
    //val 表示要修改节点的val值;
    //target 表示将val为某值的节点的val更改为target;
    public void update(int val, int target) {
        //判断是否为空
        if (head.next == null) {
            System.out.println("链表为空,不能修改");
            return;
        }
        //找到需要修改的节点,根据val值
        Node temp = head;
        boolean flag = false;//表示是否找到该节点
        while (true) {
            if (temp == null) {
                break; //表示已经遍历该链表
            } else if (temp.val == val) {
                flag = true;
                break;
            }
            temp = temp.next;
        }
        if (flag) {//根据flag判断是否找到要修改的节点
            temp.val = target;
        } else {//没有找到val为val的节点
            System.out.println("没有找到val为" + val + "的节点");
        }

    }

节点的基本操作基本上就这么多,最后我把全部的代码整理在一起供大家参考:

package com.DateStructure.Lesson.GSGLinked;


import javax.management.MBeanException;

//自己写的单链表
public class MyselfLinkedList {


    //先初始化一个头结点,不存放具体的数据
    final Node head = new Node(0);

    /*
    添加节点到单链表中
     思路:
     1.找到当前节点的最后节点
     2.将最后这个节点的next指向新的节点
      */
    public void add(Node node) {
        //因为head节点不能动,因此我们需要一个辅助节点
        Node temp = head;
        //遍历链表,找到最后的节点
        while (true) {
            if (temp.next == null) {
                break;
            } else {
                //如果没有找到最后的节点,将temp后移
                temp = temp.next;
            }
        }
        //当退出while循环时,temp就指向了链表最后的节点
        //将这个节点的最后指向新的节点
        temp.next = node;
    }

    //修改节点的信息,根据节点的val值来修改()
    //注意:只能修改val为某值的第一次出现的节点
    //val 表示要修改节点的val值;
    //target 表示将val为某值的节点的val更改为target;
    public void update(int val, int target) {
        //判断是否为空
        if (head.next == null) {
            System.out.println("链表为空,不能修改");
            return;
        }
        //找到需要修改的节点,根据val值
        Node temp = head;
        boolean flag = false;//表示是否找到该节点
        while (true) {
            if (temp == null) {
                break; //表示已经遍历该链表
            } else if (temp.val == val) {
                flag = true;
                break;
            }
            temp = temp.next;
        }
        if (flag) {//根据flag判断是否找到要修改的节点
            temp.val = target;
        } else {//没有找到val为val的节点
            System.out.println("没有找到val为" + val + "的节点");
        }

    }

    /*
    删除节点:(将val为val的节点删除)
    思路:
    1.head不能动,因此我们需要一个辅助节点temp找到待删除节点的上一个节点
    2.我们在比较时 要用 temp.next.val和需要删除的节点的val作比较
     */
    public void delete(int val) {
        if (head.next == null) {
            System.out.println("链表为空,不能删除");
        }
        Node temp = head;
        boolean flag = false;//表示是否找到待删除节点
        while (true) {
            if (temp.next == null) {//表示已经到了链表的最后
                break;
            }
            if (temp.next.val == val) {//表示找到待删除节点的前一个节点
                flag = true;
                break;
            }
            temp = temp.next;
        }
        if (flag) { //说明找到要删除的节点
            temp.next = temp.next.next;
        } else {  //说明没有找到要删除的节点不存在
            System.out.println("要删除的节点不存在");
        }
    }


    //第二种方式添加节点到单链表中(根据val的大小添加节点到指定位置)
    public void addByVal(Node node) {
        //因为head节点不能动,因此我们需要一个辅助节点(指针)来帮助找到添加的位置;
        //因为单链表,因此我们找的temp 是位于添加位置的前一个节点,否则插入不了;
        Node temp = head;
        boolean flag = false;//标志添加的val是否已经存在,默认为false;
        while (true) {
            if (temp.next == null) {//说明temp已经在链表的最后
                break;
            }
            if (temp.next.val > node.val) {//说明位置已经找到,就在temp的后面插入
                break;
            } else if (temp.next.val == node.val) {//说明添加的节点的val已经存在;
                flag = true;
                break;
            }
            temp = temp.next;//后移,遍历当前链表
        }
        if (flag) {//说明添加的节点的val已经存在;我们可以让它不添加,也可以让它添加,这里我选择不添加
            System.out.println("准备插入的节点的val为" + node.val + "已经存在,不能加入\n");
        } else {
            //插入到链表中,temp的后面
            node.next = temp.next;
            temp.next = node;
        }
    }

    //显示链表,遍历链表
    public void showList() {
        //先判断链表是否为空
        if (head.next == null) {
            System.out.println("链表为空");

        } else {
            Node temp = head.next;
            while (true) {
                if (temp == null) {
                    break;
                } else {

                    System.out.println(temp);
                    //将temp后移
                    temp = temp.next;
                }
            }
        }
    }

    public static void main(String[] args) {
        MyselfLinkedList myselfLinkedList = new MyselfLinkedList();
        MyselfLinkedList myselfLinkedList1 = new MyselfLinkedList();
        Node node = new Node(1);
        Node node1 = new Node(2);
        Node node2 = new Node(1);
        Node node3 = new Node(3);
        Node node4 = new Node(7);
        Node node5 = new Node(6);
        Node node6 = new Node(4);
        //测试add方法
        myselfLinkedList.add(node);
        myselfLinkedList.add(node1);
        myselfLinkedList.add(node2);
        myselfLinkedList.add(node3);
        myselfLinkedList.add(node4);
        myselfLinkedList.add(node5);
        myselfLinkedList.add(node6);
        myselfLinkedList.showList();
        System.out.println("|||||||||||||||||||||||||||||||||||||||||||||||");

        //测试addByVal方法
        myselfLinkedList1.addByVal(node);
        myselfLinkedList1.addByVal(node1);
        myselfLinkedList1.addByVal(node2);
        myselfLinkedList1.addByVal(node3);
        myselfLinkedList1.addByVal(node4);
        myselfLinkedList1.addByVal(node5);
        myselfLinkedList1.addByVal(node6);
        myselfLinkedList1.showList();
        System.out.println("|||||||||||||||||||||||||||||||||||||||||||||||");

        //测试修改节点的代码
        myselfLinkedList.update(1, 3);
        myselfLinkedList.showList();//遍历修改后的myselfLinkedList
        System.out.println("|||||||||||||||||||||||||||||||||||||||||||||||");

        //测试删除节点的代码
        myselfLinkedList.delete(3);
        myselfLinkedList.delete(2);
        myselfLinkedList.delete(1);
        myselfLinkedList.delete(3);
        myselfLinkedList.delete(7);
        myselfLinkedList.delete(6);
        myselfLinkedList.delete(4);
        myselfLinkedList.showList();
    }

}


class Node {
    public int val;
    public Node next;//指向下一个节点

    public Node(int val) {
        this.val = val;
    }

    @Override
    public String toString() {
        return "Node{" +
                "val=" + val +
                ", next=" + next +
                '}';
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值