12.20 - 反转链表II && 传值和传地址的区别

目录

1.反转链表

a.核心思想

b.思路

c.步骤

2.传值和传地址区别,内容会有什么不一样

a.传值

b.传地址


1.反转链表

92. 反转链表 II - 力扣(LeetCode)https://leetcode.cn/problems/reverse-linked-list-ii/description/

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* successor = nullptr;
    ListNode* reverseN(ListNode* head, int n) {
        if (n == 1) {
            successor = head->next;
            return head;
        }
        ListNode* last = reverseN(head->next, n - 1);
        head->next->next = head;
        head->next = successor;
        return last;
    }

    ListNode* reverseBetween(ListNode* head, int left, int right) {
        if (left == 1) {
            return reverseN(head, right);
        }
        head->next = reverseBetween(head->next, left - 1, right - 1);
        return head;
    }
};

a.核心思想

利用递归或迭代的方法,找到需要反转的链表部分的起始节点和结束节点,进行局部反转,并重新连接链表的前后部分。

b.思路

可以采用递归的方法,先递归到需要反转的结束节点的下一个位置,然后从后往前进行节点的反转操作,同时维护好前后链表的连接。

c.步骤

① 如果 left 等于 1,相当于从链表头部开始反转,直接调用反转整个链表的递归函数(反转前 right - left + 1 个节点)。

② 一般情况下,先递归到 left - 1 位置,记录其下一个节点为需要反转部分的头节点。

③ 继续递归到 right 位置,进行局部反转操作,将反转后的链表头节点连接到 left - 1 位置的节点后面。

④ 返回原链表的头节点。

2.传值和传地址区别,内容会有什么不一样

a.传值

传递内容:传递的是实参值的副本。函数内部获得的是与实参值相同但独立的新值。

影响:在函数中对参数的修改不会影响到实参本身。例如,将一个整数传值给函数,函数内对该整数的修改不会改变函数外原变量的值。

b.传地址

传递内容:传递的是实参的地址(指针方式)或对实参的引用(引用方式)。函数内部通过地址或引用直接操作实参所指向的内存。

影响:在函数中对参数的修改会直接影响到实参。比如传递一个指针指向的整数,函数内对该整数内存的修改会反映到函数外原变量上。

简而言之,传值是传数据副本,函数内修改不影响原数据;传地址是传数据位置,函数内修改会影响原数据。

希望这些内容对大家有所帮助!

感谢大家的三连支持!

相关推荐
如意鼠3 小时前
大模型教我成为大模型算法工程师之day20: 预训练语言模型 (Pre-trained Language Models)
人工智能·算法·语言模型
_OP_CHEN3 小时前
【算法基础篇】(三十六)图论基础之拓扑排序:从原理到实战,搞定 DAG 图的 “先后次序” 难题
c++·算法·蓝桥杯·图论·拓扑排序·算法竞赛·acm/icpc
良木生香3 小时前
【诗句结构-初阶】详解栈和队列(2)---队列
c语言·数据结构·算法·蓝桥杯
郝学胜-神的一滴3 小时前
使用EBO绘制图形:解锁高效渲染与内存节省之道
c++·qt·游戏·设计模式·系统架构·图形渲染
yaoh.wang3 小时前
力扣(LeetCode) 69: x 的平方根 - 解法思路
python·算法·leetcode·面试·职场和发展·牛顿法·二分法
!停3 小时前
数据在内存中的存储(2)
开发语言·c++·算法
认真学GIS3 小时前
逐3小时降水量!全国2421个气象站点1951-2024年逐3小时尺度长时间序列降水量(EXCEL格式)数据
人工智能·算法·机器学习
聆风吟º3 小时前
【数据结构手札】顺序表实战指南(二):结构体构建 | 初始化 | 打印 | 销毁
数据结构·初始化顺序表·销毁顺序表·打印顺序表
智航GIS3 小时前
ArcGIS大师之路500技---039趋势面法
算法·arcgis