Java找出两个链表的第一个公共节点

来源:互联网 发布:传奇物品数据库详解 编辑:程序博客网 时间:2024/06/05 07:36

题目描述

输入两个链表,找出它们的第一个公共结点。


我的思路:因为是链表,长度都是未知的,不能盲目的两个一起开始自增判断。

首先需要得到 L1的长度 和 L2的长度,让较长的那个先走 (length1-length2)步。然后再一直next去判断。

AC代码, 34ms,503K

/*public class ListNode {    int val;    ListNode next = null;    ListNode(int val) {        this.val = val;    }}*/public class Solution {    public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) { if(pHead1==pHead2){                return pHead1;            }                int l1=getLength(pHead1);        int l2=getLength(pHead2);        if(l1>l2){            for(int i=0;i<(l1-l2);i++){                pHead1=pHead1.next;            }                    }else{            for(int i=0;i<(l1-l2);i++){                pHead2=pHead2.next;            }        }                boolean f=true;        ListNode p=null;        while(f){            if(pHead1==null||pHead2==null){                return null;            }            if(pHead1==pHead2){                p=pHead1;                f=false;            }else{                pHead1=pHead1.next;                 pHead2=pHead2.next;            }                    }                return p;    }       public static int getLength(ListNode pHead) {        int length = 0;         ListNode current = pHead;        while (current != null) {            length++;            current = current.next;        }        return length;    }}

看看别的思路:

1、用HashMap: 

第一个while是把pHead1的所有节点都放进去。

第二个while开始,对pHead2的每个节点都用  containsKey 方法来判断。 

因为在前一种思路中,要求得两个链表的长度就需要对两个链表进行一次遍历,用HashMap的方法其实更加节省时间。

33ms,503K

import java.util.*;/*public class ListNode {    int val;    ListNode next = null;    ListNode(int val) {        this.val = val;    }}*/public class Solution {    public ListNode FindFirstCommonNode(ListNode pHead1, ListNode pHead2) {        ListNode current1 = pHead1;        ListNode current2 = pHead2;          HashMap<ListNode, Integer> hashMap = new HashMap<ListNode, Integer>();        while (current1 != null) {            hashMap.put(current1, null);            current1 = current1.next;        }        while (current2 != null) {            if (hashMap.containsKey(current2))                return current2;            current2 = current2.next;        }         return null;     }}


原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 国外期刊催问稿件不理睬怎么办 老公离不开老婆也离不开小三怎么办 出轨被老婆发现还和小三联系怎么办 老公出轨后回家老婆不想原谅怎么办 小三和原配打架都住院了怎么办 毕业太多年查不到学历认证怎么办 没有做税种核定开了票怎么办 在学信网上查不到学历信息怎么办 学信网手机号换了密码忘了怎么办 学信网手机号换了密码也忘了怎么办 学信网上学习形式是星号怎么办 新手机号已被注册微店买家怎么办 微信号被冻结了里面的钱怎么办 不懂公司产品却要接待老外怎么办 上菜时发现桌面摆不下新菜怎么办 超市买到过期产品商家不赔尝怎么办 皇帝成长计划2俘虏的士兵怎么办 晚上楼上有挪桌子的声音怎么办 金灶茶具出故障码e7怎么办 起亚k2灯泡掉进大灯总成怎么办 衣服上拆过线的针孔怎么办 驾考科目二坡道定点熄火怎么办 穿着超短裤感觉要漏屁股怎么办 台式电脑开机后无法进入系统怎么办 产后两年了肚子肥胖松弛怎么办 在作文中写上自己的名字怎么办 外出玩耍时迷路了你会怎么办 外出玩耍时孩子总喜欢乱跑怎么办? 如果真的物价高的受不了怎么办 每晚要5次真的受不了怎么办 五年级的学生钢笔字写不好怎么办 全麻醉药过后让人产生幻觉怎么办? 网贷小象优品上被别人冒用了怎么办 当你和老人产生冲突时该怎么办 百度网盘会员到期后容量怎么办 一个人不停的给你发视频聊天怎么办 被谋杀后的身后事应该怎么办 社保交了五年被单位辞退怎么办 桅子花叶子变黄叶杆蔫怎么办 薄荷养的都黄了干掉了怎么办 被烟草局没收的烟要是假烟怎么办