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
  • 新改進提供的Taurus Rpc 功能,可以簡化微服務間的調用,同時可以不用再手動輸出模塊名稱,或調用路徑,包括負載均衡,這一切,由框架實現並提供了。新的Taurus Rpc 功能,將使得服務間的調用,更加輕鬆、簡約、高效。 ...
  • 本章將和大家分享ES的數據同步方案和ES集群相關知識。廢話不多說,下麵我們直接進入主題。 一、ES數據同步 1、數據同步問題 Elasticsearch中的酒店數據來自於mysql資料庫,因此mysql數據發生改變時,Elasticsearch也必須跟著改變,這個就是Elasticsearch與my ...
  • 引言 在我們之前的文章中介紹過使用Bogus生成模擬測試數據,今天來講解一下功能更加強大自動生成測試數據的工具的庫"AutoFixture"。 什麼是AutoFixture? AutoFixture 是一個針對 .NET 的開源庫,旨在最大程度地減少單元測試中的“安排(Arrange)”階段,以提高 ...
  • 經過前面幾個部分學習,相信學過的同學已經能夠掌握 .NET Emit 這種中間語言,並能使得它來編寫一些應用,以提高程式的性能。隨著 IL 指令篇的結束,本系列也已經接近尾聲,在這接近結束的最後,會提供幾個可供直接使用的示例,以供大伙分析或使用在項目中。 ...
  • 當從不同來源導入Excel數據時,可能存在重覆的記錄。為了確保數據的準確性,通常需要刪除這些重覆的行。手動查找並刪除可能會非常耗費時間,而通過編程腳本則可以實現在短時間內處理大量數據。本文將提供一個使用C# 快速查找並刪除Excel重覆項的免費解決方案。 以下是實現步驟: 1. 首先安裝免費.NET ...
  • C++ 異常處理 C++ 異常處理機制允許程式在運行時處理錯誤或意外情況。它提供了捕獲和處理錯誤的一種結構化方式,使程式更加健壯和可靠。 異常處理的基本概念: 異常: 程式在運行時發生的錯誤或意外情況。 拋出異常: 使用 throw 關鍵字將異常傳遞給調用堆棧。 捕獲異常: 使用 try-catch ...
  • 優秀且經驗豐富的Java開發人員的特征之一是對API的廣泛瞭解,包括JDK和第三方庫。 我花了很多時間來學習API,尤其是在閱讀了Effective Java 3rd Edition之後 ,Joshua Bloch建議在Java 3rd Edition中使用現有的API進行開發,而不是為常見的東西編 ...
  • 框架 · 使用laravel框架,原因:tp的框架路由和orm沒有laravel好用 · 使用強制路由,方便介面多時,分多版本,分文件夾等操作 介面 · 介面開發註意欄位類型,欄位是int,查詢成功失敗都要返回int(對接java等強類型語言方便) · 查詢介面用GET、其他用POST 代碼 · 所 ...
  • 正文 下午找企業的人去鎮上做貸後。 車上聽同事跟那個司機對罵,火星子都快出來了。司機跟那同事更熟一些,連我在內一共就三個人,同事那一手指桑罵槐給我都聽愣了。司機也是老社會人了,馬上聽出來了,為那個無辜的企業經辦人辯護,實際上是為自己辯護。 “這個事情你不能怪企業。”“但他們總不能讓銀行的人全權負責, ...
  • 1. JUnit 最佳實踐指南 原文: https://howtodoinjava.com/best-practices/unit-testing-best-practices-junit-reference-guide/ 我假設您瞭解 JUnit 的基礎知識。 如果您沒有基礎知識,請首先閱讀(已針 ...