【数据结构】【顺序表算法】 删除特定值

  • 题目:对长度为n的顺序表L,编写一个时间复杂度为O(n),空间复杂度为O(1)的算法,该算法删除顺序表中所有值为x的数据元素

  • 方法1

cpp 复制代码
void del_x_1(SqList &L,ElemType x){
    int k=0,i;
    for(i=0;i<L.length;i++){
        if(L.data[i]!=x){
           L.data[k]=L.data[i];
           k++;
        }
    }
    L.length=k;
}
  • 方法2

cpp 复制代码
void del_x_2(SqList &L,ElemType x){
    int k=0,i=0;
    while(i<L.length){
        if(L.data[i]==x)
            k++;
        else
            L.data[i-k]=L.data[i];//当前元素前移动k个位置
        i++;
    }
    L.length=L.length-k;
}
相关推荐
Dylan的码园几秒前
深入浅出Java排序:从基础算法到实战优化(上)
java·数据结构·算法
星火开发设计2 分钟前
从公式到应用:卷积公式全面解析与实战指南
学习·算法·机器学习·概率论·知识·期末考试·卷积公式
学嵌入式的小杨同学9 分钟前
循环队列(顺序存储)完整解析与实现(数据结构专栏版)
c语言·开发语言·数据结构·c++·算法
shangjian00710 分钟前
AI大模型-机器学习-算法-线性回归-优化方法
人工智能·算法·机器学习
shangjian00714 分钟前
AI大模型-机器学习-算法-逻辑回归
人工智能·算法·机器学习
王锋(oxwangfeng)15 分钟前
车道线拟合算法--自动驾驶
人工智能·算法·自动驾驶
computersciencer16 分钟前
一文快速理解线性回归的过程
算法·机器学习·回归·线性回归
VT.馒头21 分钟前
【力扣】2627. 函数防抖
前端·javascript·算法·leetcode
想逃离铁厂的老铁21 分钟前
Day41 >> 121、买卖股票的最佳时机 + 122.买卖股票的最佳时机II + 123.买卖股票的最佳时机III
算法·leetcode
夏鹏今天学习了吗22 分钟前
【LeetCode热题100(79/100)】打家劫舍
算法·leetcode·职场和发展