//---------------------------15/03/30----------------------------

//min_element

template<class ForwardIterator>

ForwardIterator min_element(ForwardIterator first, ForwardIterator last)

{

if(first == last)

return first;

ForwardIterator result = first;

while(++first != last)

if(*first < *result)   
//自定义版本if(comp(*first, *result))

result = first;

return result;

}

//partition

//快排的基本步骤:划分,让判断true的元素放在区间前,让判断为false的元素放在区间后

//返回第一个非true的位置:第一种情况 end。第二种情况
元素被判断为flase

//这是不稳定的。

template<class BidirectionalIterator,
class Predicate>

BidirectionalIterator partition(BidirectionalIterator first,

BidirectionalIterator last,

Predicate pred)

{

while (true)

{

while (true)

{

if(first == last)

return first;

else if(pred(*first))

++first;

else

break;

}

--last;             //第一次指向的事end所以--
之后指向的是判断过的数,所以要--

while (true)

{

if(first == last)

return first;

else if(!pred(*last))

--last;

else

break;

}

iter_swap(first, last);

++first;           
//接下来要判断下一个

}

}

//remove

template<class ForwardIterator,
class T>

ForwardIterator remove(ForwardIterator first, ForwardIterator last,

const T& value)

{

first = find(first, last, value);

ForwardIterator next = first;

return first == last ? first : remove_copy(++next, last, first, value);

}

template<class InputIterator,
class OutputIterator,
class T>

OutputIterator remove_copy(InputIterator, first, InputIterator last,

OutputIterator result,
const T& value)

{

for(; first != last; ++first)

if(*first != value)        
//remove_copy_if版本  if(!pred(*first))

{

*result = *first;

++result;

}

return result;

}

//replace

template<class ForwardIterator,
class T>

void replace(ForwardIterator first, ForwardIterator last,

const T& old_value,
const T& new_value)

{

for(; first != last; ++first)

if(*first == old_value)

*first = new_value;

//replace_if版本 if(pred(*first)) *first = new_value;

}

template<class InputIterator,
class OutputIterator,
class T>

OutputIterator replace_copy(InputIterator first, InputIterator last,

OutputIterator result,
const T& old_value,

const T& new_value)

{

for(; first != last; ++first, ++result)

*result = *first == old_value ? new_value : *first;

//replace_copy_if版本 *result = pred(*first) ? new_value : *first;

return result;

}

//reverse

template<class BidirectionalIterator>

inline void reverse(BidirectionalIterator first, BidirectionalIterator last)

{

__reverse(first, last, iterator_category(first));

}

template<class BidirectionalIterator>

void __reverse(BidirectionalIterator first, BidirectionalIterator last,

bidirectional_iterator_tag)

{

while (true)

{

if(first == last || first == --last)

return;

else

iter_swap(first++, last);

}

}

//随机迭代器的版本只需要判断一次
而非随机迭代器要判断两次,故效率上有差距,所以分开写

template<class RandomAccessIterator>

void __reverse(RandomAccessIterator first, RandomAccessIterator last,

random_access_iterator_tag)

{

while(first < last)

iter_swap(first++, --last);

}

template<class BidirectionalIterator,
class OutputIterator>

OutputIterator reverse_copy(BidirectionalIterator first,

BidirectionalIterator last,

OutputIterator result)

{

while (first != last)

{

--last;

*result = *last;

++result;

}

return result;

}

//rotate

template<class ForwardIterator>

inline void rotate(ForwardIterator first, ForwardIterator middle,

ForwardIterator last)

{

if(first == middle || middle == last)

return;

__rotate(first, middle, last, distance_type(first),

iterator_category(first));

}

//单向的迭代器走这边

//只能单向行走,效率最低,要赋值起码1.5n次(当两者区间相同时)。

//调用一次swap就要赋值3次

template<class ForwardIterator,
class Distance>

void __rotate(ForwardIterator first, ForwardIterator middle,

ForwardIterator last, Distance*, forward_iterator_tag)

{

for(ForwardIterator i = middle; ;)

{

iter_swap(first, i);

++first;

++i;

if(first == middle)

{

if(i == last)

return;

middle = i;

}

else if(i ==last)

i = middle;

}

}

//三次反转
固定赋值1.5n次

template<class BidirectionalIterator,
class Distance>

void __rotate(BidirectionalIterator first, BidirectionalIterator middle,

BidirectionalIterator last, Distance*,

bidirectional_iterator_tag)

{

reverse(first, middle);

reverse(middle, last);

reverse(first, last);

}

template<class RandomAccessIterator,
class Distance>

void __rotate(RandomAccessIterator first, RandomAccessIterator middle,

RandomAccessIterator last, Distance*,

random_access_iterator_tag)

{

Distance n = __gcd(last - first, middle - first);

while (n--)

__rotate_cycle(first, last, first + n, middle - first,

value_type(first));

}

template<class EuclideanRingElement>

EuclideanRingElement __gcd(EuclideanRingElement m, EuclideanRingElement n)

{

)

{

EuclideanRingElement t = m % n;

m = n;

n = t;

}

return m;

}

//最差的情况赋值1.5n次(当区间相等时),最少赋值n+1次(第一个或第二个区间为1时)。

template<class RandomAccessIteratorm,
class Distance, class T>

void __rotate_cycle(RandomAccessIterator first, RandomAccessIterator last,

RandomAccessIterator initial, Distance shift, T*)

{

T value = *initial;

RandomAccessIterator ptr1 = initial;

RandomAccessIterator ptr2 = ptr1 + shift;

while (ptr2 != initial)

{

*ptr1 = *ptr2;

ptr1 = ptr2;

if(last - ptr2 > shift)

ptr2 += shift;

else

ptr2 = first + (shift - (last - ptr2));

}

*ptr1 = value;

}

//rotate_copy

template<class ForwardIterator,
class OutputIterator>

OutputIterator rotate_copy(ForwardIterator first, ForwardIterator middle,

ForwardIterator last, OutputIterator result)

{

return copy(first, middle, copy(middle, last, result));

}

//search

template<class ForwardIterator1,
class ForwardIterator2>

inline ForwardIterator search(ForwardIterator1 first1,

ForwardIterator1 last1,

ForwardIterator2 first2,

ForwardIterator last2)

{

return __search(first1, last1, first2, last2,distance_type(first1),

distance_type(first2));

}

template<class ForwardIterator1,
class ForwardIterator2,
class distance1,

class Distance2>

ForwardIterator1 __search(ForwardIterator1 first1, ForwardIterator1 last1,

ForwardIterator2 first2, ForwardIterator2 last2,

Distance1*, Distance2*)

{

Distance1 d1 =
;

distance(first1, last1, d1);

Distance2 d2 =
;

distance(first2, last2, d2);

if(d1 < d2) return last1;

ForwardIterator1 current1 = first1;

ForwardIterator2 current2 = first2;

while (current2 != last2)

{

if (*current1 == *current2)

{

++current1;

++current2;

}

else

{

if (d1 == d2)

return last1;

else

{

current1 = ++first1;

current2 = first2;

--d1;

}

}

}

return first1;

}

//search_n

template<class ForwardIterator,
class Interger, class T>

ForwardIterator search_n(ForwardIterator first,

ForwardIterator last,

Interger count,
const T& value)

{

)

return first;

else

{

//先找到第一个

first = find(first, last, value);

while (first != last)

{

Interger n = count -
;

ForwardIterator i = first;

++i;

//找连续符合的元素,都找到了的话 n会等于0;

&& *i == value)

{

++i;

--n;

}

)

return first;

else

first = find(i, last, value);

}

return last;

}

}

template<class ForwardIterator,
class Interger, class T,

class BinaryPredicate>

ForwardIterator search_n(ForwardIterator first,

ForwardIterator last,

Interger count,
const T& value,

BinaryPredicate binary_pred)

{

)

return first;

else

{

//自己实现find,其实可以使用find_if版本的
不过需要使用bind函数

while (first != last)

{

if(binary_pred(*first, value))

break;

++first;

}

while (first != last)

{

Interger n = count -
;

ForwardIterator i = first;

++i;

//找连续符合的元素,都找到了的话 n会等于0;

&& *i == value)

{

++i;

--n;

}

)

return first;

else

{

while (i != last)

{

if(binary_pred(*first, value))

break;

++i;

}

first = i;

}

}

return last;

}

}

//swap_ranges

//区间不能重叠,不然会产生未知结果

template<class ForwardIterator1,
class ForwardIterator2>

ForwardIterator2 swap_ranges(ForwardIterator1 first1,

ForwardIterator1 last1,

ForwardIterator2 first2)

{

for(; first != last1; ++first1, ++first2)

iter_swap(first1, first2);

return first2;

}

//transform

//对每个元素执行op操作后,复制到目的区间

template<class InputIterator,
class OutputIterator,
class UnaryOperation>

OutputIterator transform(InputIterator first1, InputIterator last,

OutputIterator result, UnaryOperation op)

{

for(; first != last; ++first, ++result)

*result = op(*first);

return result;

}

template<class InputIterator1,
class InputIterator2,
class OutputIterator,

class BinaryOperation>

OutputIterator transform(InputIterator1 first1, InputIterator last1,

InputIterator2 first2, InputIterator last2,

BinaryOperation binary_op)

{

for(; first1 != last1; ++first1, ++first2, ++result)

*result = binary_op(*first1, *first2);

return result;

}

//unique

//只能移除相邻的重复元素(首先要有相邻元素才会开始删除,相邻元素后面如果还有同样的元素也会被删除)

//要移除所有重复元素必须先排序

template<class ForwardIterator>

ForwardIterator unique(ForwardIterator first, ForwardIterator last)

{

first = adjacent_find(first, last);

return unique_copy(first, last, first);

}

template<class InputIterator,
class ForwardIterator>

inline OutputIterator unique_copy(InputIterator first,

InputIterator last,

OutputIterator result)

{

if(first == last)
return result;

return __unique_copy(first, last, result, iterator_category(result));

}

template<class InputIterator,
class ForwardIterator>

ForwardIterator __unique_copy(InputIterator first,

InputIterator last,

ForwardIterator result,

forward_iterator_tag)

{

*result = *first;

while (++first != last)

{

if(*result != *first)

*++result = *first;

}

return ++result;

}

template<class InputIterator,
class OutputIterator>

inline OutputIterator __unique_copy(InputIterator first,

InputIterator last,

ForwardIterator result,

output_iterator_tag)

{

return __unique_copy(first, last, result, value_type(first));

}

template<class InputIterator,
class OutputIterator,
class T>

OutputIterator __unique_copy(InputIterator first, InputIterator last,

OutputIterator result, T*)

{

T value = *first;

*result = value;

while (++first != last)

{

if(value != *first)
//如果result为只读,这里就只能通过值判断
而不能使用(*result != *first)

{

value = *first;

*++result = value;

}

}

return ++result;

}

stl源码剖析 详细学习笔记 算法(3)的更多相关文章

  1. stl源码剖析 详细学习笔记 算法(1)

    //---------------------------15/03/27---------------------------- //算法 { /* 质变算法:会改变操作对象之值 所有的stl算法都 ...

  2. stl源码剖析 详细学习笔记 算法总览

    //****************************基本算法***************************** /* stl算法总览,不在stl标准规格的sgi专属算法,都以 *加以标 ...

  3. stl源码剖析 详细学习笔记 算法(2)

    //---------------------------15/03/29---------------------------- //****************************set相 ...

  4. stl源码剖析 详细学习笔记 算法(5)

    //---------------------------15/04/01---------------------------- //inplace_merge(要求有序) template< ...

  5. stl源码剖析 详细学习笔记 算法(4)

    //---------------------------15/03/31---------------------------- //lower_bound(要求有序) template<cl ...

  6. stl源码剖析 详细学习笔记 hashtable

    //---------------------------15/03/24---------------------------- //hashtable { /* 概述: sgi采用的是开链法完成h ...

  7. stl源码剖析 详细学习笔记 set map

    // //  set map.cpp //  笔记 // //  Created by fam on 15/3/23. // // //---------------------------15/03 ...

  8. stl源码剖析 详细学习笔记 RB_tree (2)

    //---------------------------15/03/22---------------------------- //一直好奇KeyOfValue是什么,查了下就是一个和仿函数差不多 ...

  9. stl源码剖析 详细学习笔记 RB_tree (1)

    // //  RB_tree_STL.cpp //  笔记 // //  Created by fam on 15/3/21. // // #include "RB_tree_STL.h&q ...

随机推荐

  1. .NET中低版本程序调用高版本DLL

    在.NET项目开发中,有时需要对旧的程序进行二次开发,但是有些DLL是高版本的,如果对旧程序升级高版本,则需要改动的地方比较多,在项目比较急,开发时间短的情况下,可以通过下面方法让低版本程序调用高版本 ...

  2. Oracle EBS 贷项通知单核销

    SELECT cm.trx_number ,fnd_flex_ext.get_segs('SQLGL', 'GL#', gcc.chart_of_accounts_id, ad.code_combin ...

  3. 数据库还原错误:指定的转换无效。(SqlManagerUI)

    SSMS在一定程度上方便我们进行一些常见的操作.但有时候它处理得又不是那么不人性化.尤其是错误信息. 今天我在进行数据库还原的时候就碰到一个错误:指定的转换无效.(SqlManagerUI) Spec ...

  4. 找回master库中被删除的系统表

    接手的某个数据库实例中,master数据库中的所有系统表都被误删除掉了. 最直接影响就是一旦涉及到要查询这些系统表,就会出现错误. 例如,右键点击某个数据,查看属性时会出现如下图所示错误: 那么怎么找 ...

  5. [Python_3] Python 函数 & IO

    0. 说明 Python 函数 & IO 笔记,基于 Python 3.6.2 参考  Python: read(), readline()和readlines()使用方法及性能比较  Pyt ...

  6. .NET Core 环境下使用命令行移除某个 nuget 包的具体方法

    .NET Core 使用Nuget包一般是先写入csproj文件,然后下载保存在\bin\Debug\netcoreapp2.0\publish\下,所以可以采用如下方案进行删除操作(其中netcor ...

  7. .net core 入坑经验 - 2、MVC Core之获取网站运行路径

    这次是建立了asp.net mvc core项目,在controller中想获取网站在硬盘中的路径,找了一圈Server.MapPath() 已不存在,HttpContent也一样,经过查阅资料发现是 ...

  8. VS 代码整理插件推荐:CodeMaid

    一直在用,觉得很不错,其他插件基本上不用了,所以拿来记录并分享一下.CodeMaid 说明文档CodeMaid 下载安装不用说明了,使用看说明文档就好. CodeMaid和ReSharp类似,开源且免 ...

  9. 一些安卓模拟器的IP问题和getOutputStream();关于connect();的函数异常的问题

    ip问题 1.不能使用local host 和127.0.0.1作为本地服务器的地址,而网上无论10.0.0.2还是10.0.2.2的8080端口都无法访问.真正的地址应该在CMD 键入ipconfi ...

  10. vue-devtoools 调试工具安装

    最近在研究vue单页面应用,一步一步用上全家桶,开发避免不了的就是调试工具,因为vue是进行数据驱动的,单从chrome里面进行element查看,查不到什么鸟东西,必须要进行对数据动向进行关查,那我 ...