java简单算法:删除排序链表中的重复元素
2022/7/6 14:23:37
本文主要是介绍java简单算法:删除排序链表中的重复元素,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
问题
- 给定一个已排序的链表的头 head , 删除所有重复的元素,使每个元素只出现一次 。返回 已排序的链表 。
解决
/** * Definition for singly-linked list. * public class ListNode { * int val; * ListNode next; * ListNode() {} * ListNode(int val) { this.val = val; } * ListNode(int val, ListNode next) { this.val = val; this.next = next; } * } */ // 法一:直接进行遍历比较 class Solution { public ListNode deleteDuplicates(ListNode head) { // 双指针,快指针遍历,慢指针保留需要返回数据 if(head==null){ return head; } ListNode demp=new ListNode(0);//创建头结点,并且赋值为0 demp=head; while(demp.next!=null){ if(demp.val==demp.next.val){ demp.next=demp.next.next; }else{ demp=demp.next; } } return head; } } // 首先明白链表数据结构 只能遍历 // 链表以及排好序 // 法二:快慢指针比较 class Solution{ public ListNode deleteDuplicates(ListNode head) { if(head == null) { return head; } ListNode slow = head; ListNode fast = head; while(fast != null) { if (slow.val != fast.val) { slow.next = fast; slow = slow.next; //这里不能写成 slow=fast } fast = fast.next; } slow.next = null; return head; } }
总结
- 这类题需要注意链表的数据结构!
这篇关于java简单算法:删除排序链表中的重复元素的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-04-17基于SpringWeb MultipartFile文件上传、下载功能
- 2024-04-14个人开发者,Spring Boot 项目如何部署
- 2024-04-14RAG应用开发实战02-相似性检索的关键 - Embedding
- 2024-04-14出海软件草根逆袭打法是什么?
- 2024-04-13鸿蒙原生应用再新丁!企查查 碧蓝航线 入局鸿蒙
- 2024-04-11RAG应用开发实战(01)-RAG应用框架和解析器
- 2024-04-10DevOps已死?2024年的DevOps将如何发展
- 2024-04-10码农必看:常见源代码混淆技术详解
- 2024-04-07以一当十丨TiDB 在东吴证券秀财 APP 的应用实践
- 2024-04-07月活超 1.1 亿,用户超 4 亿,你也在用的「知乎」是如何在超大规模 TiDB 集群上玩转多云多活的?来听听知乎代晓磊的答案!