当前位置: 首页 > news >正文

成都网站制作服务网站做产品的审核吗

成都网站制作服务,网站做产品的审核吗,免费qq空间访客网站,山东网站制作公司排名文章目录 前言什么是链表链表的结构带头和不带头的区别 链表的实现(方法)遍历链表头插法尾插法任意位置插入一个节点链表中是否包含某个数字删除链表某个节点删除链表中所有关键字key清空链表所有节点 ArrayList 和 LinkedList的区别总结 前言 什么是链…

文章目录

  • 前言
    • 什么是链表
    • 链表的结构
    • 带头和不带头的区别
  • 链表的实现(方法)
    • 遍历链表
    • 头插法
    • 尾插法
    • 任意位置插入一个节点
    • 链表中是否包含某个数字
    • 删除链表某个节点
    • 删除链表中所有关键字key
    • 清空链表所有节点
  • ArrayList 和 LinkedList的区别
  • 总结


前言

什么是链表

含义:链表是一种物理存储结构上非连续存储结构,数据元素的逻辑顺序是通过链表中的引用链接次序实现的 。

图形解释:
逻辑上是连续的,但物理上看起来不连续
这个图形也叫单向不带头非循环
在这里插入图片描述

链表的结构

非常多样,有8种结构
在这里插入图片描述
在这里插入图片描述

重点掌握下面两种:

无头单向非循环链表:结构简单,一般不会单独用来存数据。实际中更多是作为其他数据结构的子结构,如哈希桶、图的邻接表等等。另外这种结构在笔试面试中出现很多。

无头双向链表:在Java的集合框架库中LinkedList底层实现就是无头双向循环链表。

带头和不带头的区别

在这里插入图片描述

链表的实现(方法)

在这里插入图片描述

在这里插入图片描述
定义接口

public interface ILIst {// 1、无头单向非循环链表实现//头插法void addFirst(int data);//尾插法void addLast(int data);//任意位置插入,第一个数据节点为0号下标void addIndex(int index,int data);//查找是否包含关键字key是否在单链表当中public boolean contains(int key);//删除第一次出现关键字为key的节点void remove(int key);//删除所有值为key的节点void removeAllKey(int key);//得到单链表的长度int size();void clear();void display();
}

遍历链表

在这里插入图片描述

1.怎么从一个节点走到下一个节点
head = head.next

2.怎么判断所有节点遍历完了
当head = null 循环结束


//            while(head != null){
//                System.out.print(head.val+" ");
//                head = head.next;
//            }//这个方法遍历完head=null,会导致链表空了,找不到第一个节点在哪了
//所以应该把head赋值给一个数,让它去遍历,相当于head的分身,分身消失了,主体head还在ListNode cur = this.head;//进入循环条件为链表不为空//也就是说当head为空时,循环结束while(cur != null){System.out.print(cur.val+" ");cur =cur.next;}

头插法

    //头插法//时间复杂度O(1)@Overridepublic void addFirst(int data) {//先实例化一个节点ListNode node = new ListNode(data);//如果链表没有节点,那么插入的这个节点就是第一个节点//所以head = nodeif (this.head ==null){this.head = node;}else {node.next = this.head;this.head = node;}}

在这里插入图片描述

尾插法

在这里插入图片描述

    //尾插法:在最后创建一个节点//时间复杂度O(N)@Overridepublic void addLast(int data) {//创建一个新节点ListNode node = new ListNode(data);ListNode cur = this.head;//当链表为空时,此案件的新节点就是第一个节点if (this.head == null){this.head = node;}else {//让cur遍历完走到cur.next为空时,才找到了最后一个节点//意思就是走出了while循环,就说明cur走到了最后一个节点上while (cur.next != null){cur = cur.next;}cur.next = node;node.next =null;}}

在这里插入图片描述

任意位置插入一个节点

在这里插入图片描述

    //让cur去到index-1位置private ListNode searchPrev(int index){ListNode cur = this.head;int count =0;while(count != index-1){cur = cur.next;count++;}//循环走完, cur已经走到index-1得位置了return cur;}//任意位置插一个节点@Overridepublic void addIndex(int index, int data) {ListNode node = new ListNode(data);//检查index得合法性if (index < 0 || index > size()){//抛自定义异常return ;}//如果index=0 头插法if (index == 0){addFirst(data);return;}//如果index=size,尾插法if (index == size()){addLast(data);return;}ListNode cur =  searchPrev(index);//调用cur走到index-1的方法node.next = cur.next;cur.next = node;}

链表中是否包含某个数字

    //链表是否包含某个数字@Overridepublic boolean contains(int key) {ListNode cur = this.head;while(cur != null){if (cur.val == key){return true;}cur = cur.next;}return false;}@Overridepublic void remove(int key) {}

删除链表某个节点

在这里插入图片描述

    //让cur走到要删除的节点的前一个节点private ListNode findPrev(int key){ListNode cur = this.head;//判断条件是cur不能超过倒数二个节点while(cur.next != null ){if (cur.next.val == key){return cur;}cur = cur.next;}return null;}@Overridepublic void remove(int key) {//如果链表为空,无法删除if (this.head == null){return ;}//如果要删除第一个节点if (this.head.val ==key){this.head = this.head.next;return;}//判断前驱ListNode cur = findPrev(key);//判断返回值是否为空if (cur == null){System.out.println("没有你要删除的数字!");return ;}//删除ListNode del = cur.next;cur.next = del.next;}

删除链表中所有关键字key

在这里插入图片描述

    //删除链表中所有关键字key@Overridepublic void removeAllKey(int key) {if (this.head == null){return;}ListNode prev = this.head;ListNode cur = this.head.next;while(cur != null){if (cur.val == key){prev.next = cur.next;cur = cur.next;}else{prev = cur;cur = cur.next;}}if (this.head.val == key){this.head = head.next;}}

清空链表所有节点

在这里插入图片描述

    public void clear() {ListNode cur = this.head;while(cur != null){ListNode curNext  = cur.next;cur.next =null;cur = curNext;}this.head = null;}

ArrayList 和 LinkedList的区别

在这里插入图片描述

总结

以上就是关于链表的详细知识。

http://www.yayakq.cn/news/755843/

相关文章:

  • 电子商务网站建设预算进度环wordpress
  • 有个性的个人网站网站是怎么建立起来的
  • 南乐网站开发随申行是国企嘛?
  • 基层建设检索网站外贸软件哪个好
  • 北京网站模板建站网站建设需要ftp
  • 哪些网站用黑体做的河北省住房和城乡建设厅网站查
  • 手机网站做的比较好的官网怎么进入
  • 哈尔滨免费做网站静态html网址网站导航源码
  • 做算命网站挣钱么系统网站建设需求分析
  • 做一个网站的基本步骤做评测好的视频网站有哪些
  • 谷城做网站wordpress 站外调用
  • 网站建设预期达到的效果推广宣传方式有哪些
  • 网络公司经营范围许可网站做seo外链
  • 河南城乡建设厅网站证书查询好的外贸平台
  • 郑州做网站优化的公司网站设计做图工具
  • 文学类网站模板互联网站产品开发的流程
  • 成都哪家做网站公司好wordpress主题+插件下载
  • 从事网站开发需要的证书建设网站要买空间吗
  • 手机端网站 优帮云建设网站需要服务器
  • 企业网站的分类淮南做网站
  • 建设网站项目总结网页设计答辩问题及答案
  • 手机端企业网站设计网站如何做视频链接
  • 一般网站建设流程有哪些步骤室内空间设计
  • 怎样找做淘宝客的网站网站标题名字和备案名字
  • 石家庄网站建设推广公司哪家好北京高校线上教学
  • 怎么给网站做支付接口中国四大咨询公司
  • 公司信息化网站建设实施方案福州企业网站建站系统
  • 怎么开通网站平台简述网络营销的推广方法
  • 静态网页怎么做网站江苏省建设工程信息一体化平台
  • asp.net网站开发视频教程wordpress附件插件