STL筆記 之 vector

来源:https://www.cnblogs.com/ParsipGit/p/18133749/STLvector
-Advertisement-
Play Games

初識STL STL,(Standard Template Library),即"標準模板庫",由惠普實驗室開發,STL中提供了非常多對信息學奧賽很有用的東西。 vector vetor是STL中的一個容器,可以看作一個不定長的數組,其基本形式為: vector<數據類型> 名字; 如: vector ...


初識STL

STL,(Standard Template Library),即"標準模板庫",由惠普實驗室開發,STL中提供了非常多對信息學奧賽很有用的東西。

vector

vetor是STL中的一個容器,可以看作一個不定長的數組,其基本形式為:

vector<數據類型> 名字;

如: vector<int> vvector<char> t

vector的基本操作

先定義一個vector:vector<int> p;,

p.clear() 清空vector的所有數據。

p.empty() 判斷vector是否為空,返回值為 truefalse

p.erase(pos) 刪除pos位置的數據。

p.erase(begin,end) 刪除begin~end之間的數據。

p.front() 返回vector的第一個數據。

p.insert(pos,data) 在vector的pos位置插入data。

p.push_back(data) 在vector的尾部加入一個數據data。

p.pop_back() 彈出vector末尾的數據。

p.resize(len) 重設vector的大小為len。

p.size() 返回vector實際數據的個數。

p.begin() 返回指向vector的第一個數據的迭代器。

p.end() 返回指向vector的最後一個數據的迭代器。

下麵是一個vector代碼的例子:

#include<bits/stdc++.h>
using namespace std;
vector<int> t;
int main(){
	t.push_back(1);
	t.push_back(2);
	t.push_back(3);
	cout<<t.size()<<endl;
	cout<<t.front()<<endl;
	t.push_back(10);
	t.push_back(11);
	t.erase(t.end()-1);
	while(t.size()){
		cout<<t[t.size()-1]<<" ";
		t.pop_back();
	}
	return 0;
}

代碼先向t中插入了1,2,3,然後輸出t的數據的數量和t的第一個數據,即3 1,又插入了10,11,把最後一個元素刪去了(t.erase(t.end()-1);),最後從後往前輸出t中所有的數據,即10 3 2 1

一維vector代碼示例

vector也可以像數組一樣操作:

#include<bits/stdc++.h>
using namespace std;
vector<int> t;
int main(){
	int n,m,a;
	cin>>n>>m;
	for(int i=1;i<=n;i++){
		cin>>a;
		t.push_back(a);
	}
	for(int i=1;i<=m;i++){
		int k;
		cin>>k;
		cout<<t[k]<<endl;
	}
	return 0;
}

但是需要註意,vector初始插入下標為0!

vector對於未插入數據的下標使用時會RE!

#include<bits/stdc++.h>
using namespace std;
vector<int> t;
int main(){
	cout<<t[100];//錯誤
	return 0;
}

vector的遍歷方式有兩種:

(1)下標遍歷

#include<bits/stdc++.h>
using namespace std;
vector<int> v;
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		int a;
		cin>>a;
		v.push_back(a);
	}
	for(int i=0;i<v.size();i++){
		cout<<v[i]<<" ";
	}
	return 0;
}

(2)迭代器遍歷

迭代器類似於一個指針,它可以訪問vector的所有元素。

#include<bits/stdc++.h>
using namespace std;
vector<int> v;
vector<int>::iterator it;
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		int a;
		cin>>a;
		v.push_back(a);
	}
	for(it=v.begin();it!=v.end();it++){//使迭代器指向v的起始
		cout<<*it<<" ";
	}
	return 0;
}

vector可以相互賦值,如:

#include<bits/stdc++.h>
using namespace std;
vector<int> v;
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		int a;
		cin>>a;
		v.push_back(a);
	}
	vector<int> v1(v);//把v的所有元素複製到v1 
	for(int i=0;i<v1.size();i++){
		cout<<v1[i]<<" ";
	}
	return 0;
}

二維vector

二維的vector稍有些繁瑣:

#include<bits/stdc++.h>
using namespace std;
vector<vector<int> > v;
vector<int> v1;
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		v1.clear();
		for(int j=1;j<=n;j++){
			int a;
			cin>>a;
			v1.push_back(a);//先把數據添加進v1,再把v1插入到v
		}
		v.push_back(v1);
	}
	for(auto it=v.begin();it!=v.end();it++){//遍歷
		for(auto it2=it->begin();it2!=it->end();it2++){
			cout<<*it2<<" ";
		}
		cout<<endl;
	}
	return 0;
}

例題 (洛谷P1540 機器翻譯)

題目背景

NOIP2010 提高組 T1

題目描述

小晨的電腦上安裝了一個機器翻譯軟體,他經常用這個軟體來翻譯英語文章。

這個翻譯軟體的原理很簡單,它只是從頭到尾,依次將每個英文單詞用對應的中文含義來替換。對於每個英文單詞,軟體會先在記憶體中查找這個單詞的中文含義,如果記憶體中有,軟體就會用它進行翻譯;如果記憶體中沒有,軟體就會在外存中的詞典內查找,查出單詞的中文含義然後翻譯,並將這個單詞和譯義放入記憶體,以備後續的查找和翻譯。

假設記憶體中有 \(M\) 個單元,每單元能存放一個單詞和譯義。每當軟體將一個新單詞存入記憶體前,如果當前記憶體中已存入的單詞數不超過 \(M-1\),軟體會將新單詞存入一個未使用的記憶體單元;若記憶體中已存入 \(M\) 個單詞,軟體會清空最早進入記憶體的那個單詞,騰出單元來,存放新單詞。

假設一篇英語文章的長度為 \(N\) 個單詞。給定這篇待譯文章,翻譯軟體需要去外存查找多少次詞典?假設在翻譯開始前,記憶體中沒有任何單詞。

輸入格式

\(2\) 行。每行中兩個數之間用一個空格隔開。

第一行為兩個正整數 \(M,N\),代表記憶體容量和文章的長度。

第二行為 \(N\) 個非負整數,按照文章的順序,每個數(大小不超過 \(1000\))代表一個英文單詞。文章中兩個單詞是同一個單詞,當且僅當它們對應的非負整數相同。

輸出格式

一個整數,為軟體需要查詞典的次數。

樣例 #1
樣例輸入 #1
3 7
1 2 1 5 4 4 1
樣例輸出 #1
5
提示
樣例解釋

整個查字典過程如下:每行表示一個單詞的翻譯,冒號前為本次翻譯後的記憶體狀況:

  1. 1:查找單詞 1 並調入記憶體。
  2. 1 2:查找單詞 2 並調入記憶體。
  3. 1 2:在記憶體中找到單詞 1。
  4. 1 2 5:查找單詞 5 並調入記憶體。
  5. 2 5 4:查找單詞 4 並調入記憶體替代單詞 1。
  6. 2 5 4:在記憶體中找到單詞 4。
  7. 5 4 1:查找單詞 1 並調入記憶體替代單詞 2。

共計查了 \(5\) 次詞典。

數據範圍
  • 對於 \(10\%\) 的數據有 \(M=1\)\(N \leq 5\)
  • 對於 \(100\%\) 的數據有 \(1 \leq M \leq 100\)\(1 \leq N \leq 1000\)

題目可以使用vector解決:

#include<bits/stdc++.h>
using namespace std;
vector<int> v;
int main(){
	int n,m,ans=0;
	cin>>m>>n;
	for(int i=1;i<=n;i++){
		int a;
		cin>>a;
		if((find(v.begin(),v.end(),a))==v.end()){//查找a是否存在於v中,不存在會指向v.end()
			v.push_back(a);//加入記憶體
			ans++;//查字典次數+1
		}
		if(v.size()>m){//如果大小大於記憶體容量刪除v的第一個元素
			v.erase(v.begin());
		}
	}
	cout<<ans;
	return 0;
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 系統調用 系統調用,顧名思義,說的是操作系統提供給用戶程式調用的一組“特殊”介面。用戶程式可以通過這組“特殊”介面來獲得操作系統內核提供的服務,比如用戶可以通過文件系統相關的調用請求系統打開文件、關閉文件或讀寫文件,可以通過時鐘相關的系統調用獲得系統時間或設置定時器等。 從邏輯上來說,系統調用可被看 ...
  • C++語言相比C語言最重要的功能就是支持面向對象編程,為了實現面向對象編程,C++增加了類的封裝和多態、繼承等特性,那麼這些特性的加入是否會造成對象的記憶體成本增加?如果增加了,那麼到底增加了多少? ...
  • 自己如何實現? 要實現一個簡單版本的Tomcat,整體思路如下 瞭解 Tomcat 的基本原理: Tomcat 是一個開源的 Java Servlet 容器和 Web 伺服器,它能夠運行 Java Servlet 和 JavaServer Pages。 Tomcat 是基於 Java 的,它是用 J ...
  • 大家好,我是 Java陳序員。 今天,給大家介紹一個線上的個人圖書管理系統,支持線上閱讀。 關註微信公眾號:【Java陳序員】,獲取開源項目分享、AI副業分享、超200本經典電腦電子書籍等。 項目介紹 talebook —— 一個基於Calibre的簡單的個人圖書管理系統,支持線上閱讀。 友情提醒 ...
  • 隨著互聯網的快速發展,我們的生活越來越離不開各類網路服務。從購物到銀行,從社交媒體到線上支付,我們幾乎每天都會在不同的網站和應用上輸入個人信息。然而,隨之而來的安全風險也在不斷增加,個人信息被盜取和濫用的事件屢見不鮮。為了保護用戶的個人信息安全,各個平臺和應用都開始使用各種安全認證手段,其中手機號三 ...
  • 寫在前面 自從ChatGPT火了之後,各種產品都在不停的擁抱AI,在各自場景中接入AI,國內外各種大模型層出不窮。 好像有點扯遠了,言歸正傳,今天我們要說的是SpringAI,大家在逛Spring 官網(https://spring.io/) 應該發現了,在官網中多了SpringAI 模塊 一、Sp ...
  • 1 文本Embedding 將整個文本轉化為實數向量的技術。 Embedding優點是可將離散的詞語或句子轉化為連續的向量,就可用數學方法來處理詞語或句子,捕捉到文本的語義信息,文本和文本的關係信息。 ◉ 優質的Embedding通常會讓語義相似的文本在空間中彼此接近 ◉ 優質的Embedding相 ...
  • 前言 最近自己做了個 Falsk 小項目,在部署上伺服器的時候,發現雖然不乏相關教程,但大多都是將自己項目代碼複製出來,不講核心邏輯,不太簡潔,於是將自己部署的經驗寫成內容分享出來。 uWSGI 簡介 uWSGI: 一種實現了多種協議(包括 uwsgi、http)並能提供伺服器搭建功能的 Pytho ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...