1,generate_n(序列起点,个数,函数发生器)
2,transform(begin,end,保存起点,unaryfunc)
transform(begin1,end1,begin2,保存起点,binaryfunc)
实例代码:
#include <algorithm>
#include <iostream>
#include <iterator>
#include <set>
#include <vector>
using namespace std;
template<typename ite> //打印任意迭代器类型限定的序列
void myPrint(ite first, ite last, const char* ss="", const char* ee=" ", ostream& os=cout)
{
if(ss!=0&&*ss!='\0')
os<<ss<<": "<<ee;
typedef typename iterator_traits<ite>::value_type T;//这样就可以处理任意迭代器类型限定的序列
copy(first,last,ostream_iterator<T>(os,ee));
os<<endl;
}
class LimitRand //生成一个出现一次的随机数
{
set<int> used;
int limit;
public:
LimitRand(int lim):limit(lim){}
int operator()()
{
while(1)
{
int i=(int)(rand())%limit;
if(used.find(i)==used.end())
{
used.insert(i);
return i;
}
}
}
};
int main()
{
//ostream_iterator<int> out(cout, "\n") ;
int a[]={1,3,5,7,9};
int size=sizeof(a)/sizeof(a[0]);
myPrint(a,a+size,"a");
const int SZ=10;
vector<int> x(SZ),y(SZ),r(SZ);
LimitRand lr(100);
srand(time(0));
//结合使用
generate_n(x.begin(),SZ,lr);
myPrint(x.begin(),x.end(),"x");
generate_n(y.begin(),SZ,lr);
myPrint(y.begin(),y.end(),"y");
//相加,并将结果保存到r
transform(x.begin(),x.end(),y.begin(),r.begin(),plus<int>());
myPrint(r.begin(),r.end(),"x+y");
//判断是否小于,并将结果保存到r
transform(x.begin(),x.end(),y.begin(),r.begin(),less<int>());
myPrint(r.begin(),r.end(),"less");
//r逻辑取反
transform(r.begin(),r.end(),r.begin(),logical_not<int>());
myPrint(r.begin(),r.end(),"logical_not");
}
分享到:
相关推荐
算法笔记:Visual Basic(简称VB)是Microsoft公司开发的一种通用的基于对象的程序设计语言,为结构化的、模块化的、面向对象的、包含协助开发环境的事件驱动为机制的可视化程序设计语言。是一种可用于微软自家产品...
然而,从标题“算法设计与分析笔记”以及描述“算法笔记”来看,我们可以尝试围绕算法设计与分析这一主题来构建相关知识点。接下来,将详细介绍与算法设计和分析相关的知识点,包括但不限于算法的基本概念、分类、...
这部分介绍了如何定义概率空间,并给出了通用的概率空间的概念。 **2.2 布尔事件组合** 布尔事件组合是指通过对基本事件进行逻辑运算(如并、交、补)来构建新的事件。这部分解释了如何通过布尔运算来分析和处理...
安卓逆向学习笔记之逆向OLLVM算法的通用方法.docx
这种方法不仅能够保持较低的空间消耗,而且在处理具有通用数据分布的数据流时,其性能表现非常稳定。 在实际应用中,Space-Saving算法不仅能够有效地识别数据流中的频繁元素,还能对Top-K查询提供支持,即能够返回...
第八章 **图算法**:图是表示对象间关系的通用数据结构。这一章讨论了图的表示方法、遍历(深度优先搜索和广度优先搜索)、最短路径算法(Dijkstra、Floyd-Warshall)、最小生成树(Prim、Kruskal)等。这些算法在...
安卓逆向学习笔记之逆向OLLVM的非通用方法-使用unicorn调用算法.docx
这份"数据结构与算法学习笔记"涵盖了这一领域的核心概念,特别强调了C++模板类的实现,这使得理论知识可以直接应用于实际项目。 首先,我们要了解数据结构。数据结构是组织、存储和管理数据的方式,包括数组、链表...
- 提供了一套解决动态规划问题的通用框架,帮助读者快速入门和深化理解。 #### 动态规划答疑篇 - 针对动态规划学习过程中的常见问题进行解答。 #### 回溯算法解题套路框架 - 回溯算法是解决组合问题的一类算法,本...
《算法笔记》是一本深入探讨计算机算法的书籍,主要针对C++编程语言进行阐述。算法在计算机科学中占据着核心地位,是解决复杂问题的有效工具。C++是一种强大的、通用的编程语言,以其高效性和灵活性著称,尤其适合...
《算法笔记》是一本深入探讨算法的书籍,其实验代码主要使用C++语言编写,旨在帮助读者通过实践来理解和掌握各种算法。PAT(Programming Ability Test)算法是这本书中涵盖的一部分内容,通常用于考察编程者的基本...
【标题】"SONY笔记本CMOS BIOS通用算号程序"涉及到的是计算机硬件系统中的一个重要组件——CMOS(Complementary Metal-Oxide-Semiconductor,互补金属氧化物半导体)以及与其相关的BIOS(Basic Input/Output System...
4. 写入目标序列的算法: 这些算法需要一个额外的迭代器参数作为写入的目标,例如: - `fill_n`算法:将指定数量的元素填充为给定值,如果目标范围内元素不足,则结果未定义。 使用泛型算法的优点在于代码的简洁...
这份"凌阳16位工业级通用单片机SPMC75系列应用笔记A"包含了关于该系列单片机的重要技术细节和实用案例,对于理解和应用SPMC75系列非常有帮助。 首先,SPMC75系列单片机的核心是16位CPU,具备高速运算能力,能够处理...
- **音频增强技术**:可能内置了先进的音频处理算法,如杜比音效或者环绕声技术,让音乐听起来更加立体和丰富。 - **音乐库管理**:支持导入和整理个人音乐库,方便用户快速找到想听的歌曲。 - **播放控制集成**:与...
【LeetCode算法数据结构专训笔记】 LeetCode是一个广受欢迎的在线平台,它提供了大量的算法和数据结构问题供用户练习和提升。通过刷LeetCode的题目,你可以显著提高自己的算法能力,尤其是对于链表、树等数据结构的...
细胞和细胞核分割的通用算法。 这段代码是由 Carsen Stringer 和 Marius Pachitariu 编写的。 要了解 Cellpose,请阅读或观看演讲。 如需支持,请打开一个问题。 如果您想为自己和其他人改进 Cellpose,请考虑...
回溯算法的通用框架通常如下所示: ```cpp vector<> ans; // 存储所有可能的结果数组 void backtracking(路径, 选择列表) { if (满足回溯终止条件) { ans.push_back(当前的结果); return; } for (选择: 本层...
这类软件的主要功能是通过一系列的专业算法和技术手段,帮助用户解决电池性能下降、续航时间缩短等问题。在笔记本电脑使用过程中,电池性能随着时间推移逐渐衰退是普遍现象,这可能由于过度充电、过度放电或者长时间...
用回溯法解题的一般步骤:4. 实例:解决N皇后问题 1.概念 回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。 回溯法是一...