欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

c++11&14-STL要點匯總

 更新時間:2020年06月03日 09:03:24   投稿:newname  
這篇文章主要介紹了c++11&14中的STL要點,文中代碼簡單易懂,方便大家更好的學(xué)習(xí)參考,感興趣的朋友可以了解下

在c++里面不得不提的一個標(biāo)準(zhǔn)庫,就是STL,STL包含很多實用的數(shù)據(jù)結(jié)構(gòu),如vector,list,map,set等都是我們常用的,而c++11也對STL做了一些補充,使得STL的內(nèi)容越來越豐富,可選擇的也越來越多了。

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跟數(shù)組沒什么區(qū)別,只是增加了迭代器的功能。

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區(qū)別在于它是單向鏈表,而list是雙向鏈表。我們在學(xué)習(xí)數(shù)據(jù)結(jié)構(gòu)的時候都知道,鏈表在對數(shù)據(jù)進(jìn)行插入和刪除是比順序存儲的線性表有優(yōu)勢,因此在插入和刪除操作頻繁的應(yīng)用場景中,使用list和forward_list比使用array、vectordeque效率要高很多。

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_mapstd::map用法基本差不多,但STL在內(nèi)部實現(xiàn)上有很大不同,std::map使用的數(shù)據(jù)結(jié)構(gòu)為紅黑樹,且是有序的,而std::unordered_map內(nèi)部是哈希表的實現(xiàn)方式,無序。哈希map理論上查找效率為O(1),但在存儲效率上,哈希map需要增加哈希表的內(nèi)存開銷。

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的數(shù)據(jù)存儲結(jié)構(gòu)也是哈希表的方式結(jié)構(gòu),除此之外,std::unordered_set在插入時不會自動排序,這是與set表現(xiàn)不同的地方,其他用法基本類似。

以上就是c++11&14-STL要點匯總的詳細(xì)內(nèi)容,更多關(guān)于c++11&14-STL的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 基于C++語言實現(xiàn)機動車違章處罰管理系統(tǒng)

    基于C++語言實現(xiàn)機動車違章處罰管理系統(tǒng)

    這篇文章主要介紹了基于C++語言實現(xiàn)機動車違章處罰管理系統(tǒng)的相關(guān)資料,需要的朋友可以參考下
    2016-07-07
  • c++使用正則表達(dá)式提取關(guān)鍵字的方法

    c++使用正則表達(dá)式提取關(guān)鍵字的方法

    這篇文章給大家介紹了c++使用正則表達(dá)式提取關(guān)鍵字的方法,相對來說比較簡單,同時給大家提到了c++通過正則表達(dá)式提取匹配到的字符串的方法,非常不錯,具有一定的參考借鑒價值,需要的朋友參考下吧
    2018-08-08
  • 完美解決QT?QGraphicsView提升到QChartView報錯的問題

    完美解決QT?QGraphicsView提升到QChartView報錯的問題

    使用QT提供的QChartView來繪制圖表,提升QGraphicsView控件繼承QChartView后,然后將QGraphicsView提升到我們自己寫的類,怎么才能確保提升后編譯不報錯呢,下面小編給大家?guī)砹薗T QGraphicsView 提升到QChartView報錯解決方案,感興趣的朋友一起看看吧
    2023-05-05
  • 用c 獲取文件MD5值的實現(xiàn)方法

    用c 獲取文件MD5值的實現(xiàn)方法

    本篇文章是對用c語言獲取文件MD5值的方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化

    QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化

    本文主要介紹了QT中QByteArray與char、int、float之間的互相轉(zhuǎn)化,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-05-05
  • 詳解C++17中if和switch語句的新特性

    詳解C++17中if和switch語句的新特性

    這篇文章主要為大家詳細(xì)介紹了C++17中if和switch語句的新特性的相關(guān)知識,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-12-12
  • 基于Matlab實現(xiàn)水波倒影特效的制作

    基于Matlab實現(xiàn)水波倒影特效的制作

    這篇文章主要介紹了如何利用Matlab制作出水波倒影的特效,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Matlab有一定幫助,需要的可以參考一下
    2022-03-03
  • C++ 大根堆排序?qū)W習(xí)筆記

    C++ 大根堆排序?qū)W習(xí)筆記

    這篇文章主要為大家介紹了C++ 大根堆排序的學(xué)習(xí)教程詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-10-10
  • 詳解C++中二進(jìn)制求補運算符與下標(biāo)運算符的用法

    詳解C++中二進(jìn)制求補運算符與下標(biāo)運算符的用法

    這篇文章主要介紹了C++中二進(jìn)制求補運算符與下標(biāo)運算符的用法,是C++入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下
    2016-01-01
  • C++中priority_queue的使用與模擬實現(xiàn)

    C++中priority_queue的使用與模擬實現(xiàn)

    本文主要介紹了C++中priority_queue的使用與模擬實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02

最新評論