如何將container中的iterator,從一個值取代成另外一個值? (C/C++) (STL)
2010-10-26 20:18
246 查看
Abstract
若想將container中的iterator,從一個值取代成另外一個值,但container並沒有提供replace()這個member function,而是提供了replace()這個Generic Algorithm。
Introduction
以下範例我們將vector中,所有的1取代成4。
1#include <iostream>
#include <vector>
#include <algorithm>
#include <sstream>
using namespace std;
4
2
3
19行的
replace(ivec.begin(), ivec.end(), 1, 4);
第一個參數傳入vector的起始位址,第二個參數傳入vector的結束位址,第三個參數是要被取代的值,第四個參數是要取代成的值。
replace()完整的定義為
template<typename ForwardIterator, typename T>
void replace(ForwardIterator first, ForwardIterator last, const T& old_value, const T& new_value);
其他相關的algorithm還有replace_if(),replace_copy(),replace_copy_if()。
Conclusion
初學者學習STL,對於STL的container僅提供有限的功能感到困擾,因為STL是基於泛型(GP : Generic Programming)下的產物,和物件導向的.NET Framework、Java SDK不同。在物件導向下,algorithm和container綁在一起,每個container都自給自足的提供自己的algorithm(member function),但這樣的缺點是,很多container都必須提供相同的基礎功能,這樣會造成class的肥大,且要重複寫相同的功能,如vector需提供replace(),那list、deque、stack怎麼辦?也要重新寫replace()嗎?泛型強調algorithm和container分離,而algorithm可以支援各種container,對於開發STL的人員來說,只要開發一次replace()即可,對於使用STL的人員來說,也只要學習一次replace()即可,而且將來若要從vector改成list,只需換掉container即可,其他程式都不須修改。
所以使用STL時,若container沒有提供適當的功能,別忘了找找Generic Algorithm,也可順便欣賞這個由GP思維下library的beauty。
若想將container中的iterator,從一個值取代成另外一個值,但container並沒有提供replace()這個member function,而是提供了replace()這個Generic Algorithm。
Introduction
以下範例我們將vector中,所有的1取代成4。
1#include <iostream>
#include <vector>
#include <algorithm>
#include <sstream>
using namespace std;
4
2
3
19行的
replace(ivec.begin(), ivec.end(), 1, 4);
第一個參數傳入vector的起始位址,第二個參數傳入vector的結束位址,第三個參數是要被取代的值,第四個參數是要取代成的值。
replace()完整的定義為
template<typename ForwardIterator, typename T>
void replace(ForwardIterator first, ForwardIterator last, const T& old_value, const T& new_value);
其他相關的algorithm還有replace_if(),replace_copy(),replace_copy_if()。
Conclusion
初學者學習STL,對於STL的container僅提供有限的功能感到困擾,因為STL是基於泛型(GP : Generic Programming)下的產物,和物件導向的.NET Framework、Java SDK不同。在物件導向下,algorithm和container綁在一起,每個container都自給自足的提供自己的algorithm(member function),但這樣的缺點是,很多container都必須提供相同的基礎功能,這樣會造成class的肥大,且要重複寫相同的功能,如vector需提供replace(),那list、deque、stack怎麼辦?也要重新寫replace()嗎?泛型強調algorithm和container分離,而algorithm可以支援各種container,對於開發STL的人員來說,只要開發一次replace()即可,對於使用STL的人員來說,也只要學習一次replace()即可,而且將來若要從vector改成list,只需換掉container即可,其他程式都不須修改。
所以使用STL時,若container沒有提供適當的功能,別忘了找找Generic Algorithm,也可順便欣賞這個由GP思維下library的beauty。
相关文章推荐
- (原創) 如何將container中的iterator,從一個值取代成另外一個值? (C/C++) (STL)
- (原創) 如何找出兩個container中相同元素的個數? (C/C++) (STL)
- STL中 如何在遍历中使用 iterator/reverse_iterator 删除元素
- (原創) 如何判斷一個字串是否存在於另外一個字串? (C/C++) (C)
- 如何使用istream_iterator将cin转到vector? (C/C++) (STL)
- 如何使用istream_iterator将cin转到vector? (C/C++) (STL)
- (原創) 如何使用reverse_iterator? (C/C++) (STL)
- 如何刪除container中重複的element? (C/C++) (STL)
- 如何使用istream_iterator將文字檔轉到vector? (C/C++) (STL)
- STL中使用reverse_iterator时,如何正确使用erase函数
- [zz]如何使用istream_iterator将cin转到vector? (C/C++) (STL)
- 如何使用reverse_iterator? (C/C++) (STL)
- (原創) 如何刪除container中重複的element? (C/C++) (STL)
- [转](winform cookie)如何向某网址Post信息,并得到CookieContainer以便以后直接通过验证
- [转]如何使用VS 2013發布一個可以在Windows XP中獨立運行的可執行文件
- ssm框架中,上传的资料存放在另外一台ftp服务器中是如何实现的?以及编码问题
- 使用stl中的 advance和 distance 方法来进行iterator的加减 http://blog.csdn.net/tangaowen/article/details/7515558
- STL List Container
- 如何把一个DataTable中的某列通过表关系加到另外一个DataTable中
- 如何选择合适的STL容器?