美文网首页
链表之单向链表

链表之单向链表

作者: 砌月东谷 | 来源:发表于2021-07-11 08:31 被阅读0次

链表的机制灵活,用途广泛,它适用于许多通用的数据库。它也可以取代数据,作为其他存储结构的基础,例如栈和队列,除非需要频繁通过下标随机访问各个数据,否则在很多适用数组的地方都可以用链表代替。

链接点(Link)

在链表中,每个数据项都被包含在链接点中。一个链接点是某个类的对象,这个类可以叫做Link。因为一个链表中有许多类似的链接点,所以有必要用一个不同于链表的类来表达链接点。每个Link对象中毒包含一个对下一个链接点引用的字段,通常叫做next,但是链表本身对象中有一个字段指向对第一个链接点的引用

单链表的实现

public class Link {
    public int iData;
    public double dData;
    public Link next;

    public Link(int id,double dd){
        iData=id;
        dData=dd;
    }

    public void displayLink(){
        System.out.println("{"+iData+","+dData+"}");
    }
}


class LinkList{
    private Link first;

    public LinkList(){
        first=null;
    }

    public boolean isEmpty(){
        return (first==null);
    }

    public void insertFirst(int id ,double dd){
        Link newLink=new Link(id,dd);
        newLink.next=first;
        first=newLink;
    }

    public Link deleteFirst(){
        Link tmp=first;
        first=first.next;
        return tmp;
    }

    public void displayList(){
        Link current=first;
        while(current!=null){
            current.displayLink();
            current=current.next;
        }
    }

    public Link find(int key){
        Link current=first;
        while (current.iData!=key){
            if(current.next==null){
                return null;
            }else{
                current=current.next;
            }
        }
        return current;
    }

    public Link delete(int key){
        Link current=first;
        Link previous=first;
        while (current.iData!=key){
            if(current.next==null){
                return null;
            }else{
                previous=current;
                current=current.next;
            }
        }
        if(current==first){
            first=first.next;
        }else{
            previous.next=current.next;
        }
        return current;
    }

    public static void main(String[] args) {
        LinkList linkList=new LinkList();

        linkList.insertFirst(22,2.2);
        linkList.insertFirst(44,4.3);

        linkList.displayList();
//
//        while(!linkList.isEmpty()){
//            Link link=linkList.deleteFirst();
//            System.out.println("deleted");
//            link.displayLink();
//        }
//        linkList.displayList();

        Link link = linkList.find(44);

        if(link!=null){
            System.out.println("find it"+link.iData);
        }else{
            System.out.println("not find link");
        }

        Link d=linkList.delete(44);
        if(d!=null){
            System.out.println("delete"+d.iData);
        }else{
            System.out.println("not delete");
        }
        linkList.displayList();
    }
}

find()方法

find()方法中被称为current的变量开始时指向first,然后通过不断地把自己复制给current.next,沿着链表向前移动,在每个链接点处,find()检查链表节点的关键之是否和它寻找的相等,如果找到了,它返回对该链接点的引用。如果find()到达链表的尾端,但没有发现要找的链接点,则返回null

delete()方法

delete()方法和find()方法类似,它先搜索要删除的链接点。然而它需要掌握的不仅是指向当前链接点的引用,还有指向当前链接点的前一个(previous)链接点的引用,这是因为,如果要删除当前的链接点必须把前一个链接点和后一个链接点连在一起,知道前一个链接点位置的唯一方法是拥有一个对它的引用

在while语句的每一次循环中,每当current变量赋值为current.next之前,先把previous变量赋值为current,这保证了它总数指向current所指链接点的前一个链接点,一旦发现当前链接带你是要被删除的链接点,就把前一个链接点的next字段赋值为当前链接点的下一个链接点。如果当前链接点是第一个链接点,这是一种特殊情况,因为这是由LinkList对象的first指向的链接点,而不是别的链接点的next字段所指的,在这种情况下,使first字段指向first.next,就可以删除第一个链接点

相关文章

  • 8.单向链表SingleLinkList

    目录:1.单向链表的定义2.单向链表的图解3.单向链表定义操作4.单向链表的实现 1.单向链表的定义 2.单向链表...

  • 2019-12-04 Java-LinkedList源码解读

    @TOC 1、链表数据结构 链表分为单向链表和双向链表,他们的区别在于,单向链表只能单向寻址,而双向链表可以双向寻...

  • 10.单向循环链表SingleCycleLinkList

    目录:1.单向循环链表的定义2.单向循环链表的图解3.单向循环链表定义操作4.单向循环链表的实现 1.单向循环链表...

  • 数据结构与算法——线性表3

    线性表——单向循环链表 3、单向循环链表 在单向链表的基础上,单向链表的尾结点的Next指向链表的头部,就是为循环...

  • 数据结构基础--单向循环链表

    单向循环链表 单向循环链表是可循环的单链表,它与单链表的区别在于单向链表的最后一个元素的指针域为空,而单向循环链表...

  • 线性表-单向循环链表

    为了方便,本文介绍的单向循环链表不包含头节点 单向循环链表内容 单向循环链表的的定义 单向循环链表的创建 单向循环...

  • 数据结构与算法之循环链表(3.4)

    目录 单向循环链表双向循环链表约瑟夫问题如何发挥循环链表的最大威力? 一 单向循环链表 单向循环链表 - 只有一个...

  • 04单向循环链表实现总结

    一、说说什么是单向循环链表? 人狠话不多. 上图. 单向循环链表就是这个样子!单向循环链表.png 与单向链表区别...

  • 算法与数据结构:链表

    链表 链表还分为单向链表和双向链表, 但是这篇文章只说单向链表 , 下次再讲双向链表 . 链表和数组的区别 ? 链...

  • day03-双向链表

    双向链表: 单向链表只能单向查找,双向链表可以双向查找。 啥是双向链表? 双向链表可以双向查数据,所以就不存在单向...

网友评论

      本文标题:链表之单向链表

      本文链接:https://www.haomeiwen.com/subject/bxqkpltx.html