力扣hot100——相交,回文链表

1.相交链表

解法思路:

// 抽象为相遇问题,如果有交点,将A,B链表与相遇后链表看作一个整体

// a 和 b 相遇的地方就是交点2,如果不相遇就没有交点;

// 因为路线不同,但是如果相遇则必会有一点处俩者走过的路径相同

// 由于两个链表可能长度不同,但相交部分之后的节点是相同的,因此通过让两个指针分别遍历两个链表(并在到达链表末尾时切换到另一个链表的头节点),它们最终会在交点处相遇。如果链表不相交,则p和q最终都会变为NULL,循环结束。

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode(int x) : val(x), next(NULL) {}
 * };
 */
class Solution {
public:
    ListNode *getIntersectionNode(ListNode *headA, ListNode *headB) {
        // 抽象为相遇问题,如果有交点,将A,B链表与相遇后链表看作一个整体
        // a 和 b 相遇的地方就是交点2,如果不相遇就没有交点;
        // 因为路线不同,但是如果相遇则必会有一点处俩者走过的路径相同
        // 由于两个链表可能长度不同,但相交部分之后的节点是相同的,因此通过让两个指针分别遍历两个链表(并在到达链表末尾时切换到另一个链表的头节点),它们最终会在交点处相遇。如果链表不相交,则p和q最终都会变为NULL,循环结束。

        ListNode *p = headA,*q = headB; // 从头出发的指针
        while(p != q){ // 还未相遇到,则继续走  此处比较的是指针指向位置,并非所指节点的val
            if(p != NULL){  // 走自己路
                p = p->next;
            }
            else{          // 走完自己的后,走b的路径
                p = headB;
            }

            q = q ? q->next : headA;
        }
        return p;
    }
};

2.反转链表

解法思路:

// 暴力解法: 将原链表值取出,反转后构造新链表

// 双指针解法

// 将原来的指向颠倒,定义俩个指针,一个指向头的前面,一个指向头

// 将头的next指向他前面,然后后移,逐渐将链表反转

cpp 复制代码
/**
 * Definition for singly-linked list.
 * struct ListNode {
 *     int val;
 *     ListNode *next;
 *     ListNode() : val(0), next(nullptr) {}
 *     ListNode(int x) : val(x), next(nullptr) {}
 *     ListNode(int x, ListNode *next) : val(x), next(next) {}
 * };
 */
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        // // 暴力解法: 将原链表值取出,反转后构造新链表
        // vector<int> temp;
        // ListNode *p = head;
        // while (p != nullptr){
        //     temp.push_back(p->val);
        //     p = p->next;
        // }
        // p = head;
        // reverse(temp.begin(),temp.end());
        // while (p != nullptr){
        //     for (auto &val : temp){
        //         p->val = val;
        //         p = p->next;
        //     }    
        // }
        // return head;

        // 双指针解法
        // 将原来的指向颠倒,定义俩个指针,一个指向头的前面,一个指向头
        // 将头的next指向他前面,然后后移,逐渐将链表反转

        ListNode *cur = head, *pre = NULL;
        
        while(cur){
            ListNode *temp = cur->next; // 保存原下一个节点
            cur->next = pre; // 调转指向
            pre = cur; // 前移
            cur = temp; 
        }
        return pre;

    }
};
相关推荐
不会就选b15 小时前
算法日常・每日刷题--<二分查找>1
算法
「維他檸檬茶」15 小时前
大模型算法学习2026.6.13
学习·算法
叫我:松哥15 小时前
基于Python的共享单车租赁数据分析与预测系统,技术栈flask+boostrap+随机森林+XGBoost
人工智能·python·深度学习·算法·随机森林·数据分析·flask
BAGAE15 小时前
星链卫星数据获取:从太空安全到实时通信的技术革命
网络·数据结构·数据库·算法·云计算·hbase
happymaker062615 小时前
LeetCodeHor100——438.找到字符串中所有的字母异位词
算法
西安邮电大学15 小时前
有关栈的经典算法题
java·后端·其他·算法·面试
h_a_o777oah16 小时前
【算法专项】扩展域并查集:原理详解及解决大部分种类并查集问题(洛谷P5937 P2024 C++代码)
数据结构·c++·算法·acm·并查集·扩展域·逻辑建模
兰令水16 小时前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
TMT星球16 小时前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_7644413316 小时前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互