【力扣题】关于单链表和数组习题

🌈 个人主页:白子寰

🔥 分类专栏:python从入门到精通,魔法指针,进阶C++,C语言,C语言题集,C语言实现游戏 👈 希望得到您的订阅和支持~

💡 坚持创作博文(平均质量分82+),分享更多关于深度学习、C/C++,python领域的优质内容!(希望得到您的关注~)

目录

反转链表

题目要求

示例

解法:双指针法

思路

图解

代码

轮转数组

题目要求

示例

解法

方法一:数组方法

【时间复杂度O(n)】

方法二:memcpy法

【时间和空间复杂度O(n)】

代码

方法一

方法二


反转链表

206.反转链表https://leetcode.cn/problems/reverse-linked-list/description/

题目要求

给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。

示例

解法:双指针法

思路

创建结点:temp,prev = NULL,cur = head

while使用cur遍历循环链表

temp指向头cur的下一个节点(保存cur的下一个结点)

cur的下一个节点指向prev(翻转操作)

更新prev,cur指针

如此循环,直到cur指向空指针(如下面图解)

最后返回prev

图解

代码

cs 复制代码
typedef struct ListNode LTNode;
struct ListNode* reverseList(struct ListNode* head) {
    LTNode* temp;
    LTNode* prev = NULL;
    LTNode* cur = head;
    while(cur)
    {
        //保存cur的下一个结点
        temp = cur->next;
        //翻转
        cur->next = prev;
        //更新结点
        prev = cur;
        cur = temp;
    }
    return prev;
}

轮转数组

189.轮转数组https://leetcode.cn/problems/rotate-array/

题目要求

给定一个整数数组 nums,将数组中的元素向右轮转 k个位置,其中 k是非负数。

示例

解法

方法一:数组方法

时间复杂度O(n)

方法二:memcpy法

【时间和空间复杂度O(n)】

代码

方法一

cs 复制代码
void Reverse(int* a,int left,int right)
{
    while(left < right)
    {
        int tmp = a[left];
        a[left] = a[right];
        a[right] = tmp;

        ++left;
        --right;
    }
}
void rotate(int* nums, int numsSize, int k) {
    k %= numsSize;

    //前n-k个逆置
    Reverse(nums,0,numsSize-k-1);
    //后k个逆置
    Reverse(nums,numsSize-k,numsSize-1);
    //全部逆置
    Reverse(nums,0,numsSize-1);
}

方法二

cs 复制代码
void rotate(int* nums, int numsSize, int k) {
    k %= numsSize;
    int n = numsSize;
    int tmp[numsSize];

    //前n-k个逆置
    memcpy(tmp,nums+n-k,sizeof(int)*(k));
    //后k个逆置
    memcpy(tmp+k,nums,sizeof(int)*(n-k));
    //全部逆置
    memcpy(nums,tmp,sizeof(int)*(n));
}

***********************************************************分割线*****************************************************************************
完结!!!
感谢浏览和阅读。

等等等等一下,分享最近喜欢的一句话:

"当我在追光,我与光同航**"。**

我是白子寰,如果你喜欢我的作品,不妨你留个点赞+关注让我知道你曾来过。
你的点赞和关注是我持续写作的动力!!!

好了划走吧。

相关推荐
phoenix@Capricornus1 小时前
反向传播算法——矩阵形式递推公式——ReLU传递函数
算法·机器学习·矩阵
Inverse1622 小时前
C语言_动态内存管理
c语言·数据结构·算法
数据与人工智能律师2 小时前
虚拟主播肖像权保护,数字时代的法律博弈
大数据·网络·人工智能·算法·区块链
wuqingshun3141592 小时前
蓝桥杯 16. 外卖店优先级
c++·算法·职场和发展·蓝桥杯·深度优先
YouQian7723 小时前
2025春训第十九场
算法
CodeJourney.3 小时前
基于MATLAB的生物量数据拟合模型研究
人工智能·爬虫·算法·matlab·信息可视化
Epiphany.5563 小时前
素数筛(欧拉筛算法)
c++·算法·图论
爱吃涮毛肚的肥肥(暂时吃不了版)3 小时前
项目班——0510——JSON网络封装
c++·算法·json
liang_20263 小时前
【HT周赛】T3.二维平面 题解(分块:矩形chkmax,求矩形和)
数据结构·笔记·学习·算法·平面·总结
緈福的街口3 小时前
【leetcode】2900. 最长相邻不相等子序列 I
算法·leetcode·职场和发展