STL算法实现

24 篇文章 3 订阅
23 篇文章 0 订阅
本文深入探讨了STL算法中的迭代器特性,特别是它们的值传递方式,并提供了如何在不同场景下高效使用迭代器的实践建议。通过具体的代码示例,展示了如何利用STL来实现区间和计算、容器操作以及内积计算等任务,同时强调了参数传递的最佳实践。
摘要由CSDN通过智能技术生成

写了一点STL算法,模板编程确实有点复杂,编译起来一个error接一个error。有一点体会,STL中的迭代器全都是pass by value,也就是值传递,这一点在《Effective C++》也有说明:内置类型、迭代器、仿函数作为参数应该传值,其它类型尽量传址。

using namespace std;

// 求给定区域内的和
template <class InputIterator, class T>
T accumulate(InputIterator begin, InputIterator end, T init)
{
	while (begin != end)
	{
		init += *begin;
		begin++;
	}
	return init;
}

// 给定区域用BinOp仿函数计算结果
template <class InputIterator, class T, class BinOp>
T accumulate(InputIterator begin, InputIterator end, T init, BinOp op)
{
	while (begin != end)
	{
		init = op(init, *begin);
		begin++;
	}
	return init;
}

// 容器中后一个数减前一个数
template <class InputIterator, class OutputIterator>
OutputIterator adjacent_difference(InputIterator begin, InputIterator end, OutputIterator output)
{
	if (begin == end)
		return output;

	// 萃取InputIterator迭代器所指元素的类型
	iterator_traits<InputIterator>::value_type last = *begin;
	*output++ = *begin++;
	while (begin != end)
	{
		iterator_traits<InputIterator>::value_type current = *begin++;
		*output++ = current - last;
		last = current;
	}
	return output;	// 返回迭代器指向输出区间之后
}

// 容器中后一个数和前一个数做BinOp运算
template <class InputIterator, class OutputIterator, class BinOP>
OutputIterator adjacent_difference(InputIterator begin, InputIterator end,
	OutputIterator output, BinOP op)
{
	if (begin == end)
		return output;

	// 萃取InputIterator迭代器所指元素的类型
	iterator_traits<InputIterator>::value_type last = *begin;
	*output++ = *begin++;
	while (begin != end)
	{
		iterator_traits<InputIterator>::value_type current = *begin++;
		*output++ = op(current, last);
		last = current;
	}
	return output;	// 返回迭代器指向输出区间之后
}

// 求两个序列的内积
template <class InputIterator1, class InputIterator2, class T>
T inner_product(InputIterator1 begin1, InputIterator1 end1, InputIterator2 begin2, T init)
{
	while (begin1 != end1)
	{
		init += *begin1 * *begin2;
		++begin1;
		++begin2;
	}
	return init;
}

// 两个序列进行BinOp操作
template <class InputIterator1, class InputIterator2, class T, class BinOp>
T inner_product(InputIterator1 begin1, InputIterator1 end1, InputIterator2 begin2, T init)
{
	while (begin1 != end1)
	{
		init += *begin1 * *begin2;
		++begin1;
		++begin2;
	}
	return init;
}

// 交换两个迭代器的元素
template <class ForwardIterator1, class ForwardIterator2>
void Iter_swap(ForwardIterator1 iter1, ForwardIterator2 iter2)
{
	iterator_traits<ForwardIterator1>::value_type value = *iter1;
	*iter1 = *iter2;
	*iter2 = value;
}


// 针对前向迭代器
template <class ForwardIterator, class T>
ForwardIterator __Lower_bound(ForwardIterator first, ForwardIterator last, const T &value, forward_iterator_tag)
{
	int len = 0;
	distance(first, last, len);	// 计算区间长度,前向迭代器无法直接相减
	int half;
	ForwardIterator middle;

	while (len > 0)
	{
		half = len >> 1;
		middle = first;
		advance(middle, half);	// 一步步向前走

		if (*middle < value)	// value在右边
		{
			first = middle;
			++first;
			len = len - half - 1;
		}
		else	// value在左边
			len = half;
	}
	return first;
}

// 针对随机迭代器
template <class RandomIterator, class T>
RandomIterator __Lower_bound(RandomIterator first, RandomIterator last, const T &value, random_access_iterator_tag)
{
	int len = 0;
	len = last - first;		// 计算区间长度,随即迭代器可直接相减
	int half;
	RandomIterator middle;

	while (len > 0)
	{
		half = len >> 1;
		middle = first + half;	// 迭代器直接跳到中间

		if (*middle < value)	// value在右边
		{
			first = middle + 1;
			len = len - half - 1;
		}
		else	// value在左边
			len = half;
	}
	return first;
}

// 应用于有序区间[first,last),返回第一个等于value的迭代器
template <class ForwardIterator, class T>
ForwardIterator Lower_bound(ForwardIterator first, ForwardIterator last, const T &value)
{
	// 萃取迭代器类型,前向迭代器或随机迭代器,最后一个参数是一个临时对象
	return __Lower_bound(first, last, value, iterator_traits<ForwardIterator>::iterator_category());
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值