当前位置: 首页 > article >正文

c++算法——vector

vector

        vector 是标准模板库的一个容器,直接翻译为“向量”,一般来成“可变长数组”,也即“长度会根据需要而变化的数组”。在竞赛中有些题目需要很大的很大的数组,而有些还用不上就需要用到 vector 。

        使用 vector 首先要加#include <vector>,当然万能头也包含他,同时,必须要有 “using namespace std;”。

vector 定义

定义一个 vector 方法如下:

vector<int> a;//int类型的vector
vector<double> a;//double的
vector<char> a;//字符的
vector<node> a;//node是个结构体,结构体类型的

vector数组定义

vector<int> a[100];//定义一个一维长度固定为100(行固定),另一个维度不固定(列不固定)

vector<vector<int> > a;//定义一个两个维度都可以变的二维数组 

vector访问

1,下标访问

他可以使用数组的访问方法a[i]

 2,迭代器访问

vector<int>::iterator it;  //定义迭代器

可以通过*it来访问 。

vector常用函数                           作用

  1. push_back(元素)         添加一个元素到 vector 后边,时间复杂度O(1)
  2. pop_back()                  弹出(删除) vector 的最后一个元素,复杂度O(1)
  3. insert(位置,元素)       插入元素x到 vector 的指定位置it(迭代器)处,复杂度O(n)
  4. erase(位置)                  删除 vector 指定位置的元素
  5. clear()                          清除 vector 所有元素,size变为0,复杂度O(n)
  6. front()                           取 vector 的第一个元素
  7. back()                           取 vector 的最后一个元素
  8. begin()                          vector 的的第一个元素的位置,返回第一个元素的迭代器
  9. end()                             返回最后一个元素的后面位置(不是最后一个元素的迭代器)
  10. size()                             元素个数,vector 的大小,即 vector 中已有的元素的个数
  11. resize(大小)                  重新设置 vector 的大小
  12. empty                            判断 vector 是否为空

例题 

中间数

题目描述

依次读入若干正整数,如果是奇数个就输出最中间的那个数;否则,输出中间两个数的和。

以 0 作为结束标志,但 0 不计数。

输入格式

一行若干个正整数,为 0 为结束标志。

输出格式

一个数。

样例输入

1 2 3 0

样例输出

2

样例输入

1 2 3 4 0

样例输出

5


http://www.kler.cn/a/15665.html

相关文章:

  • 【Linux内核剖析】深入分析inet_init的处理机制
  • rk3399开发环境使用Android 10初体验蓝牙功能
  • 物理hack
  • SAFETY LAYERS IN ALIGNED LARGE LANGUAGEMODELS: THE KEY TO LLM SECURITY
  • mysql数据迁移PolarDB
  • 单元测试、集成测试、系统测试、验收测试、压力测试、性能测试、安全性测试、兼容性测试、回归测试(超详细的分类介绍及教学)
  • Apache Hudi初探(二)(与spark的结合)
  • 用 AudioGPT 输入自然语言,可以让 ChatGPT 唱歌了?
  • 借助尾号限行 API 实现限行规则应用的设计思路分析
  • ElasticSearch创建文档以及索引文档的详细流程
  • 防火墙GRE和NAT
  • 【裸金属服务器】安装VMware ESXi
  • 项目合同管理
  • Haproxy搭建Web群集
  • python实战应用讲解-【numpy数组篇】常用函数(七)(附python示例代码)
  • Matlab高光谱遥感、数据处理与混合像元分解及典型案例
  • 带你搞懂人工智能、机器学习和深度学习!
  • Springboot +Flowable,详细解释啥叫流程实例(一)
  • 前端系列第10集-实战篇
  • Linux:网络套接字
  • 【SpringBoot系列】实现跨域的几种方式
  • 院内导航方案怎么样?什么地图可以用于医院导航系统?
  • effective c++ item35-39
  • Apache Druid中Kafka配置远程代码执行漏洞(MPS-2023-6623)
  • 工厂能耗管理系统linux嵌入式边缘网关
  • 元宇宙展厅--音乐科技展厅