备战秋招day3

碎碎念:

今天有个面试,学校这里还有实训。

今日任务:算法+mysql知识点补充

算法

24. 两两交换链表中的节点

复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */
class Solution {
    public ListNode swapPairs(ListNode head) {
        if(head == null) return head;
        ListNode dump = new ListNode(-1,head);
        ListNode cur = dump;
        while(cur.next != null && cur.next.next != null){
            ListNode tmp = cur.next.next.next;
            //交换
            ListNode node1 = cur.next;
            ListNode node2 = cur.next.next;
            cur.next = node2;
            node2.next = node1;
            node1.next = tmp;
            //往后迭代
            cur = node1;
        }
        return dump.next;
    }
}

19. 删除链表的倒数第 N 个结点

复制代码
/**
 * Definition for singly-linked list.
 * public class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode() {}
 *     ListNode(int val) { this.val = val; }
 *     ListNode(int val, ListNode next) { this.val = val; this.next = next; }
 * }
 */

class Solution {
    public ListNode removeNthFromEnd(ListNode head, int n) {
        ListNode dummy = new ListNode(-1,head);
        //快慢指针:找倒数第几个的话,那我们可以找两个指针,快指针先走n步
        ListNode fast = dummy;
        ListNode slow = dummy;
        int count = n;
        while(n-- > 0 && fast!=null){
            fast = fast.next;
        }
        //我们要找到待删除节点的前一个节点 
        fast = fast.next;
        while(fast!=null){
            slow = slow.next;
            fast = fast.next;
        }
        slow.next = slow.next.next;
        return dummy.next;
    }
}

面试题 02.07. 链表相交

复制代码
/**
 * 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 tmpa = headA;
        ListNode tmpb = headB;
        int lena = 0,lenb = 0;
        while(tmpa!=null){
            lena++;
            tmpa = tmpa.next;
        }
        while(tmpb!=null){
            lenb++;
            tmpb = tmpb.next;
        }
        //我们得对两条链表谁长做不同情况的判断
        //但这里有个方法可以让我们不用写两遍,就是永远让A链表是最长的那条链表
        if(lenb>lena){
            //做交换就能保证a是最长链表
            ListNode node = null;
            node = headA;
            headA = headB;
            headB = node;
        }
        //算出两者差,谁长谁先走差值的步数
        int diff = Math.abs((lena-lenb));
        //重置回来
        tmpa = headA;
        tmpb = headB;
        //A最长,所以A先走差值
        while(diff-- > 0){
            tmpa = tmpa.next;
        }
        //找相同节点
        while(tmpa!=null){
            //注意:题目说了是节点相同,而不仅仅是值,因此这里直接==即可
            if(tmpa == tmpb){
                return tmpa;
            }
            tmpa = tmpa.next;
            tmpb = tmpb.next;
            
        }
        return null;
    }
}

142. 环形链表 II

复制代码
/**
 * Definition for singly-linked list.
 * class ListNode {
 *     int val;
 *     ListNode next;
 *     ListNode(int x) {
 *         val = x;
 *         next = null;
 *     }
 * }
 */
public class Solution {
    public ListNode detectCycle(ListNode head) {
        ListNode fast = head;
        ListNode slow = head;
        //先判断是否有环
        while(fast!=null && fast.next!=null){
            slow = slow.next;
            fast = fast.next.next;
            //两个指针如果相遇,表示有环
            if(slow == fast){
                //找相遇点
                //方法是通过两个指针来去找
                ListNode node1 = fast;
                ListNode node2 = head;
                while(node1 != node2){
                    node1 = node1.next;
                    node2 = node2.next;
                }
                return node2;
            }
        }
        return null;
    }
}

知识点补充

MySQL

背了那么久的MVCC,今天再次去复习了一遍,学习到的内容有,MVCC实现原理,MVCC有什么用,快照读,当前读,undo log,什么是ReadView,MVCC如何解决相关读写问题的

事务,索引这块内容,不应该只停留在背书上,加深理解才可能更好把握面试。

明天记录Redis以及MySQL相关知识点

相关推荐
C雨后彩虹2 小时前
任务最优调度
java·数据结构·算法·华为·面试
heartbeat..2 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
Jing_jing_X2 小时前
AI分析不同阶层思维 二:Spring 的事务在什么情况下会失效?
java·spring·架构·提升·薪资
少林码僧4 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)4 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
元Y亨H4 小时前
Nacos - 服务发现
java·微服务
微露清风4 小时前
系统性学习C++-第十八讲-封装红黑树实现myset与mymap
java·c++·学习
dasi02274 小时前
Java趣闻
java
Niuguangshuo5 小时前
EM算法详解:解密“鸡生蛋“的机器学习困局
算法·机器学习·概率论
a3158238065 小时前
Android 大图显示策略优化显示(一)
android·算法·图片加载·大图片