C++学习笔记之string容器、vector容器

我们读过的书,说过的话,见过的山水,见到的人和事,最终都会变成我们脚下的的路。


1.string容器

string C++ 风格的字符串,而 string 本质上是一个类。
#include <iostream>
using namespace std;
#include <string>
//以下参数为const char* 类型与string类型的函数参数可以相互替换
void test01()
{//一、string构造函数string s1;//1.默认构造const char* str1 = "max";string s3(str1);//2.使用字符串进行初始化构造cout << "s3 =" << s3 << endl;string s4(s3);//3.使用一个string对象初始化另一个string对象cout << "s4 =" <<s4 <<endl;string s5(7, 'x');cout << "s5=" <<s5<< endl;//二.赋值方式const char* str2 = "min";s5 = str2;//char*类型字符串 赋值给当前的字符串cout << "s5=" << s5 << endl;s5 = s4;//把字符串s赋给当前的字符串cout << "s5=" << s5 << endl;s5 = 'a';//字符赋值给当前的字符串cout << "s5=" << s5 << endl;s5 = str2;//char*类型字符串 赋值给当前的字符串s5 = "hello,world";cout << "s5=" << s5 << endl;s5.assign(str2);//把字符串s赋给当前的字符串cout << "s5=" << s5 << endl;s5.assign(str2,2);//把字符串s的前n个字符赋给当前的字符串cout << "s5=" << s5 << endl;s5.assign(s4);//把字符串s赋给当前字符串cout << "s5=" << s5 << endl;s5.assign(2, 's');//用n个字符c赋给当前字符串cout << "s5=" << s5 << endl;//三、字符串拼接s5 += "rr";//string& operator+=(const char* str);重载+=操作符cout << "s5=" << s5 << endl;s5 += 'a';//string& operator+=(const char c); //重载+=操作符cout << "s5=" << s5 << endl;s5 += s4;//string& operator+=(const string& str); //重载+=操作符cout << "s5=" << s5 << endl;string str11 = "I LOVE ";str11.append("my country");//string& append(const char *s); //把字符串s连接到当前字符串结尾cout << "str11=" << str11 << endl;str11.append("tooooo",2);//string& append(const char *s, int n); //把字符串s的前n个字符连接到当前字符串结尾cout << "str11=" << str11 << endl;string str12 = "1";str11.append(str12);//string& append(const string &s); //同operator+=(const string& str)cout << "str11=" << str11 << endl;string str13 = "2223333";//string& append(const string &s, int pos, int n); //字符串s中从pos开始的n个字符连接到字符串结尾str11.append(str13,3,3);cout << "str11=" << str11 << endl;//四、查找和替换//find查找是从左往后,rfind从右往左;// find找到字符串后返回查找的第一个字符位置,找不到返回-1;// replace在替换时,要指定从哪个位置起,多少个字符,替换成什么样的字符串string str111="yue shi gu xiang ming";int pos1 = str111.find("ng");//int find(const string& str, int pos = 0) const;查找str第一次出现位置,从pos位置开始查找cout << "pos1=" << pos1 << endl;int pos4 = str111.find("ng",0,1);//int find(const char* s, int pos, int n) const; //从pos位置查找s的前n个字符第一次位置cout << "pos4=" << pos4 << endl;int pos2 = str111.rfind("ng"); //int rfind(const string& str, int pos = npos) const;查找str最后一次位置, 从pos开始查找cout << "pos2=" << pos2 << endl;int pos3 = str111.rfind("ng",21,1); //int rfind(const char* s, int pos, int n) const; //从pos查找s的前n个字符最后一次位置cout << "pos3=" << pos3 << endl;cout << "替换前str111=" << str111 << endl;str111.replace(0,7,"moon is");//替换从pos开始n个字符为字符串strcout << "替换后str111=" << str111 << endl;//五、字符串比较//字符串对比主要是用于比较两个字符串是否相等string str555 = "hello";string str556 = "hello";int pos557=str555.compare(str556);//int compare(const string &s) const;返回值为0,二者相等int pos558 = str555.compare("hello");//int compare(const char *s) const;cout <<"pos557=" << pos557 << endl;cout <<"pos558=" << pos558 << endl;//六、字符串存取//string字符串中单个字符存取有两种方式,利用 [ ] 或 atstring str666 = "hello world";for (int i = 0; i < str666.size(); i++){cout<<"str666=" << str666[i] << " ";}cout << endl;for (int i = 0; i < str666.size(); i++){cout<<"str666" << str666.at(i) << " ";}cout << endl;//字符修改str666[0] = 'x';str666.at(1) = 'x';cout <<"str666" << str666 << endl;//七、字符串插入与删除
// //插入和删除的起始下标都是从0开始string str777 = "hello world";str777.insert(2,"llll"); //string& insert(int pos, const char* s); //插入字符串cout << "str777=" << str777 << endl;str777.insert(8, 3, 'x');//string& insert(int pos, int n, char c); //在指定位置插入n个字符ccout << "str777=" << str777 << endl;str777.erase(8,3);str777.erase(2,4);//string& erase(int pos, int n = npos); //删除从Pos开始的n个字符cout << "str777=" << str777 << endl;//八、string子串
// //从字符串中获取想要的子串string str888 = "hello world";string str889=str888.substr(0, 5); //string substr(int pos = 0, int n = npos) const; //返回由pos开始的n个字符组成的字符串cout << "str889=" << str889 << endl;
}
int main() {test01();
}

2.vector容器

vector数据结构和数组非常相似,也称为单端数组,不同之处在于数组是静态空间,而vector可以动态扩展,动态扩展并不是在原空间之后续接新空间,而是找更大的内存空间,然后将原数据拷贝新空间,释放原空间。

#include <iostream>
using namespace std;
#include <vector>
void printfVector(vector <int> &v)
{for (vector<int>::iterator it = v.begin(); it != v.end(); it++)//iterator(迭代器){cout << *it << " ";}cout << endl;
}void test01() {//一、vector构造方式vector <int> v1;//1.默认构造for (int i = 0; i < 10; i++){v1.push_back(i);//尾插}printfVector(v1);vector<int>v2(v1.begin(), v1.end());//2.区间构造printfVector(v2);vector<int>v3(10, 100);//3.用n个元素的方式构造printfVector(v3);vector<int>v4(v3);//4.拷贝构造printfVector(v4);//二、vector赋值方式v4 = v1;// 1.operator=printfVector(v4);v4.assign(v3.begin(), v3.end());//2.assign方式printfVector(v4);v4.assign(5, 20);//3.n个元素的方式printfVector(v4);//vector容量和大小if (v4.empty())//为真代表容器为空{cout << "v4为空" << endl;}else{cout << "v4不为空" << endl;cout << "v4的容量" << v4.capacity() << endl;//vector容器容量cout << "v4的大小" << v4.size() << endl;//容器的大小}v4.resize(15, 100);//重新指定容器大小,指定默认填充值printfVector(v4);//如果重新指定的过长;如果未指定默认填充值用0填充v4.resize(5);//重新指定过短,删除超出的部分printfVector(v4);//三、插入和删除//尾插v4.push_back(10);v4.push_back(20);printfVector(v4);//尾删v4.pop_back();printfVector(v4);//插入v4.insert(v4.begin(), 100);//在迭代器指向的位置插入一个元素printfVector(v4);v4.insert(v4.begin(), 2, 1000);//在特定位置插入n个指定元素printfVector(v4);//删除v4.erase(v4.begin());//删除迭代器指向的元素printfVector(v4);v4.erase(v4.begin(), v4.end());//全删printfVector(v4);//清空v3.clear();//清空容器内元素printfVector(v3);//vector容器中的数据存取printfVector(v2);cout << v1[2] << endl;//使用[]的方式访问元素cout << v1.at(0) << endl;//使用at的方式访问元素cout << "最后一个元素为" <<v1.front()<< endl;//获取第一个元素cout << "最后一个元素为" <<v1.back()<< endl;//获取最后一个元素//四、互换元素vector<int>v5(10, 100);vector<int>v6(10, 200);cout << "交换前" << endl;printfVector(v5);printfVector(v6); v5.swap(v6);//交换 cout << "交换后" << endl;printfVector(v5);printfVector(v6);v6.resize(3, 10);printfVector(v6);cout << "重新指定大小后v6的容量大小" << v6.capacity() << endl;vector<int>(v6).swap(v6);//巧用swap收缩内存printfVector(v6);cout << "使用匿名对象的swap函数收缩大小后v6的容量大小" << v6.size() << endl;//五、预留空间vector<int>v7;int* p = NULL;int num = 0;for (int i = 0; i < 1000; i++){v7.push_back(i);if (p != &v7[0]){p = &v7[0];num++;}}cout << num << endl;//容器动态扩展的次数vector<int>v8;v8.reserve(1000);//使用reserve函数预留空间int* p1 = NULL;int num1 = 0;for (int i = 0; i < 1000; i++){v8.push_back(i);if (p1 != &v8[0]){p1 = &v8[0];num1++;}}cout << num1 << endl;
}int main() {test01();
}

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

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

相关文章

C++:类和对象(上)

目录 一、类的定义 二、 访问限定符 三、 实例化概念类&#xff1a; 类&#xff08;Class&#xff09; 对象&#xff08;Object&#xff09; 实例化&#xff08;Instantiation&#xff09; 四、 对象大小 五、this 指针的基本概念 this 指针的作用&#xff1a; this 指…

如何在vscode 中打开新文件不覆盖上一个窗口

在 VSCode 中&#xff0c;如果你单击文件时出现了覆盖Tab的情况&#xff0c;这通常是因为VSCode默认开启了预览模式。在预览模式下&#xff0c;单击新文件会覆盖当前预览的文件Tab。为了解决这个问题&#xff0c;你可以按照以下步骤进行操作 1.打开VSCode&#xff1a;启动你的…

Linux篇(权限管理命令)

目录 一、权限概述 1. 什么是权限 2. 为什么要设置权限 3. Linux中的权限类别 4. Linux中文件所有者 4.1. 所有者分类 4.2. 所有者的表示方法 属主权限 属组权限 其他权限 root用户&#xff08;超级管理员&#xff09; 二、普通权限管理 1. ls查看文件权限 2. 文件…

冲压车间如何开展六西格玛管理培训

面对日益严苛的客户要求与成本控制挑战&#xff0c;传统的管理模式已难以满足高质量发展的需求。此时&#xff0c;六西格玛管理以其严谨的数据驱动、持续改进的理念&#xff0c;成为众多企业转型升级的有力工具。本文&#xff0c;天行健企业管理咨询公司将深入探讨冲压车间如何…

基于微信小程序的平安驾校预约平台的设计与实现(源码+LW++远程调试+代码讲解等)

摘 要 互联网发展至今&#xff0c;广泛参与在社会中的方方面面。它让信息都可以通过网络传播&#xff0c;搭配信息管理工具可以很好地为人们提供服务。针对高校教师成果信息管理混乱&#xff0c;出错率高&#xff0c;信息安全性差&#xff0c;劳动强度大&#xff0c;费时费力…

插入排序(sort)C++

链接&#xff1a;登录—专业IT笔试面试备考平台_牛客网 来源&#xff1a;牛客网 时间限制&#xff1a;C/C/Rust/Pascal 1秒&#xff0c;其他语言2秒 空间限制&#xff1a;C/C/Rust/Pascal 512 M&#xff0c;其他语言1024 M 64bit IO Format: %lld 题目描述 插入排序是一种…

卷积、频域乘积和矩阵向量乘积三种形式之间的等价关系与转换

线性移不变系统 线性移不变系统&#xff08;Linear Time-Invariant System, LTI系统&#xff09;同时满足线性和时不变性两个条件。 线性&#xff1a;如果输入信号的加权和通过系统后&#xff0c;输出是这些输入信号单独通过系统后的输出的相同加权和&#xff0c;那么该系统就…

15分钟学 Go 第 53 天 :社区资源与学习材料

第53天&#xff1a;社区资源与学习材料 目标 了解Go语言官方资源掌握社区重要学习平台学会利用开源项目学习构建个人知识体系 一、Go语言官方资源汇总 资源类型网址说明Go官网golang.org官方文档、下载、教程Go Blogblog.golang.org技术博客、最新特性介绍Go Playgroundpla…

「QT」文件类 之 QIODevice 输入输出设备类

✨博客主页何曾参静谧的博客&#x1f4cc;文章专栏「QT」QT5程序设计&#x1f4da;全部专栏「Win」Windows程序设计「IDE」集成开发环境「UG/NX」BlockUI集合「C/C」C/C程序设计「DSA」数据结构与算法「UG/NX」NX二次开发「QT」QT5程序设计「File」数据文件格式「UG/NX」NX定制…

timescale使用例子 - 纽约出租车

一、资料使用 在timescale的官方网站的“教程”菜单中&#xff0c;有几个不同业务场景的例子&#xff0c;其中就有运输行业的例子。我访问中文站点的时候&#xff0c;关于教程的几个步骤内容刷不出来&#xff0c;所以还是建议访问英文站点。 https://docs.timescale.com/tuto…

树(二叉查找树、平衡二叉树、红黑树)

树&#xff08;二叉树、二叉查找树、平衡二叉树、红黑树&#xff09; 二叉查找树&#xff08;二叉排序树、二叉搜索树&#xff09;添加元素查找元素遍历弊端 平衡二叉树旋转机制&#xff1a;左旋旋转机制&#xff1a;右旋需要旋转的四种情况1. 左左&#xff1a;一次右旋2. 左右…

医疗器械包装运输试验之抗压试验的条件选取及方法和设备的要求

医疗器械包装运输试验之抗压试验的试验目的&#xff1a; 抗压试验通常用来评估产品在承受外界压力时&#xff0c;包装对内装物样品的保护能力。试验通常模拟产品在运输流通过程中可能遇到的压力环境。通过试验&#xff0c;可以验证包装对内装物的保护能力、包装结构的完整性、…

C++内存池实现

1.内存池概念 内存池就和其他的池数据&#xff08;如线程池&#xff09;结构类似&#xff0c;由程序维护一个“池”结构来管理程序使用的内存&#xff0c;然后根据需要从内存池中申请使用内存或者向内存池中释放内存&#xff0c;来达到高效管理内存的目的。 在一般的内存管理的…

数据结构-二叉树

一.二叉树的定义 二叉树有左右儿子之分 完美二叉树&#xff08;满二叉树&#xff09;除了最下面的没有儿子其他结点都有两个儿子&#xff0c;叶节点比较齐的&#xff0c;完全二叉树不是满二叉数允许缺失最后的结点 满二叉树可以达到2^k-1 边的总数节点数-1 二.二叉树的存储结构…

OKR制定指南

Goal Crafting 目标制定是最基本的领导活动之一。组织绩效和团队成长依赖于精心制定的目标。没有良好的目标制定练习&#xff0c;团队可能只关注眼前的事务&#xff0c;解决看似可以快速解决的问题。良好的目标制定迫使你不忽视或推迟那些需要新思维方式、合作或克服困难的问题…

详细分析Java中FilterChain过滤器的基本知识

目录 前言1. 基本知识2. Demo 前言 基本的Java知识推荐阅读&#xff1a; java框架 零基础从入门到精通的学习路线 附开源项目面经等&#xff08;超全&#xff09;【Java项目】实战CRUD的功能整理&#xff08;持续更新&#xff09; 从实战中学习&#xff1a; 常用在一些重复代…

TableGPT2-7B:用于表格数据分析的大规模解码器模型

TableGPT2-7B 是浙江大学开发的最先进的大规模解码器模型&#xff0c;专为涉及表格数据的数据密集型任务而设计。该模型以 Qwen2.5 架构为基础&#xff0c;包括针对表格数据的专用编码&#xff0c;其中独特的语义编码器可从行、列和整个表格中获取洞察力。 主要特点和功能 Ta…

SQL面试题——抖音SQL面试题 主播播出时长

主播播出时长 现有如下数据,主播id、房间号、播出的批次号,每个批次号进出房间的时间戳、分区时间: 每一次直播都有一个上播和下播,每个房间里,同一个批次号会有两条数据,分别记录了上播和下播时间,求每个主播的播出时长? 通过上面的数据,可以清晰的看出,同一个批次…

数字信号处理Python示例(14)生成锯齿波和三角波

文章目录 前言一、锯齿波和三角波二、生成锯齿波和三角波的Python代码三、仿真结果及分析写在后面的话 前言 因其独特的数学特性和物理表现&#xff0c;在工程和技术领域扮演着重要角色。这是生成非正弦信号的几个Python示例的其中一个&#xff0c;生成三角波与锯齿波&#xf…

HBase理论_HBase架构组件介绍

近来有些空闲时间&#xff0c;正好最近也在开发HBase相关内容&#xff0c;借此整理一下学习和对HBase组件的架构的记录和个人感受&#xff0c;付出了老夫不少心血啊&#xff0c;主要介绍的就是HBase的架构设计以及我的拓展内容。内容如有不当或有其他理解 matirx70163.com HB…