线性表——设计一个高效算法,将顺序表L的所有元素逆置,要求算法的空间复杂度为O(1)。

题目:设计一个高效算法,将顺序表L的所有元素逆置,要求算法的空间复杂度为O(1)。

算法思想:扫描顺序表的L的前半部分元素,对于元素L.data[i](0<=i<L.length/2),将其与后半部分的对应元素L.data[L.length-i-1]进行交换。

本题代码如下:

cpp 复制代码
void Reverse(SqList &L){
    ElemType temp;    //辅助变量
    for(int i=0;i<length/2;i++){
        temp=L.data[i];                //交换L.data[i]与L.data[length-i-1]
        L.data[i]=L.data[length-i-1];
        L.data[length-i-1]=temp;
    }
}
相关推荐
啊阿狸不会拉杆8 分钟前
《计算机视觉:模型、学习和推理》第 1 章 - 绪论
人工智能·python·学习·算法·机器学习·计算机视觉·模型
Frostnova丶12 分钟前
LeetCode 693. 交替位二进制数
算法·leetcode
_F_y24 分钟前
递归搜索入门
算法
We་ct26 分钟前
LeetCode 101. 对称二叉树:两种解法(递归+迭代)详解
前端·算法·leetcode·链表·typescript
云深处@30 分钟前
【数据结构】树&&堆
数据结构
ADDDDDD_Trouvaille30 分钟前
2026.2.18——OJ86-88题
c++·算法
努力学算法的蒟蒻42 分钟前
day89(2.18)——leetcode面试经典150
算法·leetcode·面试
丰海洋1 小时前
Leetcode-hot100-283.移动零
算法·leetcode·职场和发展
s_w.h1 小时前
【 C++ 】搜索二叉树
java·开发语言·c++·算法
俩娃妈教编程1 小时前
2023 年 09 月 二级真题(2)--数字黑洞
c++·算法·while