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

题目重述

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

题目的意思是:将一个线性表的 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]);
    }
}
相关推荐
CSharp精选营4 天前
关系型 vs 非关系型:从原理到选型,一文搞定数据库核心分类
数据结构·nosql·关系型数据库·非关系型数据库·技术选型
刘马想放假8 天前
Modbus 全栈技术解析:TCP、RTU、ASCII、RTU over TCP
数据结构·网络协议
北域码匠9 天前
冒泡排序太慢?鸡尾酒排序双向优化,原生 C# 零第三方库完整代码
数据结构·排序算法·泛型·c# 算法·鸡尾酒排序·原生 c# 开发·冒泡排序优化·嵌入式算法
Darling噜啦啦15 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
小小工匠16 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
玖玥拾16 天前
C/C++ 数据结构(七)栈、容器适配器
c语言·数据结构·c++··容器适配器
Qres82117 天前
算法复键——树状数组
数据结构·算法
酉鬼女又兒17 天前
零基础入门计算机网络运输层:端到端通信核心作用、端口号分类规则、复用分用工作机制及UDP与TCP协议全方位对比详解
网络·网络协议·tcp/ip·计算机网络·考研·udp·php
牛油果子哥q17 天前
并查集(DSU)超精讲,路径压缩、按秩合并、万能模板、连通性判定、最小生成树与刷题实战全解
数据结构·c++·最小生成树·并查集
凌波粒17 天前
LeetCode--491.递增子序列(回溯算法)
数据结构·算法·leetcode