一、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-tw/n/331899.html