news 2026/6/26 15:37:00

Vector(顺序表)详解

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vector(顺序表)详解

1. 顺序表基本概念

1.1 线性表定义

  • 线性表是n个具有相同特性的数据元素的有序序列

  • 逻辑上呈现为连续的线段结构

1.2 顺序存储结构

  • 顺序表是线性表的顺序存储实现

  • 元素存储在连续的内存空间中,类似于数组

2. 顺序表的实现方式

2.1 静态顺序表

const int N = 1e6 + 10; // 预定义最大容量 int a[N], n; // 静态数组 + 元素个数计数器

优缺点:

  • ✅ 优点:代码简单,无动态内存管理开销

  • ❌ 缺点:空间固定,可能浪费或不足

2.2 动态顺序表(vector)

  • 按需动态分配内存

  • C++ STL中的vector是典型的动态顺序表实现

3. 顺序表基本操作及时间复杂度

3.1 插入操作

操作类型

时间复杂度

代码示例

尾插

O(1)

a[++n] = x

头插

O(n)

所有元素右移一位

任意位置插入

O(n)

部分元素右移

3.2 删除操作

操作类型

时间复杂度

代码示例

尾删

O(1)

n--

头删

O(n)

所有元素左移一位

任意位置删除

O(n)

部分元素左移

3.3 查找操作

操作类型

时间复杂度

代码示例

按值查找

O(n)

遍历整个数组

按位查找

O(1)

return a[p]

3.4 修改操作

  • 时间复杂度:O(1)

  • 代码示例:a[p] = x

4. Vector(STL动态顺序表)

4.1 创建vector

vector<int> a1; // 空vector vector<int> a2(N); // 大小为N,默认值0 vector<int> a3(N, 2); // 大小为N,初始值2 vector<int> a4 = {1,2,3,4,5}; // 初始化列表 vector<vector<int>> a5; // 二维vector

4.2 常用接口及时间复杂度

基本信息
  • size(): 返回元素个数 - O(1)

  • empty(): 判断是否为空 - O(1)

迭代器
  • begin(): 起始迭代器

  • end(): 结束迭代器(最后一个元素的下一个位置)

元素访问
  • front(): 首元素 - O(1)

  • back(): 尾元素 - O(1)

  • operator[]: 随机访问 - O(1)

修改操作
  • push_back(x): 尾插 - 平均O(1)

  • pop_back(): 尾删 - O(1)

  • resize(new_size): 调整大小 - O(n)

  • clear(): 清空 - O(n)

4.3 遍历方式

// 1. 下标遍历 for(int i = 0; i < a.size(); i++) cout << a[i] << " "; // 2. 迭代器遍历 for(auto it = a.begin(); it != a.end(); it++) cout << *it << " "; // 3. 范围for循环 for(auto x : a) cout << x << " ";

5. Vector封装示例

struct SqList { static const int N = 1e6 + 10; int a[N], n; SqList() { n = 0; } void push_back(int x) { a[++n] = x; } void pop_back() { n--; } void print() { for(int i = 1; i <= n; i++) cout << a[i] << " "; cout << endl; } };

6. 算法题应用

6.1 基础应用

  • 询问学号:直接使用vector随机访问特性

  • 寄包柜:使用vector数组模拟二维结构

6.2 双指针技巧

  • 移动零:快慢指针划分数组

  • 颜色分类:三指针划分三种颜色

  • 合并有序数组:从后往前归并避免覆盖

7. 编程模式对比

ACM模式

#include<iostream> #include<vector> using namespace std; int main() { int n, m; cin >> n >> m; vector<int> a(n); for(int i = 0; i < n; i++) cin >> a[i]; // 处理逻辑... return 0; }

核心代码模式

class Solution { public: void function(vector<int>& nums) { // 只需实现核心逻辑 } };

8. 关键总结

8.1 Vector优势

  • 动态扩容,内存使用更合理

  • 提供丰富的接口,使用方便

  • 支持随机访问,效率高

8.2 使用注意事项

  • 避免频繁的中间插入删除(O(n)操作)

  • 大规模数据时注意扩容开销

  • 多维vector注意内存使用

8.3 适用场景

  • 需要频繁随机访问

  • 数据量变化不大或主要在尾部操作

  • 算法竞赛中空间充足的情况

vector作为C++中最常用的顺序容器,结合了数组的高效访问和动态扩容的灵活性,是解决各类算法问题的利器。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/25 22:28:41

5分钟掌握AMD Ryzen超频秘诀:SMUDebugTool终极实战教程

5分钟掌握AMD Ryzen超频秘诀&#xff1a;SMUDebugTool终极实战教程 【免费下载链接】SMUDebugTool A dedicated tool to help write/read various parameters of Ryzen-based systems, such as manual overclock, SMU, PCI, CPUID, MSR and Power Table. 项目地址: https://g…

作者头像 李华
网站建设 2026/6/26 9:53:49

基于STM32的两路PWM互补输出带死区:编程与仿真探索

基于stm32的两路pwm互补输出带死区。 编程仿真在电机控制等诸多应用场景中&#xff0c;我们常常需要用到PWM&#xff08;脉冲宽度调制&#xff09;互补输出且带有死区的功能。这不仅能够有效避免上下桥臂直通造成的短路风险&#xff0c;还能更精准地控制功率器件。今天咱们就来…

作者头像 李华
网站建设 2026/6/21 0:02:51

探索两阶段鲁棒优化程序:以微网模型为核心

两阶段鲁棒优化程序 采用微网为模型&#xff0c;主要将安装成本、运营成本以及综合效益三个方面纳入考虑范围&#xff0c;建立两阶段鲁棒优化模型&#xff0c;采用的是CCG方法&#xff0c;本程序为matlab编制&#xff0c;有售后&#xff0c;可以进行&#xff01;另外本程序考虑…

作者头像 李华
网站建设 2026/6/24 18:21:52

刚开始学网络技术,毫无头绪?看我这篇零基础网络技术学习指南:从零基础入门到精通,收藏这一篇就够了!

刚开始学网络技术&#xff0c;毫无头绪&#xff1f;看我这篇零基础网络技术学习指南&#xff1a;从入门到精通 对于网络技术初学者来说&#xff0c;庞大的知识体系常常让人不知从何下手。我在后台也一直看到私信说 &#xff1a;老师&#xff0c;我刚开始学网络技术&#xff0c…

作者头像 李华
网站建设 2026/6/19 14:57:19

程序员考证,这十大证书含金量最高嵌入式十大含金量证书

程序员考证&#xff0c;这十大证书含金量最高_嵌入式十大含金量证书 前言 某乎上有一个话题&#xff1a;程序员考证的意义是什么&#xff1f; 程序员考证的意义 很多人说&#xff0c;程序员大概是除医疗、建筑以外所考证书最多的一个行业。考证&#xff0c;不仅是对个人实力…

作者头像 李华