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

🌈 个人主页:白子寰

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

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

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

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

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

好了划走吧。

相关推荐
kitesxian8 分钟前
Leetcode448. 找到所有数组中消失的数字(HOT100)+Leetcode139. 单词拆分(HOT100)
数据结构·算法·leetcode
VertexGeek1 小时前
Rust学习(八):异常处理和宏编程:
学习·算法·rust
石小石Orz1 小时前
Three.js + AI:AI 算法生成 3D 萤火虫飞舞效果~
javascript·人工智能·算法
jiao_mrswang2 小时前
leetcode-18-四数之和
算法·leetcode·职场和发展
qystca2 小时前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱2 小时前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子2 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab
是阿建吖!2 小时前
【优选算法】二分查找
c++·算法
王燕龙(大卫)2 小时前
leetcode 数组中第k个最大元素
算法·leetcode
不去幼儿园3 小时前
【MARL】深入理解多智能体近端策略优化(MAPPO)算法与调参
人工智能·python·算法·机器学习·强化学习