【Java】 面试题23:链表中环的入口节点
2019-03-13 20:48
316 查看
题目描述
一个链表中包含环,请找出该链表的环的入口结点
解题思路:
利用指针遍历等方法较为复杂,可以用特殊的数据结构来帮助解决。
找到环的入口 = 找到一个已经遍历过而又即将再次被遍历的节点 = 将已经遍历的节点放在一边,每次要遍历下一个节点的时候都先看看是否已经遍历过
要实现上面这个过程,最简单高效的数据结构就是Set。我们可以利用Set中元素不相同的特点。
package jianZhiOffer; import java.util.Set; import java.util.HashSet; /* * 面试题23:链表中环的入口节点 * 题目:如果一个链表中包含环,如何找出环的入口节点? */ public class Demo23 { public static void main(String[] args) { ListNode a = new ListNode(1); ListNode b = new ListNode(2); ListNode c = new ListNode(3); ListNode d = new ListNode(4); ListNode e = new ListNode(5); ListNode f = new ListNode(7); a.next = b; b.next = c; c.next = d; d.next = e; e.next = f; f.next = c; System.out.println(EntryNodeOfLoop(a)); } public static int EntryNodeOfLoop(ListNode pHead) { Set<ListNode> set = new HashSet(); while(pHead != null) { if(!set.add(pHead)) { //添加失败,说明几何中已经存在该元素,返回该值 return pHead.val; } pHead = pHead.next; } return -1; } }
package jianZhiOffer; public class Tree { //数据域 public int data; //左指针域 public Tree left; //右指针域 public Tree right; //构造带参数的构造方法 public Tree(int data) { this.data = data; } //重写toString方法 public String toString() { return "TreeNode [data=" +data+ ",left=" +left+ ",right=" +right+ "]"; } }
HashSet和HashMap的区别:
HashSet:
HashSet实现了Set接口,它不允许集合中出现重复元素。当我们提到HashSet时,第一件事就是在将对象存储在HashSet之前,要确保重写hashCode()方法和equals()方法,这样才能比较对象的值是否相等,确保集合中没有存储相同的对象。如果不重写上述两个方法,那么将使用下面方法默认实现:
public boolean add(Object obj)方法用在Set添加元素时,如果元素重复时返回false,如果添加成功则返回true
HashMap:
HashMap实现了Map接口,Map接口对键值对进行映射。Map中不允许出现重复的键(Key)。Map接口有两个基本的实现:
TreeMap和HashMap。
TreeMap保存了对象的排列次序,而HashMap不能。HashMap可以有空的键值对( Key(null) -Value (null) )
HashMap是非线程安全的(非Synchronize),要想实现线程安全,那么需要调用collection类的静态方法synchronizeMap()实现。
public Object put(Object Key, Object value)方法用来将元素添加到map中。
HashSet与HashMap的区别:
HashMap | HashSet |
---|---|
实现了Map接口 | 实现Set接口 |
存储键值对 | 仅存储对象 |
调用put()向map中添加元素 | 调用add()方法向Set中添加元素 |
HashMap使用键(Key)计算Hashcode | HashSet使用成员对象来计算hashcode值,对于两个对象来说hashcode可能相同,所以equals()方法用来判断对象的相等性,如果两个对象不同的话,那么返回false |
HashMap相对于HashSet较快,因为它是使用唯一的键获取对象 | HashSet较HashMap来说比较满 |
相关文章推荐
- 剑指offer面试题23:链表中环的入口节点(Java 实现)
- 剑指Offer 面试题23:链表中环的入口节点 Java代码实现
- 剑指Offer面试题56:链表中环的入口节点 Java实现
- 剑指offer面试题56 链表中环的入口节点(java实现)
- 剑指offer--面试题23:链表中环的入口节点
- 剑指面试题23-链表中环的入口节点
- 面试题23:链表中环的入口节点
- 【剑指offer】面试题23:链表中环的入口节点
- 面试题23:链表中环的入口结点
- 面试题(二十三) 链表中环的入口节点
- 【剑指**】23.链表中环的入口节点
- 剑指offer----链表中环的入口节点----java实现
- 链表中环的入口节点(Java实现)
- 剑指offer-----链表中环的入口节点(java版)
- 剑指offer-链表中环的入口节点-java
- 找到链表中环的入口节点 java
- 《剑指Offer》面试题56:链表中环的入口节点
- 面试题56:链表中环的入口节点
- 面试题56:链表中环的入口节点
- 剑指Offer-23:链表中环的入口节点