iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >【C++】vector的使用
  • 214
分享到

【C++】vector的使用

c++ 2023-08-30 16:08:15 214人浏览 安东尼
摘要

1、vector的使用 #define _CRT_SECURE_NO_WARNINGS 1#include #include using namespace std;void Test1(){vector v1;vector v2(10,

1、vector的使用

在这里插入图片描述

#define _CRT_SECURE_NO_WARNINGS 1#include #include using namespace std;void Test1(){vector<int> v1;vector<int> v2(10, 15);vector<int> v3(v2.begin(), v2.end());string str("hello world");vector<char> v4(str.begin(), str.end());vector<char> v5(v4);//[下标]for (size_t i = 0; i < v3.size(); i++){cout << v3[i] << ' ';}cout << endl;//迭代器//vector::iterator it = v4.begin();auto it = v4.begin();while (it != v4.end()){cout << *it;it++;}cout << endl;//范围forfor (auto ch : v5){cout << ch;}}void Test2(){vector<int> v;//v.reserve(100); //reserve,size没变,还是从0开始size_t sz = v.capacity(); //初始容量for (int i = 0; i < 100; i++){v.push_back(i);if (sz != v.capacity()){sz = v.capacity();cout << "扩容:" << sz << endl;}}} void Test3(){vector<int> v;cout << v.max_size() << endl;//v.reserve(100); //error【size = 0    capacity 100】v.resize(100);    //【size = 100  capacity 100】【只能操控size以内的数据进行赋值、修改等】for (size_t i = 0; i < 100; i++){v[i] = i;}for (auto e : v){cout << e << " ";}cout << endl;}void Test4(){vector<int> v1;v1.push_back(1);v1.push_back(2);v1.push_back(3);v1.push_back(4);for (auto e : v1){cout << e << ' ';}cout << endl;//插入v1.insert(v1.begin(), 5); //提供的是地址,不是下标,在该位置前插入for (auto e : v1){cout << e << ' ';}cout << endl;//vector没有提供find,直接用算法库里的auto it = find(v1.begin(), v1.end(), 3);if (it != v1.end()) //【迭代器传区间都是左闭右开】{v1.insert(it, 30);}for (auto e : v1){cout << e << ' ';}cout << endl;//删除it = find(v1.begin(), v1.end(), 3);if (it != v1.end()){v1.erase(it);}for (auto e : v1){cout << e << ' ';}cout << endl;}void Test5(){vector<int> v;v.push_back(1);v.push_back(2);v.push_back(3);v.push_back(4);cout << "v.size() = " << v.size() << endl;cout << "v.capacity() = " << v.capacity() << endl;v.clear(); //只清数据(size),不清capacitycout << "clear后size = " << v.size() << endl;cout << "clear后capacity = " << v.capacity() << endl;}int main(){Test5();return 0;}

2、vector的OJ题

(1)二叉树的前序遍历

class Solution{public:    void preorder(Treenode* root, vector<int>& v)    {        if (root == nullptr)        {            return;        }        v.push_back(root->val);        preorder(root->left, v);        preorder(root->right, v);    }    vector<int> preorderTraversal(TreeNode* root)    {        vector<int> v1;        preorder(root, v1);        return v1;    }};

(2)只出现一次的数字Ⅰ

class Solution{public:    int singleNumber(vector<int>& nums)    {        size_t val = 0;        for (auto e : nums)        {            val ^= e;        }        return val;    }};

(3)杨辉三角

在这里插入图片描述

class Solution{public:    vector<vector<int>> generate(int numRows)    {        vector<vector<int>> vv;        vv.resize(numRows);        for (size_t i = 0; i < vv.size(); i++)        {            vv[i].resize(i + 1);            vv[i][0] = vv[i][vv[i].size() - 1] = 1;        }        for (size_t i = 0; i < numRows; i++)        {            for (size_t j = 0; j < vv[i].size(); j++)            {                if (vv[i][j] != 1)                {                    vv[i][j] = vv[i - 1][j] + vv[i - 1][j - 1];                }            }        }        return vv;    }};

(4)电话号码的字母组合

在这里插入图片描述

class Solution{    const char* numStrArr[10] = { "","","abc","def","ghi","jkl","mno","pqrs","tuv","wxyz" };public:    void combine(string& digits, int i, string combine_str, vector<string>& ret)    {        if (i == digits.size())        {            ret.push_back(combine_str);            return;        }        int num = digits[i] - '0'; //每次从digits取一个字符转成数字        string str = numStrArr[num]; //记录该数字对应的字符串                for (auto ch : str)        {            combine(digits, i + 1, combine_str + ch, ret);        }    }    vector<string> letterCombinations(string digits)    {        vector<string> v; //用来存放所有组合结果        if (digits.empty())        {            return v;        }        string str; //创建一个空字符串用来存每次的组合结果        combine(digits, 0, str, v);        return v;    }};

(5)删除有序数组中的重复项

class Solution{public:    //方法1:双指针+vector的使用        //方法2:双指针    int removeDuplicates(vector<int>& nums)    {        int slow = 0;        int fast = 1;        while (fast < nums.size())        {            if (nums[fast] == nums[slow])            {                fast++;            }            else            {                slow++;                nums[slow] = nums[fast];                fast++;            }        }        return slow + 1; //返回元素个数=下标+1    }};

(6)只出现一次的数字Ⅱ

在这里插入图片描述

class Solution{public:    void Swap(int* a, int* b)    {        int tmp = *a;        *a = *b;        *b = tmp;    }    int Partsort(int* a, int left, int right)    {        int keyi = left;        while (left < right)        {            //右边先开始            while (left < right && a[right] >= a[keyi])            {                right--;            }            //右边找到再找左边            while (left < right && a[left] <= a[keyi])            {                left++;            }            Swap(&a[left], &a[right]);        }        Swap(&a[left], &a[keyi]);        return left;    }    void nums_Sort(int* a, int begin, int end)    {        if (begin >= end)        {            return;        }        int keyi = Partsort(a, begin, end);        nums_Sort(a, begin, keyi - 1);        nums_Sort(a, keyi + 1, end);    }    //方法1:【先排序,再3个3个遍历数组    int singleNumber(vector<int>& nums)    {        //快排        nums_Sort(&nums[0], 0, nums.size() - 1);        int result;        for (int i = 0; i < nums.size(); i += 3)        {            //判出界            if (i + 1 >= nums.size())            {                result = nums[i];                break;            }            if (nums[i] != nums[i + 2])            {                result = nums[i];                break;            }        }        return result;    }    //方法2:【按位计算】    };

(7)只出现一次的数字Ⅲ

博客:👉【C/C++】x & -x 的含义


在这里插入图片描述

class Solution{public:    vector<int> singleNumber(vector<int>& nums)    {        //算出所有数异或后的和        int xorsum = 0;        for (auto e : nums)        {            xorsum ^= e;        }        //防止溢出        int lsb = (xorsum == INT_MIN ? xorsum : xorsum & (-xorsum)); //取出xorsum的二进制表示中最低位那个1        //按L位的不同分成两个组        int type1 = 0, type2 = 0;        for (auto f : nums)        {            if (f & lsb)            {                type1 ^= f; //二进制表示的第L位为1的数            }            else            {                type2 ^= f; //进制表示的第L位为0的数            }        }        return { type1,type2 };    }};

(8)数组中出现次数超过一半的数字

class Solution{public:    int MoreThanHalfNum_Solution(vector<int>& numbers)    {        sort(numbers.begin(),numbers.end()); //排序数组        return numbers[numbers.size()/2]; //取中间元素    }};

来源地址:https://blog.csdn.net/weixin_69231613/article/details/132229003

--结束END--

本文标题: 【C++】vector的使用

本文链接: https://www.lsjlt.com/news/383182.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 【C++】vector的使用
    1、vector的使用 #define _CRT_SECURE_NO_WARNINGS 1#include #include using namespace std;void Test1(){vector v1;vector v2(10,...
    99+
    2023-08-30
    c++
  • 如何使用C++的vector
    本篇内容介绍了“如何使用C++的vector”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!创建对象在C++中,官方文档所给的创建对象方法有4...
    99+
    2023-06-25
  • c++ vector的push_back如何使用
    在C++中,vector是一种动态数组,可以根据需要动态增长或缩小。push_back()函数用于在vector的末尾添加一个新元素...
    99+
    2024-04-02
  • C++STL中vector容器的使用
    目录一、vector(1)区分size()和capacity()(2)迭代器失效(3)区分const_iterator和const iterator(4)区分reserve()和re...
    99+
    2024-04-02
  • C++中vector怎么使用
    小编给大家分享一下C++中vector怎么使用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一,什么是vectorvector(向量)是一个封装了动态大小数组的顺序容器。能够存放各种类型的对象(注:一个容器中所有对象必须是...
    99+
    2023-06-26
  • C++ 容器 Vector 的使用方法
    目录Vector简介Vector 与数组创建 vector 的各种方法访问 vector 的元素删除元素前言: 我们都是带着问题学习,假设一个任务,也可以理解为一个问题,通过找解决方...
    99+
    2024-04-02
  • C++中vector<vector<int> >的基本使用方法
    目录前言一、为什么是vector?二、什么是vector?2.0 容器特性2.1. 基本操作2.2. 常见定义方法:2.3. 使用方法2.3.1 创建一维vector:2.3.2 定...
    99+
    2024-04-02
  • C++容器Vector如何使用
    今天小编给大家分享一下C++容器Vector如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vector简介Vecto...
    99+
    2023-06-30
  • C++的vector使用方法有哪些
    这篇文章主要讲解了“C++的vector使用方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++的vector使用方法有哪些”吧!C++vector 用法整理1.头文件#inclu...
    99+
    2023-06-29
  • C++如何使用std::vector容器
    这篇文章给大家分享的是有关C++如何使用std::vector容器的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言vector实质是C++的一个类,与数组很相似,但是vector的优势是可以动态扩展,不需要考虑...
    99+
    2023-06-20
  • C++入门之vector使用详解
    目录前言创建对象迭代器数据插入数据删除容量操作总结前言 兜兜转转,我们来到了C++的vector章节,今天就讲讲怎么使用vector吧. vector的本质就是一个线性的顺序表,只不...
    99+
    2024-04-02
  • c++中vector的使用和模拟实现
    一、接口介绍 1、插入数据 void push_back(const T& x) 在当前vector尾部插入x,如果容量不够扩大二倍。 iterator insert(it...
    99+
    2024-04-02
  • C++ vector的基本使用方法是什么
    这篇文章主要介绍“C++ vector的基本使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++ vector的基本使用方法是什么”文章能帮助大家解决问题。一、ve...
    99+
    2023-07-05
  • C++STL标准库std::vector的使用详解
    目录1. 简介2. 使用示例3. 构造、析构、赋值3.1 std::vector::vector 构造函数3.2 std::vector::~vector 析构函数3.3 std::...
    99+
    2024-04-02
  • C++  STL _ Vector使用及模拟实现
    目录1.Vector的介绍1.1 Vector的介绍2.Vector的使用2.1 vector的定义2.2 vector 迭代器的使用 2.3 vector的空间增长问题3...
    99+
    2024-04-02
  • c++中vector怎么用
    这篇文章将为大家详细讲解有关c++中vector怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、接口介绍插入数据void push_back(const T& x)在当前vector尾部插...
    99+
    2023-06-14
  • C++顺序容器(vector、deque、list)的使用详解
    目录一:STL(Standard Template Library),即标准模板库,是一个高效的C++程序库二:STL组件三:容器四:类型成员五:迭代器六:顺序容器七:顺序容器--向...
    99+
    2024-04-02
  • c++ 中vector 常见用法
    目录1、c++ 中 vector2、初始化3、常用函数 1、c++ 中 vector vector有两个参数,一个是size,表示当前vector容器内存储的元素个数,一个是capa...
    99+
    2024-04-02
  • C++ 基础函数的介绍及使用(Vector+deque+STL)
    目录一、Vector的基础函数1. 构造函数2. 增加元素3. 删除元素4. 遍历vector5. 判断函数6. 大小函数7. 其他函数二、deque的介绍及使用三、deque 和 ...
    99+
    2024-04-02
  • C++ vector::reserve()的用法是什么
    C++的vector类提供了reserve()函数,用于预留一定的内存空间,以便在后续的插入操作中避免不必要的重新分配和复制元素的操...
    99+
    2023-10-21
    C++
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作