c/c++ 標準庫 map multimap元素訪問

来源:https://www.cnblogs.com/xiaoshiwang/archive/2018/09/25/9703958.html
-Advertisement-
Play Games

標準庫 map multimap元素訪問 一,map,unordered_map下標操作 | 下標操作種類 | 功能描述 | | | | | c[k] | 返回關鍵字為k的元素;如果k不在c中,添加一個關鍵字為k的元素,並對其初始化 | | c.at(k) | 訪問關鍵字為k的元素;若k不在c中,拋 ...


標準庫 map multimap元素訪問

一,map,unordered_map下標操作

下標操作種類 功能描述
c[k] 返回關鍵字為k的元素;如果k不在c中,添加一個關鍵字為k的元素,並對其初始化
c.at(k) 訪問關鍵字為k的元素;若k不在c中,拋出out_of_range異常

註意:

1,當使用使用自定義類作為key時,這個類必須重寫operator<函數

2,下標操作只適用於const map,unordered_map

二,訪問元素

查找元素的操作 功能描述
c.find(k) 返回一個迭代器,指向第一個關鍵字為k的元素,若k不在c種,則返回c.end()
c.count(k) 返回關鍵字等於k的元素的數量。
c.lower_bound(k) 返回一個迭代器,指向第一個關鍵字大於等於k的元素。若k不在c中,返回和c.upper_bound(k)相等的迭代器。
c.upper_bound(k) 返回一個迭代器,指向第一個關鍵字大於k的元素。若k不在c中,返回和c.lower_bound(k)相等的迭代器。
c.equal_range(k) 返回一個pair,pair裡面是2個c的迭代器。first為第一個關鍵字等於k的迭代器,second為最後一個關鍵字等於k的位置的下一個位置的迭代器。若未找到,則pair的2個成員都等於c.end()

小例子嚮導:

程式塊 功能描述
test1 map的下標操作
test2 map 用自定義類型的下標操作
test3 map的查找
test4 multimap的查找

小例子:

#include <iostream>
#include <map>
#include <unordered_map>
#include <set>
#include <vector>

using namespace std;

class Test{
public:
  Test(int d = 0):data(d){}
  bool operator<(const Test& s)const{
    return s.data < data;
  }
  const int& getData()const{
    return data;
  }
private:
  int data;
};
int main(){
  //test1 map的下標操作                                                         
  /*                                                                            
  map<string,int> smap{{"aa",12},{"bb",10}};                                    
  unordered_map<int, int> imap{{1,11},{2,22}};                                  
  map<string,int>::mapped_type m1 = smap["aa"];//m1為int                        
  cout << m1 << endl;                                                           
  unordered_map<string,int>::mapped_type m2 = imap[2];//m2為int                 
  cout << m2 << endl;                                                           
  smap["aa"] = 33;                                                              
  cout << smap["aa"] << endl;                                                   
  smap["cc"] = 13;//想smap添加{"cc",13}                                         
  cout << smap["cc"] << endl;                                                   
  cout << smap.at("cc") << endl;                                                
  //cout << smap.at("ccd") << endl;//拋出out_of_range異常                       
  map<string,int>::mapped_type m3 = smap.at("aa");                              
  cout << m3 << endl;                                                           
  //想smap里添加了{"dd", 0},                                                    
  cout << smap["dd"] << endl;                                                   
  for(auto const &s : smap){                                                    
    cout << s.first << "," << s.second << endl;                                 
  }                                                                             
  */

  //test2 map 用自定義類型的下標操作                                            
  /*                                                                            
  map<Test,int> tmap{{Test(10), 10},{Test(11), 11}};                            
  tmap[Test()] = 1;                                                             
  for(auto const &s : tmap){                                                    
    cout << s.first.getData() << "," << s.second << endl;                       
  }                                                                             
  */

  //test3 map的查找                                                             
  /*                                                                            
  map<int, int> imap{{1,1},{3,3},{2,2},{5,5},{4,4}};                            
  map<int,int>::iterator it1 = imap.find(1);                                    
  cout << it1->first << endl;                                                   
  map<int,int>::iterator it2 = imap.find(4);//返回imap.end()                   
  if(it2 == imap.end()){cout << "it2 is end" << endl;}                          
  cout << imap.count(2) << endl;                                                
  auto it3 = imap.lower_bound(2);//{2,2}                                        
  cout << it3->first << "," << it3->second << endl;                             
  auto it4 = imap.upper_bound(4);//{5,5}                                        
  cout << it4->first << "," << it4->second << endl;                             
  */

  //test4 multimap的查找                                                        
  multimap<string, string> autrs{{"aaa","n1"},{"bbb","n1"},{"aaa","n2"},
                                                             {"aaa","n3"}};
  string sch("aaa");
  //方法1                                                                       
  auto cnt = autrs.count(sch);
  auto it = autrs.find(sch);
  while(cnt){
    cout << it->second << endl;
    ++it;
    --cnt;
  }
  cout << "-----------------" << endl;
  //方法2                                                                       
  for(auto beg = autrs.lower_bound(sch),end = autrs.upper_bound(sch);
      beg != end; ++beg){
    cout << beg->second << endl;
  }
  cout << "-----------------" << endl;
  //方法3                                                                       
  for(auto pos = autrs.equal_range(sch);pos.first != pos.second;++pos.first){
    cout << pos.first->second << endl;
  }
}

github完整代碼

c/c++ 學習互助QQ群:877684253

本人微信:xiaoshitou5854


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

-Advertisement-
Play Games
更多相關文章
  • 構建乘積數組給定一個數組A[0,1,...,n-1],請構建一個數組B[0,1,...,n-1],其中B中的元素B[i]=A[0]*A[1]*...*A[i-1]*A[i+1]*...*A[n-1]。不能使用除法。 1. 這題的意思是 B數組的元素是A數組中所有元素的乘積,但是要排除掉當前元素2. ...
  • 前言 在 "上一篇" 中我們學習了結構型模式的組合模式和過濾器模式。本篇則來學習下結構型模式最後的兩個模式, 享元模式和代理模式。 享元模式 簡介 享元模式主要用於減少創建對象的數量,以減少記憶體占用和提高性能。這種類型的設計模式屬於結構型模式,它提供了減少對象數量從而改善應用所需的對象結構的方式。 ...
  • 斷點調試的作用: A:查看程式的執行流程。 B:調試程式。 i變數只在for迴圈內有效,for迴圈結束後,變數i就消失了。 註意:要想看被調用方法的執行流程,那麼被調用方法也必須要加斷點。 ...
  • 限流可以認為服務降級的一種,限流就是限制系統的輸入和輸出流量已達到保護系統的目的。一般來說系統的吞吐量是可以被測算的,為了保證系統的穩定運行,一旦達到的需要限制的閾值,就需要限制流量並採取一些措施以完成限制流量的目的。比如:延遲處理,拒絕處理,或者部分拒絕處理等等。在介紹限流概念之前,我們先來聊聊身... ...
  • 上一篇文章介紹瞭如何運行了第一個Java程式“Hello World”。然而這個開發環境看起來那麼陌生,一個個名字元號完全不知道它們是幹啥的呀,對於初學者來說,好比天書一般,多看幾眼感覺都要走火入魔了。因此接下來還是好好分析一下Java工程的總體結構,理清這些文字元號的來龍去脈才好。話說宇宙原本一片 ...
  • The formal parameters of the method ...
  • 切片 在Python基礎篇里,我們知道Python的可序列對象可以通過索引號(下標)來引用對象元素,索引號可以由0開始從左向右依次獲取,可以從-1開始由右向左獲取。這種方法可以幫助我們依次獲取我們想要的元素。而切片可以幫助我們獲取被切片元素的副本。 可序列對象切片時所需要的參數[start_inde ...
  • Spring是眾多開源 Java 項目中的一員,基於分層的 JavaEE 應用一站式輕量級開源框架,主要核心是IOC控制反轉(Inversion of Control, IoC)和依賴註入(Dependency Injection, DI)這兩大技術。 下麵是一個非常原始,簡易的BeanFactor ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...