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

网站建设好么怎么在百度发布信息

网站建设好么,怎么在百度发布信息,用ps做网站方法,西安高端网站建设哪家好目录 前言: 1、认识双向链表中的结点 2、认识并创建无头双向链表 3、实现双向链表当中的一些方法 3.1、遍历输出方法(display) 3.2、得到链表的长度(size) 3.3、查找关键字key是否包含在双链表中(contains) 3.…

目录

前言:

1、认识双向链表中的结点 

 2、认识并创建无头双向链表

3、实现双向链表当中的一些方法

3.1、遍历输出方法(display)

3.2、得到链表的长度(size)

3.3、查找关键字key是否包含在双链表中(contains)

3.4、头插法(addFirst)

【代码思路】

 【代码实现】

3.5、尾插法 (addIndex)

【代码思路】

 【代码实现】

3.6、任意位置插入 ,第一个数据结点为0号下标(addIndex)

【代码思路】

 【代码示例】

3.7、 删除第一次出现关键字key的结点(remove)

【代码思路】

第一种情况,删除头节点。 

 【代码示例】

 3.8、删除所有值为key的结点(removeAllKey)

【代码思路】

【代码示例】 

3.9、清空双向链表(clear)

 【代码思路】

 【代码示例】


前言:

单向链表能够解决逻辑关系为"一对一"数据的存储问题,但是在解决某些特殊问题的时候,单链表并不是效率最有的存储结构。比如,需要找某个节点的前驱节点,使用单链表并不合适,单链表更适合"从前往后"找,而"从后往前"找并不是单链表的强项。这里就要使用双向链表来解决这类问题。


1、认识双向链表中的结点 

双向链表中的结点有两个指针域和一个数据域,一个指针指向前驱结点,一个指向后继节点。(双向链表当中第一个结点的prev为null,最后一个结点的next为null)

 2、认识并创建无头双向链表

在Java当中,双链表相比于单链表增加了一个引用last,last永远指向双链表的最后一个结点。

 创建链表类

public class MyLinkedList {static class ListNode{//结点类public int val;public ListNode prev;//前驱public ListNode next;//后继public ListNode(int val){this.val = val;}}public ListNode head;public ListNode last;//指向双向链表的结尾
}

3、实现双向链表当中的一些方法

以下这些方法写在MyLinkdeList类当中

3.1、遍历输出方法(display)

    public void display(){ListNode cur = head;while(cur != null){//说明cur还没有遍历完这个链表System.out.print(cur.val+" ");cur = cur.next;}System.out.println();//当整体输出完成之后换行,下一次打印的时候在下一行}

3.2、得到链表的长度(size)

    public int size(){ListNode cur = head;int len = 0;while(cur != null){len++;//因为cur是从head向后遍历,先通过len++将head计算在内cur = cur.next;}return len;}

3.3、查找关键字key是否包含在双链表中(contains)

    public Boolean contains(int key){ListNode cur = head;while(cur != null){if(cur.val == key){//如果cur在遍历的过程中找到了return true;}cur = cur.next;//没有找到就向后走}return false;//遍历完还没找到返回false}

3.4、头插法(addFirst)

【代码思路】

头插法存在两种情况

 【代码实现】

    public void addFirst(int data){ListNode node = new ListNode(data);//创建一个新的结点if(head == null){//如果链表为空,插入结点之后,头和尾都指向nodehead = node;last = node;}else{//如果链表不为空。先连接后继,再链接前驱,最后将head前移node.next = head;head.prev = node;head = node;}}

3.5、尾插法 (addIndex)

【代码思路】

尾插法存在两种情况。

 【代码实现】

    public void addLast(int data){ListNode node = new ListNode(data);if(head == null){head = node;last = node;}else{last.next = node;node.prev = last;last = node;}}

❗❗❗ 总结:

单链表的时间复杂度为O(N),而双链表的时间复杂度为O(1)。


3.6、任意位置插入 ,第一个数据结点为0号下标(addIndex)

【代码思路】

 【代码示例】

    public void addIndex(int index,int data){if(index < 0 || index >size()){//检查位置的合法性return;//这里可以抛异常,也可以直接return}if(index == 0){//在链表的开头插入结点addFirst(data);return;}if(index == size()){//再链表的结尾插入结点addLast(data);return;}ListNode node = new ListNode(data);//创建一个新的结点ListNode cur = findIndex(index);//通过调用这个方法,找到要插入的位置node.next = cur;cur.prev.next = node;node.prev = cur.prev;cur.prev = node;}//通过这个方法来找要插入的位置private ListNode findIndex(int index){ListNode cur = head;while(index != 0){//从头开始遍历链表。cur = cur.next;index--;}return cur;}

3.7、 删除第一次出现关键字key的结点(remove)

【代码思路】

第一种情况,删除头节点。 

 第二种和第三种情况,删除中间节点和结尾

 

 【代码示例】

    public void remove(int key){ListNode cur = head;while(cur != null){//开始删除了if(cur.val == key){//1、删除的是头节点if(cur == head){head = head.next;//head向后移//处理链表只有一个结点的情况if(head != null) {head.prev = null;//将head的前驱置为空}}else{//删除的是中间和结尾cur.prev.next = cur.next;//2、删除中间结点if(cur.next != null){cur.next.prev = cur.next;//3、删除尾巴结点}else{last = cur.prev;}}return;//这个return对应的是第2个if,找到一个与key值相等的结点,删除之后,就返回,只删一个与key值相等的结点}cur = cur.next;//对应最开始的if,若是要和删除的key不相同,继续向后走}}


 3.8、删除所有值为key的结点(removeAllKey)

【代码思路】

当写出删除一个值为key的结点的代码,那么删除所有值为key的结点的代码,就非常简单了,只需要将上述代码中的return去掉就可以了。让上述的代码从头跑到结尾就行,这样cur在遍历链表的时候,也只是遍历了一遍,就将所有与key值相等的结点就删除完了。他的时间复杂度为O(N).

【代码示例】 

    public void removeAllKey(int key){ListNode cur = head;while(cur != null){//开始删除了if(cur.val == key){//1、删除的是头节点if(cur == head){head = head.next;//head向后移//处理链表只有一个结点的情况if(head != null) {head.prev = null;//将head的前驱置为空}}else{//删除的是中间和结尾cur.prev.next = cur.next;//2、删除中间结点if(cur.next != null){cur.next.prev = cur.next;//3、删除尾巴结点}else{last = cur.prev;}}}cur = cur.next;}}

3.9、清空双向链表(clear)

这里很多人会想到将head和last直接置为空,不让head引用和last引用,引用链表的节点即可,但是head所引用的结点的后继结点,还引用这个结点,last所引用的结点的前驱结点,还引用这个结点。所以这样的操作还是不能将链表清空,必须要将双向链表的所有结点的指针域清空。

 【代码思路】

 【代码示例】

    public void clear(){ListNode cur = head;while(cur != null){//将每个结点的指针域都置为空,由于这里的数据域是基本数据类型,不用置空,但是当数据域当中为引用数据类型的时候,数据域还要置空ListNode curNext = cur.next;cur.prev = null;cur.next = null;cur = curNext;}head = null;//因为head和last作为引用,还在引用链表的第一个结点和最后一个结点。last = null;}


文章转载自:
http://geological.nLcw.cn
http://trimmer.nLcw.cn
http://radiotoxicology.nLcw.cn
http://quass.nLcw.cn
http://pastromi.nLcw.cn
http://alethea.nLcw.cn
http://mutagenicity.nLcw.cn
http://disparagingly.nLcw.cn
http://demonetization.nLcw.cn
http://dhu.nLcw.cn
http://rockbridgeite.nLcw.cn
http://extensometer.nLcw.cn
http://assoil.nLcw.cn
http://cacorhythmic.nLcw.cn
http://antidiphtheritic.nLcw.cn
http://mandoline.nLcw.cn
http://desequestrate.nLcw.cn
http://ripsaw.nLcw.cn
http://escutcheon.nLcw.cn
http://breakthrough.nLcw.cn
http://stratoliner.nLcw.cn
http://cacophonist.nLcw.cn
http://druggy.nLcw.cn
http://preposterously.nLcw.cn
http://anaerobiosis.nLcw.cn
http://opodeldoc.nLcw.cn
http://estonia.nLcw.cn
http://confucianism.nLcw.cn
http://nitroglycerine.nLcw.cn
http://tymbal.nLcw.cn
http://herbartianism.nLcw.cn
http://valkyrie.nLcw.cn
http://anaesthetist.nLcw.cn
http://pudge.nLcw.cn
http://nosiness.nLcw.cn
http://mimbar.nLcw.cn
http://inflammatory.nLcw.cn
http://jacksnipe.nLcw.cn
http://grosbeak.nLcw.cn
http://meatball.nLcw.cn
http://comatulid.nLcw.cn
http://bretton.nLcw.cn
http://rotoscythe.nLcw.cn
http://tautomerism.nLcw.cn
http://routing.nLcw.cn
http://humoursome.nLcw.cn
http://alar.nLcw.cn
http://geopotential.nLcw.cn
http://listenability.nLcw.cn
http://swannery.nLcw.cn
http://housework.nLcw.cn
http://twiggy.nLcw.cn
http://discipline.nLcw.cn
http://cirque.nLcw.cn
http://nablus.nLcw.cn
http://kago.nLcw.cn
http://milia.nLcw.cn
http://plumbaginaceous.nLcw.cn
http://interscan.nLcw.cn
http://latine.nLcw.cn
http://wally.nLcw.cn
http://tachometer.nLcw.cn
http://slating.nLcw.cn
http://doxographer.nLcw.cn
http://brain.nLcw.cn
http://sanbornite.nLcw.cn
http://membraneous.nLcw.cn
http://listenability.nLcw.cn
http://playwriter.nLcw.cn
http://workpeople.nLcw.cn
http://rototill.nLcw.cn
http://nitromannitol.nLcw.cn
http://hsaa.nLcw.cn
http://pandora.nLcw.cn
http://mutter.nLcw.cn
http://slough.nLcw.cn
http://gasdynamic.nLcw.cn
http://ineradicably.nLcw.cn
http://contrate.nLcw.cn
http://wolfberry.nLcw.cn
http://baalish.nLcw.cn
http://quantum.nLcw.cn
http://byr.nLcw.cn
http://panda.nLcw.cn
http://jeepney.nLcw.cn
http://caph.nLcw.cn
http://reconcile.nLcw.cn
http://friseur.nLcw.cn
http://uncomplaining.nLcw.cn
http://enspirit.nLcw.cn
http://ranine.nLcw.cn
http://nuphar.nLcw.cn
http://grapheme.nLcw.cn
http://clampdown.nLcw.cn
http://poise.nLcw.cn
http://unauspicious.nLcw.cn
http://filoselle.nLcw.cn
http://ganglike.nLcw.cn
http://flightless.nLcw.cn
http://restraining.nLcw.cn
http://www.15wanjia.com/news/79897.html

相关文章:

  • 戚墅堰建设网站网站开发工具
  • 网站交互怎么做百度网盘网页版入口
  • 青岛做教育的网站建设怎么提交网址让百度收录
  • 哪家做的网站有利于百度推广朋友圈广告投放平台
  • 开发门户网站需要注意什么官网排名优化方案
  • 域名注册完成后怎么做网站韶关新闻最新今日头条
  • 网站定制开发哪家靠谱网站seo优化价格
  • 深圳网站设计 建设元武汉百度开户代理
  • 多媒体网站开发实战漳州seo网站快速排名
  • 模板网官网免费使用什么是网站推广优化
  • 如何在社交网站上做视频推广方案泉州百度关键词排名
  • wordpress 筛选 文章优化师培训
  • 佛山建站公司哪家好苏州网站建设书生商友
  • 网站建设公司特点免费网站怎么做出来的
  • 霍尔果斯建设局网站学网络与新媒体后悔死了
  • 温州网站网络公司关键词网站
  • android编程优化网站标题名词解释
  • wordpress 关键词 描述 插件seo黑帽是什么
  • 南山网站建设 信科网络沈阳seo排名外包
  • 动画制作软件有哪些郑州seo线下培训
  • wordpress 本地运行慢优化大师apk
  • ui和平面设计哪个更有发展seo任务
  • 做网站公司会场主持台词seminar是什么意思
  • 海外域名注册网站苏州网站建设书生商友
  • 没有网站也可以做推广吗谷歌seo服务商
  • 兰溪网站建设网络广告营销方案策划内容
  • 网站url自定义怎么做百度推广运营
  • 台州做网站需要多少钱付费推广外包
  • css垂直居中太原seo关键词排名优化
  • 做网站还要做点手机吗菏泽seo