STL算法---remove系列

本文详细介绍了C++ STL中的移除算法,包括remove、remove_copy、remove_if及其对应_copy版本的功能、作用及代码实现。这些算法用于在不改变容器大小的前提下移除特定元素。
remove
●接受的是前向迭代器,返回的也是前向迭代器。
●移除但不删除。这个操作意思是原来那个位置的元素值改变了,但是该存储单元还是存在的。容器的大小不会发生变化。
●可能会有残余数据。可以利用erase()成员函数删除残余数据。
●代码实现:
template <typename ForwardIterator,typename 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);
}
通过调用remove_copy函数来实现数据的移动


remove_copy
●接收的是输入迭代器和输出迭代器,返回的也是输出迭代器
●原来的容器的数据和大小没有发生任何改变,把原来容器的数据复制到新容器内。
●新容器可以和原容器重叠,但是如果对新容器实际给值时,超越了原容器的大小时,会产生无法预期的结果。
●返回值指出被复制的最后一个元素的下一个位置。
●代码的实现:
template <typename InputIterator,typename OutputIterator,typename T>

OutputIterator remove_copy(InputIterator first,InputIterator last,OutputIterator result,const T& value)
{
    for(;first!=last;++first)
    {
        if(*first!=value)
        {
            *result=*first;
            ++result;
        }
    }
    return result;
}



remove_if
●移除给定范围内所有被函数对象判定为真的元素。
●并不是真正移除那些元素,只是改变那些符合条件的元素的值而已。容器的大小没有发生改变。
●可能会有残留的数据存在。可以使用erase成员函数删除那些残留元素。
●返回值指出整理后的最后元素的下一个位置。
●代码实现:
template <typename ForwardIterator,typename Predicate>
ForwardIterator remove_if(ForwardIterator first,ForwardIterator last,Predicate pred)
{
    first=find_if(first,last,pred);
    ForwardIterator next=first;
    return first==last?first:remove_copy_if(++next,last,first,pred);
}



remove_copy_if
●接受输入、输出迭代器和函数对象,返回输出迭代器对象
●将输入范围内被函数对象判定为真的那些函数复制到新容器中,原始容器的数据和大小没有发生改变。
●新容器可以和原容器重叠,但是如果对新容器实际给值时,超越了原容器的大小时,会产生无法预期的结果。
●返回值指出被复制的最后一个元素的下一个位置。
●代码实现:
template <typename InputIterator,typename OutputIterator,typename Predicate>
OutputIterator remove_copy_if(InputIterator first,InputIterator last,OutputIterator result,Predicate pred)
{
    for(;first!=last;++first)
    {
        if(!pred(*first))
        {
            *result=*first;
            ++result;
        }
    }
    return result;
}




带开环升压转换器和逆变器的太阳能光伏系统 太阳能光伏系统驱动开环升压转换器和SPWM逆变器提供波形稳定、设计简单的交流电的模型 Simulink模型展示了一个完整的基于太阳能光伏的直流到交流电力转换系统,该系统由简单、透明、易于理解的模块构建而成。该系统从配置为提供真实直流输出电压的光伏阵列开始,然后由开环DC-DC升压转换器进行处理。升压转换器将光伏电压提高到适合为单相全桥逆变器供电的稳定直流链路电平。 逆变器使用正弦PWM(SPWM)开关来产生干净的交流输出波形,使该模型成为研究直流-交流转换基本操作的理想选择。该设计避免了闭环和MPPT的复杂性,使用户能够专注于光伏接口、升压转换和逆变器开关的核心概念。 此模型包含的主要功能: •太阳能光伏阵列在标准条件下产生~200V电压 •具有固定占空比操作的开环升压转换器 •直流链路电容器,用于平滑和稳定转换器输出 •单相全桥SPWM逆变器 •交流负载,用于观察实际输出行为 •显示光伏电压、升压输出、直流链路电压、逆变器交流波形和负载电流的组织良好的范围 •完全可编辑的结构,适合分析、实验和扩展 该模型旨在为太阳能直流-交流转换提供一个干净高效的仿真框架。布局简单明了,允许用户快速了解信号流,检查各个阶段,并根据需要修改参数。 系统架构有意保持模块化,因此可以轻松扩展,例如通过添加MPPT、动态负载行为、闭环升压控制或并网逆变器概念。该模型为进一步开发或整合到更大的可再生能源模拟中奠定了坚实的基础。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值