深入剖析mapfind函數

一、mapfind函數

mapfind函數是C++ STL中關聯式容器map中的一個成員函數,用於在map中查找鍵值對應的value值。


//示例代碼,使用mapfind函數查找key對應的value
#include <iostream>
#include <map>

using namespace std;

int main()
{
    map<string,int> mymap;
    mymap["apple"] = 1;
    mymap["banana"] = 2;
    mymap["orange"] = 3;

    string key = "apple";
    int value = mymap.mapfind(key);

    cout << key << " " << value << endl;

    return 0;
}

在上面的代碼中,我們創建了一個map容器,將字符串”apple”作為鍵,將整數1作為值存入map中。然後,我們使用mapfind函數查找”apple”對應的值,並將其輸出。

二、mapfind函數返回

如果mapfind函數在map中找到了給定的鍵值,它將返回對應的值。如果沒有找到,mapfind函數將返回一個默認值,這個默認值與map容器中存儲的value類型有關。如int類型的默認值為0,string類型的默認值為空字符串。


//示例代碼,返回默認值
#include <iostream>
#include <map>

using namespace std;

int main()
{
    map<string,int> mymap;
    mymap["apple"] = 1;
    mymap["banana"] = 2;
    mymap["orange"] = 3;

    string key = "watermelon";
    int value = mymap.mapfind(key);

    cout << key << " " << value << endl;

    return 0;
}

在上面的代碼中,我們使用了一個在map中不存在的鍵”watermelon”,mapfind函數將返回默認值0,並將其輸出。

三、mapfind找不到返回什麼

mapfind函數在找不到對應的鍵值時,將返回一個默認值。對於基本類型的值,如int、double等,默認值為0。對於類類型的值,將默認構造一個該類型的對象。


//示例代碼,返回默認構造的對象
#include <iostream>
#include <map>
#include <string>

using namespace std;

class Person{
public:
    string name;
    int age;
};

int main(){
    map<string,Person> mymap;
    mymap["Tom"].name = "Tom";
    mymap["Tom"].age = 18;

    string key = "Jerry";
    Person value = mymap.mapfind(key);

    cout << key << " " << value.name << " " << value.age << endl;

    return 0;
}

上面這段代碼中,我們在map容器中創建了一個Person對象,並將其存入map中。然後,我們使用一個不存在於map中的鍵”Jerry”調用mapfind函數,mapfind函數將返回默認構造的Person對象,並將其輸出。

四、find的用法

與mapfind函數不同,find函數不是map容器的成員函數,而是在頭文件中提供的函數,用於在STL容器中查找元素。find函數的返回值是一個迭代器,指向容器中第一個等於待查找元素的元素。如果找不到,則返回容器的end迭代器。


//示例代碼,使用find函數查找key對應的value
#include <iostream>
#include <map>

using namespace std;

int main()
{
    map<string,int> mymap;
    mymap["apple"] = 1;
    mymap["banana"] = 2;
    mymap["orange"] = 3;

    string key = "apple";
    auto it = mymap.find(key);

    if(it != mymap.end()){
        int value = it->second;
        cout << key << " " << value << endl;
    }

    return 0;
}

在上面的代碼中,我們使用了find函數查找鍵為”apple”的鍵值對,並將其輸出。如果找到了,我們使用迭代器訪問對應的value值。否則,我們不執行任何操作。

五、find out

在使用STL容器的時候,我們常常需要查找容器中的元素。除了find函數,STL中還有一些其他的查找函數可供使用,如count、lower_bound、upper_bound等。

count函數用於在容器中查找某個值的出現次數。如果該值出現了n次,count函數將返回n。


//示例代碼,使用count函數查找值的出現次數
#include <iostream>
#include <map>

using namespace std;

int main()
{
    map<string,int> mymap;
    mymap["apple"] = 1;
    mymap["banana"] = 2;
    mymap["orange"] = 3;

    int count = mymap.count("apple");

    cout << "apple count: " << count << endl;

    return 0;
}

在上面的代碼中,我們使用count函數查找”apple”出現的次數,並將次數輸出。

lower_bound和upper_bound函數用於在有序容器中查找某個值。lower_bound函數返回第一個大於或等於給定值的迭代器,upper_bound函數返回第一個大於給定值的迭代器。


//示例代碼,使用lower_bound和upper_bound函數查找值在有序容器中的位置
#include <iostream>
#include <set>

using namespace std;

int main()
{
    set<int> myset;
    myset.insert(1);
    myset.insert(3);
    myset.insert(5);

    auto low = myset.lower_bound(2);
    auto up = myset.upper_bound(4);

    cout << "lower bound: " << *low << endl;
    cout << "upper bound: " << *up << endl;

    return 0;
}

在上面的代碼中,我們使用lower_bound函數查找第一個大於或等於2的元素,並使用upper_bound函數查找第一個大於4的元素。由於set容器是有序的,所以它們的返回值分別為3和5。

六、map find和count 性能

在使用STL容器時,我們需要考慮它們的性能。在map容器中,find函數和count函數是用於查找元素的常用函數。find函數的時間複雜度為O(logN),count函數的時間複雜度為O(logN)。在實際使用時,我們應該根據具體的情況選擇使用哪一個函數。


//示例代碼,比較map find和count函數的性能
#include <iostream>
#include <map>
#include <chrono>

using namespace std;

int main(){

    map<int,int> mymap;
    for(int i=0; i<1000000; i++){
        mymap[i] = i+1;
    }

    auto start = chrono::high_resolution_clock::now();
    int count = mymap.count(999999);
    auto end = chrono::high_resolution_clock::now();
    cout << "count time: " << chrono::duration_cast<chrono::microseconds>(end-start).count() << endl;

    start = chrono::high_resolution_clock::now();
    auto it = mymap.find(999999);
    int value = it->second;
    end = chrono::high_resolution_clock::now();
    cout << "find time: " << chrono::duration_cast<chrono::microseconds>(end-start).count() << endl;

    return 0;
}

在上面的代碼中,我們創建了一個包含1000000個元素的map容器。然後,我們使用count函數和find函數分別查找鍵值為999999的元素,並比較它們的時間複雜度。

根據實驗結果,count函數的執行時間約為400微秒,find函數的執行時間約為200微秒。因此,在多次查找同一個元素的情況下,使用find函數的效率更高。

原創文章,作者:RQRNQ,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/331899.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
RQRNQ的頭像RQRNQ
上一篇 2025-01-20 14:11
下一篇 2025-01-20 14:11

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字符串操作中,capitalize函數常常被用到,這個函數可以使字符串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • 單片機打印函數

    單片機打印是指通過串口或並口將一些數據打印到終端設備上。在單片機應用中,打印非常重要。正確的打印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的打印數據可以幫助我們快速…

    編程 2025-04-29
  • Python3定義函數參數類型

    Python是一門動態類型語言,不需要在定義變量時顯示的指定變量類型,但是Python3中提供了函數參數類型的聲明功能,在函數定義時明確定義參數類型。在函數的形參後面加上冒號(:)…

    編程 2025-04-29
  • Python實現計算階乘的函數

    本文將介紹如何使用Python定義函數fact(n),計算n的階乘。 一、什麼是階乘 階乘指從1乘到指定數之間所有整數的乘積。如:5! = 5 * 4 * 3 * 2 * 1 = …

    編程 2025-04-29
  • Python定義函數判斷奇偶數

    本文將從多個方面詳細闡述Python定義函數判斷奇偶數的方法,並提供完整的代碼示例。 一、初步了解Python函數 在介紹Python如何定義函數判斷奇偶數之前,我們先來了解一下P…

    編程 2025-04-29
  • Python函數名稱相同參數不同:多態

    Python是一門面向對象的編程語言,它強烈支持多態性 一、什麼是多態多態是面向對象三大特性中的一種,它指的是:相同的函數名稱可以有不同的實現方式。也就是說,不同的對象調用同名方法…

    編程 2025-04-29
  • 分段函數Python

    本文將從以下幾個方面詳細闡述Python中的分段函數,包括函數基本定義、調用示例、圖像繪製、函數優化和應用實例。 一、函數基本定義 分段函數又稱為條件函數,指一條直線段或曲線段,由…

    編程 2025-04-29

發表回復

登錄後才能評論