408算法题leetcode--第13天

61. 旋转链表

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* rotateRight(ListNode* head, int k) {
        // 思路1:和数组一样做三次翻转
        // 思路2:先连接尾节点和头节点成环,然后返回正数n-k+1个节点
        if(head == nullptr) return nullptr;
        int len = 1;
        ListNode* p = head;
        while(p->next){
            len++;
            p = p->next;
        }
        p->next = head;
        k %= len;
        // 移动n-k到目标节点的前一个节点
        p = head;
        for(int i = 0; i < len - k - 1; i++){
            p = p->next;
        }
        head = p->next;
        p->next = nullptr;
        return head;
    }
};

206. 反转链表

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) {
        // 思路1:头插法
        // 思路2:两两互换
        ListNode *pre = nullptr, *cur = head, *temp = nullptr;
        while(cur){
            temp = cur->next;
            cur->next = pre;
            pre = cur;
            cur = temp;
        }
        return pre;
    }
};
相关推荐
hn小菜鸡3 分钟前
LeetCode 面试经典150题 201.数字范围按位与
算法·leetcode·面试
深度学习实战训练营28 分钟前
基于AFM注意因子分解机的推荐算法
算法·机器学习·推荐算法
ling1s32 分钟前
C#基础(15)选择排序
开发语言·数据结构·算法·c#
清流君34 分钟前
【自动驾驶】控制算法(九)深度解析车辆纵向控制 | 从算法基础到 Carsim 仿真实践
人工智能·笔记·算法·自动驾驶·控制算法
糖炒栗子要加糖1 小时前
论文阅读 | 一种基于潜在向量优化的可证明安全的图像隐写方法(TMM 2023)
算法·安全
Kenneth風车1 小时前
【第十一章:Sentosa_DSML社区版-机器学习之分类】
人工智能·算法·低代码·机器学习·分类·数据挖掘·数据分析
Vertira1 小时前
matlab2022a 函数或变量 ‘knnclassify‘ 无法识别(已解决)
人工智能·算法·机器学习
夏天天天天天天天#1 小时前
深度优先搜索算法及其matlab程序详解
算法·matlab·深度优先·图论
freexyn2 小时前
Matlab自学笔记36:日期时间型的概念、分类和创建方法
数据结构·笔记·算法·matlab
爱学习的真真子2 小时前
Lingo求解器基本语法
算法