LC142.环形链表II

java 复制代码
/**
     * 题目链接:https://leetcode.cn/problems/linked-list-cycle-ii/
     * 使用 map集合来存储链表的结点,在每次添加节点的时候使用map.containsValue()方法进行判断,
     * 如果存在相同的节点,就说明有环,然后返回当前节点
     * 举例:3 =》2 =》0 =》3 (这里0指向头节点 3)
     *     我们依次向map中存储节点:
     *     0: 3,
     *     1: 2,
     *     2: 0,
     *   再次添加3的时候,发现map中已经存在该节点,因此返回 3
     * @param head
     * @return
*/
    public static ListNode detectCycle(ListNode head) {
        Map<Integer, ListNode> map =  new HashMap<>();
        int i = 0 ;
        while(head != null){
            if(map.containsValue(head)){
                return head;
            }
            else{
                map.put(i, head);
                i ++ ;
                head = head.next;
            }
        }
        return null;
    }
相关推荐
anOnion31 分钟前
构建无障碍组件之Carousel Pattern
前端·html·交互设计
ssshooter40 分钟前
Tauri 2 iOS 开发避坑指南:文件保存、Dialog 和 Documents 目录的那些坑
前端·后端·ios
Можно1 小时前
深入理解 ES6 Proxy:与 Object.defineProperty 的全面对比
前端·javascript·vue.js
zs宝来了2 小时前
Playwright 自动发布 CSDN 的完整实践
java
Birdy_x2 小时前
接口自动化项目实战(1):requests请求封装
开发语言·前端·python
吴声子夜歌3 小时前
TypeScript——基础类型(三)
java·linux·typescript
天天向上10243 小时前
vue el-table实现拖拽排序
前端·javascript·vue.js
西西学代码3 小时前
Flutter---回调函数
开发语言·javascript·flutter
卷帘依旧4 小时前
JavaScript 闭包经典问题:为什么输出 10 次 i=10
javascript