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

🌈 个人主页:白子寰

🔥 分类专栏: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));
}

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

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

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

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

好了划走吧。

相关推荐
捕鲸叉14 分钟前
创建线程时传递参数给线程
开发语言·c++·算法
A charmer19 分钟前
【C++】vector 类深度解析:探索动态数组的奥秘
开发语言·c++·算法
wheeldown1 小时前
【数据结构】选择排序
数据结构·算法·排序算法
观音山保我别报错2 小时前
C语言扫雷小游戏
c语言·开发语言·算法
TangKenny3 小时前
计算网络信号
java·算法·华为
景鹤3 小时前
【算法】递归+深搜:814.二叉树剪枝
算法
iiFrankie3 小时前
SCNU习题 总结与复习
算法
Dola_Pan4 小时前
C++算法和竞赛:哈希算法、动态规划DP算法、贪心算法、博弈算法
c++·算法·哈希算法
小林熬夜学编程4 小时前
【Linux系统编程】第四十一弹---线程深度解析:从地址空间到多线程实践
linux·c语言·开发语言·c++·算法
躺不平的理查德5 小时前
数据结构-链表【chapter1】【c语言版】
c语言·开发语言·数据结构·链表·visual studio