C++利用std::forward_list查找插入數(shù)據(jù)方法示例
std::forward_list介紹
std::forward_list是在C++11中引入的單向鏈表或叫正向列表。forward_list具有插入、刪除表項速度快、消耗內(nèi)存空間少的特點(diǎn),但只能向前遍歷。與其它序列容器(array、vector、deque)相比,forward_list在容器內(nèi)任意位置的成員的插入、提取(extracting)、移動、刪除操作的速度更快,因此被廣泛用于排序算法。forward_list是一個允許在序列中任何一處位置以常量耗時插入或刪除元素的順序容器(sequence Container)。forward_list可以看作是對C語言風(fēng)格的單鏈表的封裝,僅提供有限的接口,和C中它的實(shí)現(xiàn)相比,基本上不會有任何開銷。當(dāng)不需要雙向迭代的時候,與std::list相比,該容器具有更高的空間利用率。
forward_list的主要缺點(diǎn)是不能在常量時間內(nèi)隨機(jī)訪問任意成員,對成員的訪問需要線性時間代價;以及存儲鏈接信息需要消耗內(nèi)存,特別是當(dāng)包含大量的小規(guī)模成員時。forward_list處于效率考慮,有意不提供size()成員函數(shù)。獲取forward_list所包含的成員個數(shù)需要用std::distance(_begin, _end)算法。forward_list中的每個元素保存了定位前一個元素及后一個元素的信息,不能進(jìn)行直接隨機(jī)訪問操作。
本文將給大家介紹關(guān)于C++用std::forward_list查找插入數(shù)據(jù)的相關(guān)內(nèi)容,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細(xì)的介紹吧。
示例代碼:
//
// Forward_list.hpp
// 練習(xí)
//
// Created by hanzhiqiang on 2017/6/11.
// Copyright © 2017年 hanzhiqiang. All rights reserved.
//
#ifndef Forward_list_hpp
#define Forward_list_hpp
#include <stdio.h>
#include <iostream>
#include <forward_list>
using namespace std;
int main()
{
forward_list<string> mList;
mList.emplace_front("aaa");
mList.emplace_front("bbb");
mList.emplace_front("ccc");
for (auto it = mList.begin(); it != mList.end(); it++)
{
cout<<*it<<endl;
}
// for (auto it = mList.before_begin(); it != mList.end(); it++)
// {
// cout<<*it<<endl;
// }
// auto itList = find(mList.begin(), mList.end(), "fff");
// if (itList != mList.end()) \
// {
// mList.emplace_after(itList, "111");
// }
// else
// {
// mList.insert_after(mList.end(),"222");//c++ primer p 313 向末尾插入數(shù)據(jù)結(jié)果未知 error
// }
auto prev = mList.before_begin();
auto curr = mList.begin();
bool isInsert = false;
while (curr != mList.end())
{
if (*curr == "fff")
{
curr = mList.insert_after(curr, "111");
isInsert = true;
}
prev = curr;
curr++;
}
if(!isInsert)
{
curr = mList.insert_after(prev, "222");//向末尾插入數(shù)據(jù)成功
}
for (auto it = mList.begin(); it != mList.end(); it++)
{
cout<<"插入元素后"<<*it<<endl;
}
cout<<"fuck"<<endl;
return 0;
}
#endif /* Forward_list_hpp */
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
C++實(shí)現(xiàn)學(xué)生住宿管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++實(shí)現(xiàn)學(xué)生住宿管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
C語言實(shí)現(xiàn)手寫Map(數(shù)組+鏈表+紅黑樹)的示例代碼
這篇文章主要為大家詳細(xì)介紹了如何利用C語言實(shí)現(xiàn)手寫Map(數(shù)組+鏈表+紅黑樹),文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)有一定借鑒價值,需要的可以參考一下2022-09-09
詳解C語言中printf輸出的相關(guān)函數(shù)
這篇文章主要介紹了C語言中printf輸出的相關(guān)函數(shù)總結(jié),是C語言入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下2015-08-08
C語言程序設(shè)計譚浩強(qiáng)第五版課后答案(第三章習(xí)題答案)
這篇文章主要介紹了C語言程序設(shè)計譚浩強(qiáng)第五版課后答案(第三章習(xí)題答案),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2021-04-04

