C++:STL - vector

news2025/1/12 20:04:34

C++:STL - vector

    • 构造函数
    • 修改操作
      • push_back
      • pop_back
      • erase
    • 访问操作
      • empty
      • operatror[]
      • back
      • front
    • 容量操作
      • size
      • capacity
      • resize
      • reserve


C++的vector是一种可变长度的动态数组,被广泛用于C++编程中。它是标准模板库(STL)中的容器之一,提供了比原始数组更灵活和方便的操作。

vector可以存储任意类型的元素,包括基本类型(如整数和浮点数)和自定义类型(如类和结构体)。它的大小可以根据需要动态调整,而不需要手动管理内存。

vector支持随机访问,即可以通过下标直接访问容器中的元素。它还提供了一系列的成员函数和操作符,如插入、删除和查找等,使得对元素的操作变得更加方便和高效。

vector的内部实现使用了动态数组,当存储元素的个数超过当前容量时,会自动分配更大的内存空间,并将元素从旧的内存复制到新的内存中。这种动态分配和释放内存的特性使得vector能够有效地处理不可预知的元素个数。

要使用vector,首先需要包含头文件<vector>。然后可以用vector< T >声明一个vector对象,其中T表示要存储的元素类型。例如,可以使用vector< int >来声明一个存储整数的vector对象。

vector是C++中非常实用的容器,它提供了简洁、高效的操作,使得动态数组的使用变得更加方便。使用vector可以避免手动管理内存和处理数组大小的复杂逻辑。


构造函数

在这里插入图片描述
vector提供了多种构造函数来创建和初始化vector对象。

  1. 默认构造函数:

    vector();
    

    用于创建一个空的vector。
    示例:

    vector<int> vec;  // 创建一个空的整数类型的vector
    
  2. 带有初始值的构造函数:

    vector(size_type count, const T& value = T());
    

    创建包含count个元素的vector,每个元素都初始化为value的值。
    示例:

    vector<int> vec(5, 10);  // 创建一个包含5个元素,每个元素都为10的整数类型的vector
    
  3. 基于范围的构造函数:

    template <class InputIterator>
    vector(InputIterator first, InputIterator last);
    

    创建一个包含[first, last)范围内元素的vector。
    示例:

    int arr[] = {1, 2, 3, 4, 5};
    vector<int> vec(arr, arr + 5);  // 创建一个包含数组中所有元素的整数类型的vector
    
  4. 拷贝构造函数:

    vector(const vector& other);
    

    创建一个与other相同元素的vector。
    示例:

    vector<int> vec1(5, 10);  // 创建一个包含5个元素,每个元素都为10的整数类型的vector
    vector<int> vec2(vec1);   // 创建一个与vec1相同元素的整数类型的vector
    

以上是vector的常用构造函数,可以根据具体需求选择合适的构造函数来创建vector对象。


修改操作

push_back

push_back()vector类的成员函数之一,用于在vector的尾部插入一个新的元素。

push_back()函数的语法如下:

void push_back (const value_type& val);

其中,value_type表示vector中存储的元素类型,val是要插入的新元素。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> myVector;

    // 使用push_back()函数插入元素
    myVector.push_back(10);
    myVector.push_back(20);
    myVector.push_back(30);

    // 打印vector中的元素
    for(int i = 0; i < myVector.size(); i++) {
        std::cout << myVector[i] << " ";
    }
    std::cout << std::endl;

    return 0;
}

输出结果为:

10 20 30

首先,我们创建了一个空的vector对象myVector。然后,使用三次push_back()函数分别插入了整数值102030。最后,通过循环遍历vector,打印出了vector中的元素。

可以看到,push_back()函数将新元素添加到了vector的尾部。由于vector是动态大小的,因此可以随时在尾部插入新的元素,并且vector会自动调整大小以容纳新的元素。

需要注意的是,push_back()函数的参数是一个常量引用,这是为了防止在插入元素时进行不必要的拷贝操作,以提高性能。


pop_back

vectorpop_back()函数用于删除向量中的最后一个元素,并将容器的大小减1。不返回任何值。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec;
    
    // 向向量中插入元素
    vec.push_back(1);
    vec.push_back(2);
    vec.push_back(3);
    
    std::cout << "元素:";
    for (int i : vec) {
        std::cout << " " << i;
    }
    std::cout << std::endl;
    
    // 使用pop_back()函数删除最后一个元素
    vec.pop_back();
    
    std::cout << "删除最后一个元素后:";
    for (int i : vec) {
        std::cout << " " << i;
    }
    std::cout << std::endl;
    
    return 0;
}

输出结果:

元素: 1 2 3
删除最后一个元素后: 1 2

在上面的代码中,我们首先创建了一个空的vector vec。然后使用push_back()函数向向量中插入三个元素(1,2,3)。接下来,我们使用pop_back()函数删除最后一个元素。最后,我们分别使用循环打印出原始的和删除最后一个元素后的vector

需要注意的是,如果vector是空的,调用pop_back()函数将引发未定义的行为。因此,在使用pop_back()函数之前,最好先检查vector是否为空。可以使用empty()函数来完成此操作。


erase

vectorerase函数用于删除指定位置的元素,其原型如下:

iterator erase (iterator position);
iterator erase (iterator first, iterator last);

第一种形式的erase函数用于删除指定位置的元素,它接受一个迭代器参数position,表示要删除的元素的位置。该函数返回一个指向被删除元素之后元素的迭代器。

第二种形式的erase函数用于删除指定范围内的元素,它接受两个迭代器参数firstlast,表示要删除的范围。该函数删除范围内的所有元素,并返回一个指向最后一个被删除元素之后元素的迭代器。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> v = {1, 2, 3, 4, 5};
    
    // 删除指定位置的元素
    std::vector<int>::iterator it = v.begin() + 2;
    it = v.erase(it);
    // 输出: 1 2 4 5
    for (int i : v) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    
    // 删除指定范围内的元素
    std::vector<int>::iterator first = v.begin() + 1;
    std::vector<int>::iterator last = v.begin() + 3;
    v.erase(first, last);
    // 输出: 1 5
    for (int i : v) {
        std::cout << i << " ";
    }
    std::cout << std::endl;
    
    return 0;
}

在上述代码中,我们首先创建了一个vector对象v,并初始化了5个元素。然后我们使用erase函数删除了指定位置的元素(第3个元素),并输出了剩余的元素。接着我们使用erase函数删除了指定范围内的元素(第2个和第3个元素),并再次输出了剩余的元素。

输出结果如下:

1 2 4 5
1 5

通过这个例子,我们可以看到使用erase函数可以有效地删除vector中的元素。


访问操作

empty

vectorempty函数可以用来检查向量是否为空。当向量为空时,返回true;否则,返回false

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> numbers;

    if (numbers.empty()) {
        std::cout << "vector为空" << std::endl;
    } else {
        std::cout << "vector不为空" << std::endl;
    }

    numbers.push_back(10);

    if (numbers.empty()) {
        std::cout << "vector为空" << std::endl;
    } else {
        std::cout << "vector不为空" << std::endl;
    }
    
    return 0;
}

在这个例子中,开始时我们声明了一个numbers。然后,我们使用empty函数检查vector是否为空。由于开始时vector是空的,所以输出的结果是"vector为空"。

接着,我们使用push_back函数向vector中添加一个元素10。然后再次使用empty函数检查vector是否为空。由于vector中现在有一个元素,所以输出的结果是"vector不为空"。

通过这个例子,我们可以看到empty函数的用法和作用。它可以帮助我们判断一个vector是否为空,从而对vector进行进一步的操作。


operatror[]

vector可以提供高效的随机访问。
vectoroperator[]是一个重载运算符,用于访问vector中的元素。它的语法是vector_name[index],其中vector_namevector的名称,index是要访问的元素的索引。索引从0开始,表示vector中的第一个元素。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> numbers = {1, 2, 3, 4, 5};

    // 使用operator[]访问vector中的元素
    std::cout << numbers[0] << std::endl;  // 输出: 1
    std::cout << numbers[2] << std::endl;  // 输出: 3

    // 修改vector中的元素
    numbers[1] = 10;

    // 输出修改后的元素
    std::cout << numbers[1] << std::endl;  // 输出: 10

    return 0;
}

在上面的示例中,我们首先创建了一个vectornumbers并初始化了一些整数。然后,我们使用numbers[0]numbers[2]访问了vector中的元素,并将它们输出到控制台上。接着,我们将第二个元素修改为10,再次使用numbers[1]访问并输出修改后的元素。

需要注意的是,当使用operator[]访问vector时,如果索引超出了vector的范围,没有元素与该索引对应,将会导致未定义行为。因此,在使用operator[]之前,最好确保索引在合法范围内。


back

vectorback函数用于返回容器中最后一个元素的引用,即最后一个元素的值。如果容器为空,则未定义行为

案例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec;

    vec.push_back(10);
    vec.push_back(20);
    vec.push_back(30);

    int& lastElement = vec.back(); // 获取最后一个元素的引用

    std::cout << "最后一个元素的值为:" << lastElement << std::endl;

    return 0;
}

运行结果:

最后一个元素的值为:30

在上述案例中,我们创建了一个名为vecvector容器,并使用push_back函数依次将数值10、20和30添加到容器中。然后,通过调用back函数获取容器vec中最后一个元素的引用,并将其保存在lastElement变量中。最后,我们将所获得的最后一个元素的值打印出来。

需要注意的是,如果容器为空,那么调用back函数将会导致未定义行为。因此,在使用back函数之前,最好先使用empty函数检查容器是否为空。


front

front()vector容器的一个成员函数,用于获取容器中第一个元素的值。
示例:

#include <iostream>
#include <vector>

int main() {
    // 创建一个vector容器
    std::vector<int> myVector;

    // 向容器中添加元素
    myVector.push_back(10);
    myVector.push_back(20);
    myVector.push_back(30);

    // 使用front()函数获取容器中第一个元素的值
    int firstElement = myVector.front();

    // 输出第一个元素的值
    std::cout << "The first element is: " << firstElement << std::endl;

    return 0;
}

上面的代码首先创建了一个名为myVectorvector容器,并向其中添加了三个整数元素:10、20和30。然后使用front()获取了容器中第一个元素的值,并将其赋值给了变量firstElement。最后,通过cout输出了第一个元素的值。

运行上述代码,将会得到如下输出结果:

The first element is: 10

需要注意的是,如果vector容器为空,则调用front()函数将会引发未定义行为。因此,在使用front()之前,最好先检查vector是否为空,可以使用empty()进行判断。


容量操作

size

vectorsize函数用于获取vector中元素的数量。
示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> numbers = {1, 2, 3, 4, 5};

    std::cout << "Size of vector numbers: " << numbers.size() << std::endl;

    return 0;
}

在上述示例中,我们创建了一个名为numbersvector,并初始化它包含5个整数元素。然后,我们使用size函数获取vector numbers的大小,并将其打印出来。输出结果将是:

Size of vector numbers: 5

可以看到,numbers的大小为5,即它包含5个元素。


capacity

capacityvector中可以存储元素的总空间大小。

vector中的元素数量超过了它的容量时,vector会自动分配更多的内存空间,以容纳更多的元素。这个过程称为动态内存分配。动态内存分配是一种消耗时间和计算资源的操作,因此vector会在必要时一次性分配较大的内存空间,以减少动态内存分配的频率。

下面是一个案例,演示vector的capacity的变化:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec;

    std::cout << "Initial capacity: " << vec.capacity() << std::endl;
    std::cout << "Initial size: " << vec.size() << std::endl;

    // 向vector中添加元素
    for (int i = 0; i < 10; i++) {
        vec.push_back(i);
        std::cout << "Capacity after adding element " << i << ": " << vec.capacity() << std::endl;
        std::cout << "Size after adding element " << i << ": " << vec.size() << std::endl;
    }

    return 0;
}

输出结果为:

Initial capacity: 0
Initial size: 0
Capacity after adding element 0: 1
Size after adding element 0: 1
Capacity after adding element 1: 2
Size after adding element 1: 2
Capacity after adding element 2: 4
Size after adding element 2: 3
Capacity after adding element 3: 4
Size after adding element 3: 4
Capacity after adding element 4: 8
Size after adding element 4: 5
Capacity after adding element 5: 8
Size after adding element 5: 6
Capacity after adding element 6: 8
Size after adding element 6: 7
Capacity after adding element 7: 8
Size after adding element 7: 8
Capacity after adding element 8: 16
Size after adding element 8: 9
Capacity after adding element 9: 16
Size after adding element 9: 10

可以看到,vector在添加元素时,当元素数量超过当前容量时,会自动增加容量。初始时,vector的容量为0,添加第一个元素后,容量变为1;添加第二个元素后,容量变为2;添加第三个元素后,容量变为4;依次类推。当容量不足时,vector会分配更大的内存空间,容量会以指数级增长。注意,vector的容量并不等于元素的数量,它可以大于等于元素数量。


resize

vectorresize()函数是用于改变vector的大小的,它可以增加或缩小vector的元素数量。

resize()函数有两种形式:

  1. resize(n):将vector的大小改变为n。如果n小于当前的大小,则vector将被截断为前n个元素。如果n大于当前的大小,则vector的大小将增加,在末尾添加默认值的元素。

  2. resize(n, val):将vector的大小改变为n,并用val填充新添加的元素。如果n小于当前的大小,则vector将被截断为前n个元素。如果n大于当前的大小,则vector的大小将增加,新添加的元素用val填充。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> nums = {1, 2, 3, 4, 5};

    // 使用resize(n)来增加vector的大小
    nums.resize(7);
    std::cout << "After resize(7): ";
    for (int num : nums) {
        std::cout << num << " ";
    }
    // 输出: After resize(7): 1 2 3 4 5 0 0

    // 使用resize(n, val)来增加vector的大小,并用val填充
    nums.resize(10, 9);
    std::cout << "\nAfter resize(10, 9): ";
    for (int num : nums) {
        std::cout << num << " ";
    }
    // 输出: After resize(10, 9): 1 2 3 4 5 0 0 9 9 9

    // 使用resize(n)来缩小vector的大小
    nums.resize(3);
    std::cout << "\nAfter resize(3): ";
    for (int num : nums) {
        std::cout << num << " ";
    }
    // 输出: After resize(3): 1 2 3

    return 0;
}

在上面的例子中,我们先创建了一个包含5个整数的vector。然后使用resize()函数对其进行调整大小操作。首先使用resize(7)扩大vector的大小,新添加了两个默认值为0的元素。然后使用resize(10, 9)再次扩大vector的大小,新添加了三个值为9的元素。最后使用resize(3)缩小vector的大小,截断了后面的元素。在每次resize操作后,我们打印出vector的内容来验证结果。


reserve

由于vector的内存管理可能涉及动态分配和释放内存,这个过程可能会很耗时。为了优化性能,我们可以使用vectorreserve函数来预分配内存空间,以避免频繁的内存分配和释放操作。

reserve函数的函数原型如下:

void reserve (size_type n);

参数n指定了预分配的内存空间大小,以元素个数为单位。这意味着reserve函数将为vector预分配至少n个元素所需的内存空间。

示例:

#include <iostream>
#include <vector>

int main() {
    std::vector<int> vec;
    
    std::cout << "Before reserve: size = " << vec.size() << ", capacity = " << vec.capacity() << std::endl;
    
    vec.reserve(100); // 预分配至少100个元素的内存空间
    
    std::cout << "After reserve: size = " << vec.size() << ", capacity = " << vec.capacity() << std::endl;
    
    for (int i = 0; i < 50; i++) {
        vec.push_back(i);
    }
    
    std::cout << "After push_back: size = " << vec.size() << ", capacity = " << vec.capacity() << std::endl;
    
    return 0;
}

输出结果为:

Before reserve: size = 0, capacity = 0
After reserve: size = 0, capacity = 100
After push_back: size = 50, capacity = 100

从输出结果可以看出,我们在调用reserve函数之前,vectorsizecapacity都是0。调用reserve函数之后,虽然size仍然是0,但capacity变为了100,预分配了100个元素的内存空间。

当我们向vector中添加元素时,size会发生变化,而capacity则保持不变。可以看到,在向vector中添加了50个元素之后,size变为了50,而capacity仍然是100。

这说明,通过调用reserve函数预分配内存空间,可以有效避免频繁的内存分配和释放操作,从而提高程序的性能。
注意,reserve函数只会增加capacity,不会改变size的值


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1440273.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

2024年 复习 HTML5+CSS3+移动web 笔记 之CSS遍 第6天

6.1 定位-相对和绝对和固定 6.2 相对和绝对和固定 6.3 堆叠顺序z-index 6.4 定位总结 6.5 CSS精灵 基本使用 6.6 案例 CSS精灵 京东服务 6.7 字体图标-下载和使用 6.8 字体图标-上传 6.9 垂直对齐方式vertical-align 6.10 过渡属性 6.11 修饰属性-透明度与光标类型 6.12 综合案…

react将选中文本自动滑动到容器可视区域内

// 自动滚动到可视区域内useEffect(() > {const target ref;const wrapper wrapperRef?.current;if (target && wrapperRef) {const rect target.getBoundingClientRect();const wrapperRect wrapper.getBoundingClientRect();const isVisible rect.bottom &l…

npm 上传一个自己的应用(4) 更新自己上传到NPM中的工具版本 并进行内容修改

前面 npm 上传一个自己的应用(2) 创建一个JavaScript函数 并发布到NPM 我们讲了将自己写的一个函数发送到npm上 那么 如果我们想到更好的方案 希望对这个方法进行修改呢&#xff1f; 比如 我们这里加一个方法 首先 我们还是要登录npm npm login然后 根据要求填写 Username 用…

Sping Cloud Hystrix 参数配置、简单使用、DashBoard

Sping Cloud Hystrix 文章目录 Sping Cloud Hystrix一、Hystrix 服务降级二、Hystrix使用示例三、OpenFeign Hystrix四、Hystrix参数HystrixCommand.Setter核心参数Command PropertiesFallback降级配置Circuit Breaker 熔断器配置Metrix 健康统计配置Request Context 相关参数C…

【Spring源码解读!底层原理进阶】【上】探寻Spring内部:BeanFactory和ApplicationContext实现原理揭秘✨

&#x1f389;&#x1f389;欢迎光临&#x1f389;&#x1f389; &#x1f3c5;我是苏泽&#xff0c;一位对技术充满热情的探索者和分享者。&#x1f680;&#x1f680; &#x1f31f;特别推荐给大家我的最新专栏《Spring 狂野之旅&#xff1a;底层原理高级进阶》 &#x1f680…

【图形图像的C++ 实现 01/20】 2D 和 3D 贝塞尔曲线

目录 一、说明二、贝塞尔曲线特征三、模拟四、全部代码如下 一、说明 以下文章介绍了用 C 计算和绘制的贝塞尔曲线&#xff08;2D 和 3D&#xff09;。    贝塞尔曲线具有出色的数学能力来计算路径&#xff08;从起点到目的地点的曲线&#xff09;。曲线的形状由“控制点”决…

个体诊所门诊电子处方开单管理系统软件,配方模板病历模板设置一键导入操作教程

个体诊所门诊电子处方开单管理系统软件&#xff0c;配方模板病历模板设置一键导入操作教程 一、前言 以下操作教程以 佳易王诊所电子处方软件V17.2为例说明&#xff0c;最新版V17.3下载可以点击最下方官网卡片了解。 1、在现实生活中&#xff0c;医师开单可谓是争分夺秒&…

苏宁易购移动端首页(rem布局)

技术选型 方案∶采取单独制作移动页面方案技术:布局采取rem适配布局( less rem &#xff0b;媒体查询)设计图:设计图采用750px设计尺寸 设置视口标签以及引入初始化样式 <meta name"viewport" content"widthdevice-width, initial-scale1.0, user-scalable…

Vulnhub靶机:hacksudo-FOG

一、介绍 运行环境&#xff1a;Virtualbox 攻击机&#xff1a;kali&#xff08;10.0.2.15&#xff09; 靶机&#xff1a;hacksudo-FOG&#xff08;10.0.2.48&#xff09; 目标&#xff1a;获取靶机root权限和flag 靶机下载地址&#xff1a;https://www.vulnhub.com/entry/…

TCP和UDP相关问题(重点)(5)——5.TCP三次握手和四次挥手(非常重要)

5.1三次握手的过程 一次握手&#xff1a;客户端发送带有SYN(x)标志的数据包到服务端&#xff0c;然后客户端进入SYN_SEND状态&#xff0c;等待服务器端的确认。 二次握手&#xff1a;服务端发送带有SYN(y)ACK(x1)标志的数据包到客户端&#xff0c;然后服务端进入SYN_RECV状态。…

SCI 1区论文:Segment anything in medical images(MedSAM)[文献阅读]

基本信息 标题&#xff1a;Segment anything in medical images中文标题&#xff1a;分割一切医学图像发表年份: 2024年1月期刊/会议: Nature Communications分区&#xff1a; SCI 1区IF&#xff1a;16.6作者: Jun Ma; Bo Wang(一作&#xff1b;通讯)单位&#xff1a;加拿大多…

负载均衡(3)

文章目录 一、HAProxy介绍企业版社区版版本对比HAProxy功能支持功能不具备的功能 二、编译安装HAProxy解决lua环境Centos 基础环境 编译安装HAProxy验证HAProxy版本HAProxy启动脚本配置文件启动haproxy验证haproxy状态查看haproxy的状态页面 三、HAProxy基础配置详解global配置…

SSH口令问题

SSH&#xff08;Secure Shell&#xff09;是目前较可靠、专为远程登录会话和其他网络服务提供 安全性的协议&#xff0c;主要用于给远程登录会话数据进行加密&#xff0c;保证数据传输的安全。 SSH口令长度太短或者复杂度不够&#xff0c;如仅包含数字或仅包含字母等时&#xf…

正版软件 - Proxyman:让网络调试变得更智能、更高效

在软件开发的世界里&#xff0c;网络调试一直是开发者和测试工程师的痛点。传统的调试工具往往操作复杂&#xff0c;界面不够直观&#xff0c;而且性能上也难以满足现代应用的需求。今天&#xff0c;我要向大家介绍一款名为Proxyman的网络调试工具&#xff0c;它以其简洁的界面…

项目02《游戏-12-开发》Unity3D

基于 项目02《游戏-11-开发》Unity3D &#xff0c; 人物&#xff1a;实现场景怪物自动巡航 &#xff0c; 首先在场景中创建小球命名为路径点WayPoint0&#xff0c; 取消小球的碰撞器Collider&#xff0c; 再复制两个改名为WayPoint1 和 WayPoint2 &#xff0c; 在…

懒人精灵 之 Lua 捕获 json解析异常 ,造成的脚本停止.

Time: 2024年2月8日20:21:17 by:MemoryErHero 1 异常代码 Expected value but found T_END at character 12 异常代码 Expected value but found T_OBJ_END at character 223 处理方案 - 正确 json 示范 while true do--Expected value but found T_END at character 1--Ex…

【数据分享】1929-2023年全球站点的逐日平均风速数据(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、能见度等指标&#xff0c;说到气象数据&#xff0c;最详细的气象数据是具体到气象监测站点的数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2023年全球气象站…

Java毕业设计-基于ssm的仓库管理系统-第76期

获取源码资料&#xff0c;请移步从戎源码网&#xff1a;从戎源码网_专业的计算机毕业设计网站 项目介绍 基于ssm的游泳馆管理系统&#xff1a;前端jsp、jquery、bootstrap&#xff0c;后端 springmvc、spring、mybatis&#xff0c;集成游泳课程报名、游泳卡在线售卖、购物车、…

c++设计模式之装饰器模式

作用 为现有类增加功能 案例说明 class Car { public:virtual void show()0; };class Bmw:public Car { public:void show(){cout<<"宝马汽车>>"<<endl;} };class Audi:public Car { public:void show(){cout<<"奥迪汽车>>&q…

【数据分享】1929-2023年全球站点的逐日平均能见度(Shp\Excel\免费获取)

气象数据是在各项研究中都经常使用的数据&#xff0c;气象指标包括气温、风速、降水、湿度等指标&#xff0c;说到常用的降水数据&#xff0c;最详细的降水数据是具体到气象监测站点的降水数据&#xff01; 有关气象指标的监测站点数据&#xff0c;之前我们分享过1929-2023年全…