#include<vector>

#include<vector>

查了下这个头文件的作用,现在搞不懂,先保存再说,貌似好用
先简单介绍一下,vector是一种顺序容器,事实上和数组差不多,但它比数组更优越。一般来说数组不能动态拓展,因此在程序运行的时候不是浪费内存,就是造成越界。而vector正好弥补了这个缺陷,它的特征是相当于可分配拓展的数组,它的随机访问快,在中间插入和删除慢,但在末端插入和删除快,而且如果你用.at()访问的话,也可以做越界检查。

#include <vector>

双端队列deque比向量vector更有优势
vector是动态数组,在堆上
vector比array更常用
不需要变长,容量较小,用array
需要变长,容量较大,用vector
1 at()

取出下标

2 c_str()

执行

3 clear()

清空

4 erase()

根据迭代器的位置,删除元素

erase(myvector.begin() + 3)

5 fill

填充

6 find

7 find_if

8 find_if_not

9 insert()

插入元素

insert(myvector.begin() + 3, 998);//在第4个位置插入

10 pop_back()

删除最后一个元素

11 push_back()

push_back,算法语言里面的一个函数名,如c++中的vector头文件里面就有这个push_back函数,在vector类中作用为在vector尾部加入一个数据。

12 size()

求数组元素个数

13 sort

排序

14 swap()

交换

1 at()

取出下标

4 erase()

根据迭代器的位置,删除元素

erase(myvector.begin() + 3)

5 insert()

插入元素

insert(myvector.begin() + 3, 998);//在第4个位置插入

6 pop_back()

删除最后一个元素

7 push_back()

push_back,算法语言里面的一个函数名,如c++中的vector头文件里面就有这个push_back函数,在vector类中作用为在vector尾部加入一个数据。

8 size()

求数组元素个数

1

三。在第2个位置前插入,新数据变成第2(从0开始计算的话)
38
39 for (int i = 0; i < myvector.size(); i++)//遍历
40 {

41 std::cout << myvector[i] << std::endl;
42 }
43 std::cout << std::endl;
44
45 system(“pause”);
46 }

2 c_str()

执行

3 clear()

清空

6 pop_back()

删除最后一个元素

7 push_back()

push_back,算法语言里面的一个函数名,如c++中的vector头文件里面就有这个push_back函数,在vector类中作用为在vector尾部加入一个数据。

8 size()

求数组元素个数

1

#include <iostream>
#include <vector>
using namespace std;

void main()
{
   
    std::vector<int>myvector;//创建一个数组,数组元素是int类型

    myvector.push_back(1);//尾部加入一个数据
    myvector.push_back(11);
    myvector.push_back(111);
    myvector.push_back(1111);
    myvector.push_back(2);

    myvector.pop_back();//删除尾部元素

    for (int i = 0; i < myvector.size(); i++)//遍历
    {
   
        //std::cout << myvector[i] << std::endl;//上下一样
        std::cout << myvector.at(i) << std::endl;//上下一样,at()可以取出下标
    }
    std::cout << std::endl;

    //根据迭代器的位置删除
    myvector.erase(myvector.begin() + 3);//删除第四个元素。删除第3个元素(从0开始计算的话)

    for (int i = 0; i < myvector.size(); i++)//遍历
    {
   
        if (1)
        {
   
            //可以增加查询,修改功能
        }
        std::cout << myvector[i] << std::endl;
    }
    std::cout << std::endl;

    myvector.insert(myvector.begin() + 2, 998);//在第三个位置前插入,新数据变成第三。在第2个位置前插入,新数据变成第2(从0开始计算的话)

    for (int i = 0; i < myvector.size(); i++)//遍历
    {
   
        std::cout << myvector[i] << std::endl;
    }
    std::cout << std::endl;

    system("pause");
}

//正向迭代器iterator,begin()返回一个迭代器,它指向容器c的第一个元素,end()返回一个迭代器,它指向容器c的最后一个元素的下一个位置

//反向迭代器reverse_iterator,rbegin()返回一个逆序迭代器,它指向容器c的最后一个元素,rend()返回一个逆序迭代器,它指向容器c的第一个元素前面的位置

image

反向迭代器是一种反向遍历容器的迭代器。也就是,从最后一个元素到第一个元素遍历容器。反向迭代器将自增(和自减)的含义反过来了:对于反向迭代 器,++ 运算将访问前一个元素,而 – 运算则访问下一个元素。

1


```cpp
    #include <iostream>
#include <vector>
using namespace std;

void main()
{
   
    std::vector<std::string>string1;//创建一个字符串数组

    string1.clear();//清空

    string1.push_back("notepad");//尾部加入
    string1.push_back("calc");
    string1.push_back("mspaint");

    //正向迭代器iterator,begin()返回一个迭代器,它指向容器c的第一个元素,end()返回一个迭代器,它指向容器c的最后一个元素的下一个位置
    std::vector<std::string>::iterator ibegin, iend;//创建两个迭代器指针
    ibegin = string1.begin();//初始化迭代器指针,数据起始点
    iend = string1.end();//初始化迭代器指针,结束

    for (; ibegin != iend; ibegin++)//从头到尾
    {
   
        std::string tempstr = *ibegin;//创建中间临时变量,获取指针指向的数据
        system(tempstr.c_str());//执行
    }

    //反向迭代器reverse_iterator,rbegin()返回一个逆序迭代器,它指向容器c的最后一个元素,rend()返回一个逆序迭代器,它指向容器c的第一个元素前面的位置
    std::vector<std::string>::reverse_iterator rbegin = string1.rbegin();//创建迭代器指针,数据起始点
    std::vector<std::string>::reverse_iterator rend = string1.rend();//创建迭代器指针,结束

    while (rbegin != rend)//从尾到头
    {
   
        std::string tempstr = *rbegin;//获取指针指向的数据
        system(tempstr.c_str());//执行
        rbegin++;//指针移动
    }

    system("pause");
}

7 push_back()

push_back,算法语言里面的一个函数名,如c++中的vector头文件里面就有这个push_back函数,在vector类中作用为在vector尾部加入一个数据。

8 size()

求数组元素个数

 

//创建一个数组变量,元素是数组

vector可用于管理不规则的树状结构

国家-省-市县


#include <iostream>
#include <vector>
using namespace std;

void main()
{
   
    std::vector<int>myvector1;//创建一个数组变量,元素是int类型
    myvector1.push_back(12);
    myvector1.push_back(13);
    myvector1.push_back(14);

    std::vector<int>myvector2;//创建一个数组变量,元素是int类型
    myvector2.push_back(22);

    std::vector<int>myvector3;//创建一个数组变量,元素是int类型
    myvector3.push_back(32);
    myvector3.push_back(37);

    std::vector<std::vector<int>>allvector;//创建一个数组变量,元素是数组
    allvector.push_back(myvector1);
    allvector.push_back(myvector2);
    allvector.push_back(myvector3);

    for (int i = 0; i < allvector.size(); i++)//遍历
    {
   
        for (int j = 0; j < allvector[i].size(); j++)
        {
   
            std::cout << " " << allvector[i][j];
        }
        std::cout << std::endl;
    }

    system("pause");
}

fill

#include <iostream>
#include <algorithm>
#include <vector>

template <class T>
class show
{
   
public:
    void operator()(T &t)
    {
   
        std::cout << t << " ";
    }
};

void main()
{
   
    std::vector<int>myv;

    myv.push_back(7);
    myv.push_back(8);
    myv.push_back(9);
    myv.push_back(4);
    myv.push_back(5);
    myv.push_back(6);

    fill(myv.begin() + 2, myv.end(), 10);//从下标2开始到尾部,用10填充
    
    for_each(myv.begin(), myv.end(), show<int>());
}

find

#include <iostream>
#include <vector>

void main()
{
   
    std::vector<int>myv;

    myv.push_back(1);
    myv.push_back(2);
    myv.push_back(3);

    auto i = find(myv.begin(), myv.end(), 22);

    if (i == myv.end())
    {
   
        std::cout << "not found" << std::endl;
    }
    else
    {
   
        std::cout << *i << std::endl;
    }
}

sort

全部元素排序

#include <iostream>
#include <algorithm>
#include <vector>

template <class T>
class show
{
   
public:
    void operator()(T &t)
    {
   
        std::cout << t << " ";
    }
};

void main()
{
   
    std::vector<int>myv;

    myv.push_back(7);
    myv.push_back(8);
    myv.push_back(9);
    myv.push_back(4);
    myv.push_back(5);
    myv.push_back(6);

    sort(myv.begin(), myv.end());//排序
    
    for_each(myv.begin(), myv.end(), show<int>());
}
sort

部分元素排序
  #include <iostream>
#include <algorithm>
#include <vector>

template <class T>
struct show
{
   
public:
    void operator()(T &t)
    {
   
        std::cout << t << " ";
    }
};

void main()
{
   
    std::vector<char>myv;

    myv.push_back('B');
    myv.push_back('A');
    myv.push_back('C');
    myv.push_back('Y');
    myv.push_back('Z');
    myv.push_back('X');

    for_each(myv.begin(), myv.end(), show<char>());
    std::cout << std::endl;

    sort(myv.begin(), myv.begin() + 3);

    for_each(myv.begin(), myv.end(), show<char>());
    std::cout << std::endl;
}
   
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/114927.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • acwing1185. 单词游戏(欧拉图)「建议收藏」

    acwing1185. 单词游戏(欧拉图)「建议收藏」有 N 个盘子,每个盘子上写着一个仅由小写字母组成的英文单词。你需要给这些盘子安排一个合适的顺序,使得相邻两个盘子中,前一个盘子上单词的末字母等于后一个盘子上单词的首字母。请你编写一个程序,判断是否能达到这一要求。输入格式第一行包含整数 T,表示共有 T 组测试数据。每组数据第一行包含整数 N,表示盘子数量。接下来 N 行,每行包含一个小写字母字符串,表示一个盘子上的单词。一个单词可能出现多次。输出格式如果存在合法解,则输出”Ordering is possible.”,否则输出”The

    2022年8月9日
    3
  • vue单页面应用的原理

    vue单页面应用的原理通常的url地址由什么构成呢:协议名域名端口号路径参数哈希值比如:http://www.itcast.cn:80/home/index?name=zs#absdklfajdf当哈希值改变(哈希值就是:#absdklfajdf),页面不会发生跳转,单页面应用就是利用了这一点:单页面应用因为只有一个页面,所以页面不能发生跳转,但是,我们又需要根据url地址来展示不同的组件…

    2022年6月28日
    28
  • C语言结构体(struct)常见使用方法[通俗易懂]

    C语言结构体(struct)常见使用方法[通俗易懂]注意:盗版是不会得到修正和更新的!今天复习一下struct,顺便挖掘一下以前没注意的小细节:基本定义:结构体,通俗讲就像是打包封装,把一些有共同特征(比如同属于某一类事物的属性,往往是某种业务相关属性的聚合)的变量封装在内部,通过一定方法访问修改内部变量。(因为C++和C有共通之处,但是在结构体上的某些机制又有所不同,所以后边提了一下,不喜欢可以略过)结构体定义:…

    2022年5月12日
    74
  • 教你如何免费将XPS转换为PDF格式

    教你如何免费将XPS转换为PDF格式XPS文件在我们日常工作中使用比较少,大部分时候我们都会将它转换成PDF格式后进行修改或保存等操作,不懂这种文档要怎么打开?其实这些都不重要,只要你知道PDF就可以,教你几种将XPS转成PDF的方法,还有免费使用哦。1、另存文档目前很多PDF软件都可以直接打开XPS文件,这里我们推荐使用极速PDF阅读器打开XPS文档,然后将文档另存为PDF格式就可以了,这个方式是不是超级简单实用。2、在线转换只需要电脑打开百度浏览器搜索speedpdf找到并打开这款在线免费转换工具,选择XPS转PD

    2022年6月4日
    46
  • UNet详解(附图文和代码实现)

    卷积神经网络被大规模的应用在分类任务中,输出的结果是整个图像的类标签。但是UNet是像素级分类,输出的则是每个像素点的类别,且不同类别的像素会显示不同颜色,UNet常常用在生物医学图像上,而该任务中图片数据往往较少。所以,Ciresan等人训练了一个卷积神经网络,用滑动窗口提供像素的周围区域(patch)作为输入来预测每个像素的类标签。这个网络有两个优点:(1)输出结果可以定位出目标类别的位置;(2)由于输入的训练数据是patches,这样就相当于进行了数据增强,从而解决了生物医学图像数量少的问题。但是,

    2022年4月4日
    225
  • k8s中pod的状态包括_k8s pod状态

    k8s中pod的状态包括_k8s pod状态文章目录第五章 Pod详解5.1 Pod介绍5.1.1 Pod结构5.1.2 Pod定义5.2 Pod配置5.2.1 基本配置5.2.2 镜像拉取5.2.3 启动命令5.2.4 环境变量5.2.5 端口设置5.2.6 资源配额5.3 Pod生命周期5.3.1 创建和终止5.3.2 初始化容器5.3.3 钩子函数5.3.4 容器探测5.3.5 重启策略5.4 Pod调度5.4.1 定向调度5.4.2 亲和性调度NodeAffinityPodAffinityPodAntiAffinity5.4.3 污点和容忍

    2022年8月11日
    4

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号