力扣爆刷第137天之哈希表五连刷(环形链表哈希表)

力扣爆刷第137天之哈希表五连刷(环形链表哈希表)

文章目录

      • 力扣爆刷第137天之哈希表五连刷(环形链表哈希表)
      • [一、面试题 02.07. 链表相交](#一、面试题 02.07. 链表相交)
      • [二、142. 环形链表 II](#二、142. 环形链表 II)
      • [三、242. 有效的字母异位词](#三、242. 有效的字母异位词)
      • [四、349. 两个数组的交集](#四、349. 两个数组的交集)
      • [五、202. 快乐数](#五、202. 快乐数)

一、面试题 02.07. 链表相交

题目链接:https://leetcode.cn/problems/intersection-of-two-linked-lists-lcci/description/

思路:求链表相交的位置,很简单的题目,直接求两个链表的长度,然后长度提前走几步,走到长度相等,然后同步走,并且判断。

java 复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public ListNode getIntersectionNode(ListNode headA, ListNode headB) {
        ListNode pa = headA, pb = headB;
        int lena = 0, lenb = 0;
        while(pa != null) {
            lena++;
            pa = pa.next;
        }
        while(pb != null) {
            lenb++;
            pb = pb.next;
        }
        pa = headA;
        pb = headB;
        for(int i = lena; i < lenb; i++) {
            pb = pb.next;
        }
        for(int i = lenb; i < lena; i++) {
            pa = pa.next;
        }
        while(pa != null) {
            if(pa == pb) {
                return pa;
            }
            pa = pa.next;
            pb = pb.next;
        }
        return null;
    }
}

二、142. 环形链表 II

题目链接:https://leetcode.cn/problems/linked-list-cycle-ii/description/

思路:本题求的是环形链表的环的入口,一共分为两步,第一步先判断是否成环,第二步再寻找入口。

使用快慢指针,慢指针每次走一步,快指针每次走两步,当相遇时说明链表有环。

然后快指针位置不动,慢指针改为头结点,然后快慢指针同步每次一步,相遇时就是环的入口。

java 复制代码
public class Solution {
    public ListNode detectCycle(ListNode head) {
        ListNode slow = head, fast = head;
        while(fast != null && fast.next != null) {
            slow = slow.next;
            fast = fast.next.next;
            if(slow == fast) break;
        }
        if(fast == null || fast.next == null) return null;
        slow = head;
        while(slow != fast) {
            slow = slow.next;
            fast = fast.next;
        }
        return slow;
    }
}

三、242. 有效的字母异位词

题目链接:https://leetcode.cn/problems/valid-anagram/description/

思路:求字符串是否是异位词,用一个数组来代替哈希表,字符存在则对应位置+1,不存在则对应位置-1。若最后数组不全为0则非法。

java 复制代码
class Solution {
    public boolean isAnagram(String s, String t) {
        if(s.length() != t.length()) return false;
        int[] nums = new int[26];
        for(int i = 0; i < s.length(); i++) {
            int j = s.charAt(i) - 'a';
            nums[j]++;
        }
        for(int i = 0; i < t.length(); i++) {
            int j = t.charAt(i) - 'a';
            nums[j]--;
        }
        for(int i : nums) {
            if(i != 0) return false;
        }
        return true;
    }
}

四、349. 两个数组的交集

题目链接:https://leetcode.cn/problems/intersection-of-two-arrays/description/

思路:用两个set,第一个set收集第一个数组的元素,然后遍历第二个数组,看看元素是否存在于第一个set中,存在就加入第二个set中,第二个set中的就是交集。

java 复制代码
class Solution {
    public int[] intersection(int[] nums1, int[] nums2) {
        Set<Integer> set1 = new HashSet<>();
        for(int i : nums1) {
            set1.add(i);
        }
        Set<Integer> set2 = new HashSet<>();
        for(int i : nums2) {
            if(set1.contains(i)) {
                set2.add(i);
            }
        }
        int[] nums = new int[set2.size()];
        int k = 0;
        for(int i : set2) {
            nums[k++] = i;
        }
        return nums;
    }
}

五、202. 快乐数

题目链接:https://leetcode.cn/problems/happy-number/description/

思路:题目提到了结果可能为1可能无限循环,所以停止的边界条件就是1或者无限循环,为了停止,所以要使用set来收集中间元素,防止停不下来。

java 复制代码
class Solution {
    public boolean isHappy(int n) {
        Set<Integer> set = new HashSet<>();
        while(!set.contains(n)) {
            set.add(n);
            n = fun(n);
            if(n == 1) return true;
        }
        return false;
    }

    int fun(int n) {
        int sum = 0;
        while(n != 0) {
            int i = n % 10;
            n = n / 10;
            sum += i*i;
        }
        return sum;
    }
}
相关推荐
tinker在coding3 小时前
Coding Caprice - Linked-List 1
算法·leetcode
南宫生8 小时前
力扣-图论-17【算法学习day.67】
java·学习·算法·leetcode·图论
Lenyiin9 小时前
第146场双周赛:统计符合条件长度为3的子数组数目、统计异或值为给定值的路径数目、判断网格图能否被切割成块、唯一中间众数子序列 Ⅰ
c++·算法·leetcode·周赛·lenyiin
TT哇13 小时前
【数据结构练习题】链表与LinkedList
java·数据结构·链表
涵涵子RUSH16 小时前
合并K个升序链表(最优解)
算法·leetcode
清炒孔心菜16 小时前
每日一题 338. 比特位计数
leetcode
sjsjs1117 小时前
【多维DP】力扣3122. 使矩阵满足条件的最少操作次数
算法·leetcode·矩阵
Sudo_Wang17 小时前
力扣150题
算法·leetcode·职场和发展
yyyyyyykk18 小时前
数据结构--链表
数据结构·链表
呆呆的猫20 小时前
【LeetCode】9、回文数
算法·leetcode·职场和发展