您好,登錄后才能下訂單哦!
這篇文章主要總結c++11&14-STL的要點,內容清晰明了,對此有興趣的小伙伴可以學習一下,相信大家閱讀完之后會有幫助。
在c++里面不得不提的一個標準庫,就是STL,STL包含很多實用的數據結構,如vector,list,map,set等都是我們常用的,而c++11也對STL做了一些補充,使得STL的內容越來越豐富,可選擇的也越來越多了。
1. std::array
先看一段代碼:
#include <array> #include <iostream> int main() { std::array<int, 4> arrayDemo = { 1,2,3,4 }; std::cout << "arrayDemo:" << std::endl; for (auto itor : arrayDemo) { std::cout << itor << std::endl; } int arrayDemoSize = sizeof(arrayDemo); std::cout << "arrayDemo size:" << arrayDemoSize << std::endl; return 0; }
從上面代碼可以看到,其實std::array
跟數組沒什么區別,只是增加了迭代器的功能。
2. std::forward_list
先看一段代碼:
#include <forward_list> #include <iostream> int main() { std::forward_list<int> numbers = {1,2,3,4,5,4,4}; std::cout << "numbers:" << std::endl; for (auto number : numbers) { std::cout << number << std::endl; } numbers.remove(4); std::cout << "numbers after remove:" << std::endl; for (auto number : numbers) { std::cout << number << std::endl; } return 0; }
std::forward_list
為c++11新增的線性表,與list
區別在于它是單向鏈表,而list
是雙向鏈表。我們在學習數據結構的時候都知道,鏈表在對數據進行插入和刪除是比順序存儲的線性表有優勢,因此在插入和刪除操作頻繁的應用場景中,使用list和forward_list
比使用array
、vector
和deque
效率要高很多。
3. std::unordered_map
先看一段代碼:
#include <iostream> #include <string> #include <unordered_map> int main() { std::unordered_map<std::string, std::string> mymap = { { "house","maison" }, { "apple","pomme" }, { "tree","arbre" }, { "book","livre" }, { "door","porte" }, { "grapefruit","pamplemousse" } }; unsigned n = mymap.bucket_count(); std::cout << "mymap has " << n << " buckets.\n"; for (unsigned i = 0; i<n; ++i) { std::cout << "bucket #" << i << " contains: "; for (auto it = mymap.begin(i); it != mymap.end(i); ++it) std::cout << "[" << it->first << ":" << it->second << "] "; std::cout << "\n"; } return 0; }
std::unordered_map
與std::map
用法基本差不多,但STL在內部實現上有很大不同,std::map
使用的數據結構為紅黑樹,且是有序的,而std::unordered_map
內部是哈希表的實現方式,無序。哈希map理論上查找效率為O(1),但在存儲效率上,哈希map需要增加哈希表的內存開銷。
4. std::unordered_set
先看一段代碼:
#include <iostream> #include <string> #include <unordered_set> #include <set> int main() { std::unordered_set<int> unorder_set; unorder_set.insert(7); unorder_set.insert(5); unorder_set.insert(3); unorder_set.insert(4); unorder_set.insert(6); std::cout << "unorder_set:" << std::endl; for (auto itor : unorder_set) { std::cout << itor << std::endl; } ​ std::set<int> set; set.insert(7); set.insert(5); set.insert(3); set.insert(4); set.insert(6); std::cout << "set:" << std::endl; for (auto itor : set) { std::cout << itor << std::endl; } }
std::unordered_set
的數據存儲結構也是哈希表的方式結構,除此之外,std::unordered_set
在插入時不會自動排序,這是與set表現不同的地方,其他用法基本類似。
看完上述內容,是不是對總結c++11&14-STL的要點有進一步的了解,如果還想學習更多內容,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。