c++中string和vector的詳細介紹
知識點1【STL的概述】
STL(Standard Template Library,標(biāo)準(zhǔn)模板庫)
STL的三大組件:容器(container)、算法(algorithm)、迭代器(iterator)。
算法操作數(shù)據(jù),容器存儲數(shù)據(jù),迭代器是算法操作容器的橋梁,迭代器和容器一一對應(yīng)。

STL六大組件:
容器 算法 迭代器 仿函數(shù) 適配器 空間配置器
容器:存放數(shù)據(jù)
算法:操作數(shù)據(jù)
迭代器:容器和算法的橋梁
仿函數(shù):為算法提供更多的策略
適配器:為算法提供更多的參數(shù)接口
空間配置器:管理容器和算法的空間
算法的分類:
質(zhì)變算法:是指運算過程中會改變區(qū)間元素的內(nèi)容。例如拷貝,替換,刪除等。
非質(zhì)變算法:是指運算過程中不會區(qū)間的元素內(nèi)容,例如查找、計數(shù)、遍歷、尋找極值。
迭代器的分類:

知識點2【迭代器的案例】

案例:容器vector
#include <iostream>
#include <vector>
#include<algorithm>
void myPrintInt(int num);
using namespace std;
void test01(){
//單端動態(tài)數(shù)組vector類模板
vector<int> arr(0);
//push_back()尾部插入數(shù)據(jù)
arr.push_back(100);
arr.push_back(200);
arr.push_back(300);
arr.push_back(400);
//訪問數(shù)據(jù)
//定義一個迭代器存儲arr的起始迭代器
vector<int>::iterator beginIt = arr.begin();
//定義一個迭代器存儲arr的結(jié)束迭代器
vector<int>::iterator endIt = arr.end();
//for循環(huán)遍歷1
for(vector<int>::iterator i = beginIt; i != endIt; i++){
//對迭代器取* 代表的是 容器的元素
//*biginIt
cout << *i << " ";
}
cout << endl;
//for循環(huán)遍歷2(推薦)
for(vector<int>::iterator beginIt = arr.begin(); beginIt != arr.end();beginIt++){
cout << *beginIt << " ";
}
cout << endl;
//STL提供的算法來遍歷容器(包含算法頭文件algorithm)
//for_each從容器的起始--->結(jié)束,逐個元素取出
//myPrintInt容器數(shù)據(jù)的打印方式
for_each(arr.begin(),arr.end(),myPrintInt);
}
void myPrintInt(int num){
cout << num << " ";
}
int main(int argc, char *argv[])
{
test01();
return 0;
}運行結(jié)果:

案例2:容器存放自定義數(shù)據(jù)類型
#include <iostream>
#include <vector>
#include<algorithm>
#include <string.h>
using namespace std;
class Person{
friend void myPrintInt1(Person &ob);
private:
string name;
int age;
public:
Person(string name,int age){
this->name = name;
this->age = age;
}
};
void myPrintInt1(Person &ob){
cout << ob.age << " " << ob.name << endl;
}
void test02(){
vector<Person> arr;
Person p1("tom",15);
arr.push_back(p1);
arr.push_back(Person("davi",16));
arr.push_back(Person("mary",17));
arr.push_back(Person("peter",18));
for_each(arr.begin(),arr.end(),myPrintInt1);
}
int main(int argc, char *argv[])
{
test02();
return 0;
}運行結(jié)果:

案例3:容器嵌套容器
void test03(){
vector<int> v1;
vector<int> v2;
vector<int> v3;
v1.push_back(10);
v1.push_back(20);
v1.push_back(30);
v1.push_back(40);
v2.push_back(100);
v2.push_back(200);
v2.push_back(300);
v2.push_back(400);
v3.push_back(1000);
v3.push_back(2000);
v3.push_back(3000);
v3.push_back(4000);
vector< vector<int>> v4;
v4.push_back(v1);
v4.push_back(v2);
v4.push_back(v3);
for(vector<vector<int>>::iterator it = v4.begin(); it != v4.end(); it++){
for(vector<int>::iterator mit = (*it).begin(); mit != (*it).end();mit++){
cout << (*mit) << " ";
}
cout << endl;
}
}運行結(jié)果:

知識點3【string類】
1、案例:string的構(gòu)造和賦值
#include <iostream>
#include <string.h>
using namespace std;
/*
3.1.2.1 string 構(gòu)造函數(shù)
string();//創(chuàng)建一個空的字符串 例如: string str;
string(const string& str);//使用一個 string 對象初始化另一個 string 對象
string(const char* s);//使用字符串 s 初始化
string(int n, char c);//使用 n 個字符 c 初始化
3.1.2.2 string 基本賦值操作
string& operator=(const char* s);//char*類型字符串 賦值給當(dāng)前的字符串
string& operator=(const string &s);//把字符串 s 賦給當(dāng)前的字符串
string& operator=(char c);//字符賦值給當(dāng)前的字符串
string& assign(const char *s);//把字符串 s 賦給當(dāng)前的字符串
string& assign(const char *s, int n);//把字符串 s 的前 n 個字符賦給當(dāng)前的字符串
string& assign(const string &s);//把字符串 s 賦給當(dāng)前字符串
string& assign(int n, char c);//用 n 個字符 c 賦給當(dāng)前字符串
string& assign(const string &s, int start, int n);//將 s 從 start 開始 n 個 字符賦值給字符串
*/
void test01(){
//string(const char* s);//使用字符串s初始化
string str1 = "hello";
cout << str1 << endl;
//string(int n, char c);//使用n個字符c初始化
string str2(10,'H');
cout<<str2<<endl;//"HHHHHHHHHH"
}
int main(int argc, char *argv[])
{
test01();
return 0;
}到此這篇關(guān)于c++中string和vector的詳細介紹的文章就介紹到這了,更多相關(guān)c++ string和vector內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C++ Qt實現(xiàn)瀏覽器網(wǎng)頁內(nèi)嵌的音視頻播放器
這篇文章主要為大家詳細介紹了如何利用C++ Qt實現(xiàn)瀏覽器網(wǎng)頁內(nèi)嵌的音視頻播放器,并支持軟硬解碼,支持音頻,支持錄像截圖,支持多路播放等,感興趣的可以了解下2024-01-01
C語言菜鳥基礎(chǔ)教程之單精度浮點數(shù)與雙精度浮點數(shù)
在C語言中,單精度浮點數(shù)(float)和雙精度浮點數(shù)(double)類型都是用來儲存實數(shù)的,雙精度是用記憶較多,有效數(shù)字較多,數(shù)值范圍較大。2017-10-10
C語言數(shù)組和指針,內(nèi)存之間的關(guān)系
這篇文章主要介紹了C語言數(shù)組和指針,內(nèi)存之間的關(guān)系,首先論證一維數(shù)組和一級指針之前的關(guān)系,我們常常使用一級指針指針的方式訪問一維數(shù)組,只有對內(nèi)存的理解到位才能理解它們直接的關(guān)系。需要的小伙伴可以參考一下2022-02-02

