数据结构学习系列之顺序表的两种删除方式

  • 方式1:
  • 在顺序表的末端删除所存储的数据元素,代码如下:
  • 示例代码:
int delete_seq_list_1(list_t *seq_list){

    if(NULL == seq_list){

        printf("入参为NULL\n");

        return -1;

    }
    if(0 == seq_list->count){

        printf("顺序表为空,删除失败\n");

        return -1;
    }
    seq_list->count--;

    return 0;
}
  • 注意事项:

  • 1.形参传入到具有删除数据元素功能的函数后,需要做入参合理性检查

  • 2.还需要判断此时顺序表所存储的数据元素是否为空

  • 3.count是计数的变量每次删除一个数据元素后,需要减1,此处易忽略

  • 方式2:

  • 在顺序表的任意位置删除数据元素,代码如下:

  • 示例代码:

int delete_seq_list_2(list_t *seq_list,int pos){

    if(NULL == seq_list){

        printf("入参为NULL\n");

        return -1;

    }
    if(0 == seq_list->count){

        printf("顺序表为空,删除失败\n");

        return -1;
    }

     if( pos < 0 || pos >= seq_list->count){

        printf("删除位置不合理,删除失败\n");

        return -1;

    }

    int i = pos;

    while(i < seq_list->count-1){

        seq_list->a[i] = seq_list->a[i+1];

        i++;

    }

    seq_list->count--;

    return 0;

}
  • 注意事项:
  • 1.同方式1:形参传入到具有删除数据元素功能的函数后,需要做入参合理性检查
  • 2.也同方式1:还需要判断此时顺序表所存储的数据元素是否为空
  • 3.判断所要删除数据元素的位置在顺序表中是否合理,一定要区别在任意位置插入数据元素的位置合理性检查,两者略有不同,防止越界操作,所导致运行结果出错
  • 4.可以采用while循环或者for循环的方式找到所要删除数据元素的位置后,此位置之后的所有数据元素,依次向前挪动一个位置,目的是删除所指定的待删除位置
  • 5.删除所指定位置的数据元素后,记得count减1
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于顺序表删除元素可以分为两种情况:删除指定位置的元素删除指定值的元素。 1. 删除指定位置的元素: 首先判断要删除的位置是否合法。如果位置超出了表的范围,则无法删除。 如果位置合法,则将该位置后面的元素向前移动一位,并将表的长度减1。 2. 删除指定值的元素: 遍历整个顺序表,找到第一个等于指定值的元素,并记录其位置。 如果找到了该元素,则将该位置后面的元素向前移动一位,并将表的长度减1。 如果未找到该元素,则表示顺序表不存在该值。 下面是一个示例代码,演示了如何在顺序表删除指定位置或指定值的元素: ```cpp #include <iostream> using namespace std; // 定义顺序表结构体 struct SeqList { int* data; // 用于存储数据的数组 int length; // 当前存储的元素个数 int capacity; // 顺序表的容量 }; // 初始化顺序表 void initSeqList(SeqList& list, int capacity) { list.data = new int[capacity]; list.length = 0; list.capacity = capacity; } // 删除指定位置的元素 bool deleteAt(SeqList& list, int pos) { if (pos < 0 || pos >= list.length) { return false; // 位置非法,删除失败 } for (int i = pos + 1; i < list.length; i++) { list.data[i - 1] = list.data[i]; } list.length--; return true; } // 删除指定值的元素 bool deleteValue(SeqList& list, int value) { int pos = -1; // 记录要删除的位置 for (int i = 0; i < list.length; i++) { if (list.data[i] == value) { pos = i; break; } } if (pos != -1) { return deleteAt(list, pos); // 调用 deleteAt 删除指定位置的元素 } else { return false; // 指定值不存在,删除失败 } } // 输出顺序表元素 void printSeqList(const SeqList& list) { for (int i = 0; i < list.length; i++) { cout << list.data[i] << " "; } cout << endl; } // 测试代码 int main() { SeqList list; initSeqList(list, 10); // 插入一些元素 for (int i = 0; i < 5; i++) { list.data[i] = i + 1; list.length++; } // 输出顺序表 cout << "顺序表当前元素:" << endl; printSeqList(list); // 删除指定位置的元素 int pos = 2; if (deleteAt(list, pos)) { cout << "成功删除位置 " << pos << " 的元素:" << endl; printSeqList(list); } else { cout << "删除位置 " << pos << " 的元素失败" << endl; } // 删除指定值的元素 int value = 4; if (deleteValue(list, value)) { cout << "成功删除值为 " << value << " 的元素:" << endl; printSeqList(list); } else { cout << "删除值为 " << value << " 的元素失败" << endl; } return 0; } ``` 希望以上示例代码能帮助到你!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值