【Java】 面试题23:链表中环的入口节点

题目描述

一个链表中包含环,请找出该链表的环的入口结点

解题思路:
利用指针遍历等方法较为复杂,可以用特殊的数据结构来帮助解决。

找到环的入口 = 找到一个已经遍历过而又即将再次被遍历的节点 = 将已经遍历的节点放在一边,每次要遍历下一个节点的时候都先看看是否已经遍历过

要实现上面这个过程,最简单高效的数据结构就是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 ListNode {
	//数据域
	public int val;
	public Tree next;
	
	//构造带参数的构造方法
	public ListNode(int val) {
		this.val = val;
	}
	//重写toString方法
	public String toString() {
		return "TreeNode [data=" +val+",next=" +next+"]";
	}
}

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的区别:

HashMapHashSet
实现了Map接口实现Set接口
存储键值对仅存储对象
调用put()向map中添加元素调用add()方法向Set中添加元素
HashMap使用键(Key)计算HashcodeHashSet使用成员对象来计算hashcode值,对于两个对象来说hashcode可能相同,所以equals()方法用来判断对象的相等性,如果两个对象不同的话,那么返回false
HashMap相对于HashSet较快,因为它是使用唯一的键获取对象HashSet较HashMap来说比较慢
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值