力扣--LCR 141.训练计划III

题目

给定一个头节点为 head 的单链表用于记录一系列核心肌群训练编号,请将该系列训练编号 倒序 记录于链表并返回。

示例 1:

输入:head = [1,2,3,4,5]

输出:[5,4,3,2,1]

示例 2:

输入:head = [1,2]

输出:[2,1]

示例 3:

输入:head = []

输出:[]

提示:

链表中节点的数目范围是 [0, 5000]
-5000 <= Node.val <= 5000

代码

/**

  • Definition for singly-linked list.

  • public class ListNode {

  int val;
  ListNode next;
  ListNode() {}
  ListNode(int val) { this.val = val; }
  ListNode(int val, ListNode next) { this.val = val; this.next = next; }
  • }

    */

    class Solution {

    public ListNode trainningPlan(ListNode head) {

    if(headnull||head.nextnull){

    return head;

    }

    ListNode cur = head, pre = null;

     while(cur != null){
         ListNode temp = cur.next;
         cur.next = pre;
         pre = cur;
         cur = temp;
     }
    
     return pre;
    

    }

    }

    时间复杂度:O(N)

    额外空间复杂度 O(1)

递归

// 递归

public ListNode reverseList(ListNode head) {

if(head == null || head.next == null){

return head;

}

// 反转子链表

ListNode temp = reverseList(head.next);

head.next.next = head;

head.next = null;

    return temp;
}

时间复杂度:O(N)

额外空间复杂度 O(n),递归调用需要消耗栈空间

相关推荐
重生之我在VS写bug2 小时前
【C++知识总结2】C++里面的小配角cout和cin
数据结构·c++·算法
测试杂货铺3 小时前
Postman设置接口关联,实现参数化
自动化测试·软件测试·测试工具·职场和发展·测试用例·接口测试·postman
pzn25063 小时前
蓝桥杯练习题
c++·算法·蓝桥杯
奶茶戒断高手4 小时前
【CSP CCF记录】201903-2第16次认证 二十四点
数据结构·c++·算法
xxxmmc4 小时前
Leetcode 290 word Pattern
算法·leetcode·hashmap双映射
羽墨灵丘5 小时前
0-1背包问题(1):贪心算法
算法·贪心算法
vampire-wpre6 小时前
我要成为算法高手-递归篇
算法·深度优先
醒了就刷牙7 小时前
Leetcode 面试150题 88.合并两个有序数组 简单
算法·leetcode·面试
测试老哥7 小时前
pytest之收集用例规则与运行指定用例
自动化测试·软件测试·python·测试工具·职场和发展·测试用例·pytest