数据结构:线性表原地逆置

题目重述

本题应该是非常经典的题目了,之前在力扣碰到过,当时写的时候应该是瞎写,根本没有满足题目原地操作

题目的意思是:将一个线性表的 M 和 N 两部分交换位置

解题思路

当我们想要直接交换 M、N 两部分时,一开始一定想的是,遍历+swap,但是会逐渐发现,**当 M 和 N 两部分长度不一致时,根本不能实现直接交换,因为位置不匹配。**在这种情况下,必须要借助辅助空间操作。

但是,当我问 AI 是否这道题不可能用原地操作实现,它轻蔑一笑:首先直接回答你:完全可以原地(In-place)操作,且空间复杂度为 O(1)O(1)O(1)

然后给出了下面的答案:

前人的智慧确实令我感叹,在有限的时间里,我们不可能一下子把前人花费大量时间思考的问题一下子解决出来,即使是在我们拥有众多知识的情况下,因此,在平时学习的时候,确实要多思考,多积累一些方法,才能在考试时游刃有余,下面敬附代码

cpp 复制代码
bool SwapMNSqlist(SqList &list, int m) {
    int n = list.length - m;
    for (int i=0;i<m/2;i++) {
        swap(list.data[i],list.data[m-i-1]);
    }
    for (int i=m;i<(2*m+n)/2;i++) {
        swap(list.data[i],list.data[2*m+n-i-1]);
    }
    for (int i=0;i<list.length/2;i++) {
        swap(list.data[i],list.data[list.length-i-1]);
    }
}
相关推荐
寄存器漫游者14 分钟前
数据结构:带头节点单链表
c语言·数据结构
鹿角片ljp28 分钟前
力扣9.回文数-转字符双指针和反转数字
java·数据结构·算法
梦梦代码精1 小时前
开源、免费、可商用:BuildingAI一站式体验报告
开发语言·前端·数据结构·人工智能·后端·开源·知识图谱
what丶k4 小时前
深度解析:以Kafka为例,消息队列消费幂等性的实现方案与生产实践
java·数据结构·kafka
爱敲代码的TOM6 小时前
基础算法技巧总结2(算法技巧零碎点,基础数据结构,数论模板)
数据结构·算法
惊讶的猫6 小时前
InnoDB选用B+树作为索引的原因
数据结构·b树
历程里程碑6 小时前
子串-----和为 K 的子数组
java·数据结构·c++·python·算法·leetcode·tornado
liu****6 小时前
Qt进阶实战:事件处理、文件操作、多线程与网络编程全解析
开发语言·网络·数据结构·c++·qt
寄存器漫游者7 小时前
数据结构 二叉树核心概念与特性
数据结构·算法
皮皮哎哟7 小时前
数据结构:从队列到二叉树基础解析
c语言·数据结构·算法·二叉树·队列