关于C++中的resize()函数在vector上的使用

一、resize()函数使用方法

#include<bits/stdc++.h>
using namespace std;
vector<int> v1;
vector<bool> v2;
vector<vector<int> > v3;

int main(){
    int n = 10;
    v1.resize(n+1);
    v2.resize(n+1);
    v3.resize(n+3);

    for(int i = 0; i < n; i++){
        int a, b, c;
        scanf("%d%d%d", &a, &b, &c);
        v1.push_back(a);
        v3[b].push_back(c);
        printf("v1[%d] = %d, v3[%d] = %dn", i, v1[i], b, v3[b][0]);
    } 
    return 0;
}

关于C++中的resize()函数在vector上的使用

原因

  1. 使用resize(n, v),这个函数会把空间控制成n个,然后这n个空间里面的会赋值为v,如果没有默认赋值为0。如上图所示这里单个数组,使用这个函数后,已经赋值完成,所以后面使用push_back()函数,插值会插不进入,输出的结果是前面已经赋值的n个0,这也是为啥会出现这样的结果。如果是二维的,它相当于开辟了n个vector向量,而这n个向量没有被开辟空间赋值,所以可以插入。

原文链接: https://www.cnblogs.com/tsruixi/p/13068580.html

欢迎关注

微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍;

也有高质量的技术群,里面有嵌入式、搜广推等BAT大佬

    关于C++中的resize()函数在vector上的使用

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/353665

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年3月2日 上午8:11
下一篇 2023年3月2日 上午8:11

相关推荐