【剧前爆米花--爪哇岛寻宝】Java实现无头单向非循环链表和无头双向链表与相关题目
创始人
2024-05-31 11:58:46
0

作者:困了电视剧

专栏:《数据结构--Java》

文章分布:这是关于数据结构链表的文章,包含了自己的无头单向非循环链表和无头双向链表实现简单实现,和相关题目,想对你有所帮助。

 

 

目录

无头单向非循环链表实现

无头双向链表实现

链表的相关题目

移除链表元素

反转一个单链表

链表的中间结点

链表中倒数第k个结点


无头单向非循环链表实现

public class SingleLinkedList {static class Node {public int val;//存储的数据public Node next;//存储下一个节点的地址//public Node(){}public Node (int val) {this.val = val;}}public Node head;public int size=0;//头插法public void addFirst(int data){Node node = new Node(data);node.next=head;head = node;size++;}//尾插法public void addLast(int data){Node node = new Node(data);if ( head==null ){head=node;return;}Node tmp=head;while ( tmp.next!=null ){tmp=tmp.next;}tmp.next=node;size++;}//任意位置插入,第一个数据节点为0号下标public boolean addIndex(int index,int data){//先判断idx是否合法if ( index>size||index<0 ){return false;}if ( head==null ){return false;}Node node = new Node(data);Node cur=head;int cnt=0;while ( cnt!=index ){cur=cur.next;cnt ++;}node.next=cur.next;cur.next=node;return true;}//查找是否包含关键字key是否在单链表当中public boolean contains(int key){if ( head==null ){return false;}Node cur = head;while ( cur!=null ){if ( cur.val==key ){return true;}cur=cur.next;}return false;}//删除第一次出现关键字为key的节点public void remove(int key){if ( head==null ){return;}if ( head.val==key ){head=head.next;return;}Node cur = head;while ( cur.next!=null ){if ( cur.next.val==key ){cur.next=cur.next.next;return;}cur=cur.next;}}//删除所有值为key的节点public void removeAllKey(int key){if ( head==null ){return;}Node pre=head;Node cur=head.next;while ( cur!=null ){if ( cur.val==key ){cur=cur.next;pre.next=cur;}else{pre=cur;cur=cur.next;}}if ( head.val==key ){head=head.next;}return;}//得到单链表的长度public int size(){return this.size;}public void display(){if ( head==null ){return;}Node cur=head;while ( cur!=null ){System.out.println(cur.val+" ");}}public void clear(){head=null;}
}

无头双向链表实现

public class MyLinkedList {//内部类构造一个链表数据结构static class ListNode{public int val;public ListNode prev;public ListNode next;public ListNode(){}public ListNode(int val){this.val=val;}}private ListNode first;private ListNode last;private int size=0;MyLinkedList(){}//头插法public void addFirst(int data){ListNode node=new ListNode(data);if ( first==null ){first=node;last=node;}else{node.next=first;first.prev=node;first=node;}size++;}//尾插法public void addLast(int data){ListNode node=new ListNode(data);if ( first==null ){first=node;last=node;}else{last.next=node;node.prev=last;last=node;}size++;}//任意位置插入,第一个数据节点为0号下标public boolean addIndex(int index,int data){//判断这个index是否合法if ( index<0 || index>size ){return false;}ListNode node=new ListNode(data);ListNode cur=first;for ( int i=0;i

链表的相关题目

移除链表元素

https://leetcode.cn/problems/remove-linked-list-elements/description/

class Solution {public ListNode removeElements(ListNode head, int val) {if ( head==null ){return null;}ListNode pre=head;ListNode cur=head.next;while ( cur!=null ){if ( cur.val==val ){cur=cur.next;pre.next=cur;}else{pre=cur;cur=cur.next;}}if ( head.val==val ){head=head.next;}return head;}
}

反转一个单链表

https://leetcode.cn/problems/reverse-linked-list/description/

将每一个结点的指向翻转一下,不需要重新遍历什么的。

class Solution {public ListNode reverseList(ListNode head) {if ( head==null ){return null;}ListNode cur = head.next;ListNode pre = head;pre.next = null;while ( cur != null ){ListNode nextNode = cur.next;cur.next = pre;pre = cur;cur = nextNode;}return pre;}
}

链表的中间结点

https://leetcode.cn/problems/middle-of-the-linked-list/description/

用快慢指针可以在O(n)的时间复杂度完成。

class Solution {public ListNode middleNode(ListNode head) {if ( head == null ){return null;}ListNode slow = head;ListNode fast = head;while (fast != null && fast.next != null){slow = slow.next;fast = fast.next.next;}return slow;}
}

链表中倒数第k个结点

https://www.nowcoder.com/practice/529d3ae5a407492994ad2a246518148a?tpId=13&&tqId=11167&rp=2&ru=/activity/oj&qru=/ta/coding-interviews/question-ranking

用快慢指针的方法,快指针先跑k个,然后慢指针和快指针再按相同的速度跑 

public class Solution {public ListNode FindKthToTail(ListNode head,int k) {if ( head == null ){return null;}ListNode fast = head;ListNode slow = head;while (k != 0){if (fast != null){fast = fast.next;k--;}else{return null;}}while ( fast != null ){slow = slow.next;fast = fast.next;}return slow;}
}

 

相关内容

热门资讯

苏轼的诗句都有哪些 苏轼的诗句都有哪些  苏轼的诗句都有哪些呢,大家感兴趣了解一下吗?以下是小编为大家整理的关于苏轼的诗...
张爱玲经典语录 张爱玲经典语录100句  在日常的学习、工作、生活中,许多人都接触或是使用过一些比较经典的语录吧,语...
乍咽凉柯,还移暗叶,重把离愁... “乍咽凉柯,还移暗叶,重把离愁深诉。”出处 出自 宋代 王沂孙 的《齐天乐·蝉》“乍咽凉柯,还移暗叶...
“一径穿缘应就郭,千花掩映似... “一径穿缘应就郭,千花掩映似无溪。”这两句是说,一条幽僻的路径,缘山通向寺院的墙外;溪水两旁百花盛开...
“远钟惊漏压,微月被灯欺”的... “远钟惊漏压,微月被灯欺。”这两句是说,滴漏声可以压倒远方的钟声,近处的灯光比微弱的残月还亮。喻事物...
“蝉噪林逾静,鸟鸣山更幽”的... 蝉噪林逾静下一句鸟鸣山更幽出自南朝梁·王籍《入若邪溪》入若邪溪诗   艅艎何泛泛,空水共悠悠。  阴...
经典诵读的诗句 经典诵读的诗句  有关经典诵读的'诗句  1. 诗经·关雎  关关雎鸠,在河之洲。窈窕淑女,君子好逑...
唯美清纯诗句 唯美清纯诗句  导语:谁的眼泪湿了谁的心 谁的`眼角触了谁的眉,下面是小编给大家带来唯美清纯诗句,欢...
“种竹交加翠,栽桃烂熳红。”... “种竹交加翠,栽桃烂熳红。”这两句是说,自己种的竹子,长得十分茂盛,翠绿之色,交相辉映;栽的桃树花开...
张小娴作品《爸爸的味道》原文 张小娴作品《爸爸的味道》原文  每个人身上都有一种独特的气味,日子久了,那种气味就代表他。  F说,...
杜甫的《江汉》原文赏析 杜甫的《江汉》原文赏析  杜甫唐五言律诗:《江汉》原文:  江汉思归客,乾坤一腐儒。  片云天共远,...
小学五年级的必背古诗词 小学五年级的必背古诗词  古今中外的文学家用丰富的词汇、审美的语感、神奇的表现手法塑造了无数不朽表现...
《除夜雪》 南宋 陆游 《除夜雪》 南宋 陆游  无论是在学校还是在社会中,大家或多或少都接触过一些经典的古诗吧,古诗具有格...
绝美情诗 绝美情诗  引导语:相濡以沫,不如相忘于江湖……下面由yjbys小编精心为您整理了一些绝美情诗,希望...
“秋草不堪频送远,白云何处更... “秋草不堪频送远,白云何处更相期”这两句是说,在秋草枯黄的季节,为友人送行,送了一程又一程,离恨难堪...
于描写清明节诗句 于描写清明节诗句  导语:清明节是缅怀故人的.日子,是充满悲伤之日,这一天连老天爷都与我们这些失去至...
劝君莫惜金缕衣全诗   劝君莫惜金缕衣全诗  《金缕衣》  作者:杜秋娘  原文:  劝君莫惜金缕衣,劝君惜取少年时。 ...
怀古,怀古王冕,怀古的意思,... 怀古,怀古王冕,怀古的意思,怀古赏析 -诗词大全 怀古 作者:王冕朝代:元体裁:七律 浮云...
听泉,听泉齐己,听泉的意思,... 听泉,听泉齐己,听泉的意思,听泉赏析 -诗词大全 听泉 作者:齐己朝代:唐体裁:五律 落石...