我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【C++】vector的使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【C++】vector的使用

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【C++】vector的使用

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

下载Word文档

猜你喜欢

【C++】vector的使用

1、vector的使用 #define _CRT_SECURE_NO_WARNINGS 1#include #include using namespace std;void Test1(){vectorint> v1;vectorint
2023-08-30

如何使用C++的vector

本篇内容介绍了“如何使用C++的vector”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!创建对象在C++中,官方文档所给的创建对象方法有4
2023-06-25

C++中vector怎么使用

小编给大家分享一下C++中vector怎么使用,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!一,什么是vectorvector(向量)是一个封装了动态大小数组的顺序容器。能够存放各种类型的对象(注:一个容器中所有对象必须是
2023-06-26

C++容器Vector如何使用

今天小编给大家分享一下C++容器Vector如何使用的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。Vector简介Vecto
2023-06-30

C++的vector使用方法有哪些

这篇文章主要讲解了“C++的vector使用方法有哪些”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++的vector使用方法有哪些”吧!C++vector 用法整理1.头文件#inclu
2023-06-29

C++如何使用std::vector容器

这篇文章给大家分享的是有关C++如何使用std::vector容器的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言vector实质是C++的一个类,与数组很相似,但是vector的优势是可以动态扩展,不需要考虑
2023-06-20

C++ vector的基本使用方法是什么

这篇文章主要介绍“C++ vector的基本使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“C++ vector的基本使用方法是什么”文章能帮助大家解决问题。一、vector和strin
2023-07-05

c++中vector怎么用

这篇文章将为大家详细讲解有关c++中vector怎么用,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、接口介绍1、插入数据void push_back(const T& x)在当前vector尾部插入x
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录