`
kmplayer
  • 浏览: 512174 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

通用算法笔记4

阅读更多
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");
}
分享到:
评论

相关推荐

    算法笔记.rar

    算法笔记:Visual Basic(简称VB)是Microsoft公司开发的一种通用的基于对象的程序设计语言,为结构化的、模块化的、面向对象的、包含协助开发环境的事件驱动为机制的可视化程序设计语言。是一种可用于微软自家产品...

    算法设计与分析笔记

    然而,从标题“算法设计与分析笔记”以及描述“算法笔记”来看,我们可以尝试围绕算法设计与分析这一主题来构建相关知识点。接下来,将详细介绍与算法设计和分析相关的知识点,包括但不限于算法的基本概念、分类、...

    随机算法笔记(英文)

    这部分介绍了如何定义概率空间,并给出了通用的概率空间的概念。 **2.2 布尔事件组合** 布尔事件组合是指通过对基本事件进行逻辑运算(如并、交、补)来构建新的事件。这部分解释了如何通过布尔运算来分析和处理...

    安卓逆向学习笔记之逆向OLLVM算法的通用方法.docx

    安卓逆向学习笔记之逆向OLLVM算法的通用方法.docx

    space-saving算法论文

    这种方法不仅能够保持较低的空间消耗,而且在处理具有通用数据分布的数据流时,其性能表现非常稳定。 在实际应用中,Space-Saving算法不仅能够有效地识别数据流中的频繁元素,还能对Top-K查询提供支持,即能够返回...

    算法导论读书笔记

    第八章 **图算法**:图是表示对象间关系的通用数据结构。这一章讨论了图的表示方法、遍历(深度优先搜索和广度优先搜索)、最短路径算法(Dijkstra、Floyd-Warshall)、最小生成树(Prim、Kruskal)等。这些算法在...

    安卓逆向学习笔记之逆向OLLVM的非通用方法-使用unicorn调用算法.docx

    安卓逆向学习笔记之逆向OLLVM的非通用方法-使用unicorn调用算法.docx

    数据结构与算法 学习笔记

    这份"数据结构与算法学习笔记"涵盖了这一领域的核心概念,特别强调了C++模板类的实现,这使得理论知识可以直接应用于实际项目。 首先,我们要了解数据结构。数据结构是组织、存储和管理数据的方式,包括数组、链表...

    labuladong的算法小抄完整版.pdf

    - 提供了一套解决动态规划问题的通用框架,帮助读者快速入门和深化理解。 #### 动态规划答疑篇 - 针对动态规划学习过程中的常见问题进行解答。 #### 回溯算法解题套路框架 - 回溯算法是解决组合问题的一类算法,本...

    AlgorithmNote:《算法笔记》

    《算法笔记》是一本深入探讨计算机算法的书籍,主要针对C++编程语言进行阐述。算法在计算机科学中占据着核心地位,是解决复杂问题的有效工具。C++是一种强大的、通用的编程语言,以其高效性和灵活性著称,尤其适合...

    PAT算法:《算法笔记》实验代码

    《算法笔记》是一本深入探讨算法的书籍,其实验代码主要使用C++语言编写,旨在帮助读者通过实践来理解和掌握各种算法。PAT(Programming Ability Test)算法是这本书中涵盖的一部分内容,通常用于考察编程者的基本...

    SONY笔记本CMOS BIOS通用算号程序

    【标题】"SONY笔记本CMOS BIOS通用算号程序"涉及到的是计算机硬件系统中的一个重要组件——CMOS(Complementary Metal-Oxide-Semiconductor,互补金属氧化物半导体)以及与其相关的BIOS(Basic Input/Output System...

    C++ Primer学习笔记——$11 泛型算法

    4. 写入目标序列的算法: 这些算法需要一个额外的迭代器参数作为写入的目标,例如: - `fill_n`算法:将指定数量的元素填充为给定值,如果目标范围内元素不足,则结果未定义。 使用泛型算法的优点在于代码的简洁...

    凌阳16位工业级通用单片机SPMC75系列应用笔记A.rar

    这份"凌阳16位工业级通用单片机SPMC75系列应用笔记A"包含了关于该系列单片机的重要技术细节和实用案例,对于理解和应用SPMC75系列非常有帮助。 首先,SPMC75系列单片机的核心是16位CPU,具备高速运算能力,能够处理...

    外星人笔记本音乐播放器(三大主题)型号通用

    - **音频增强技术**:可能内置了先进的音频处理算法,如杜比音效或者环绕声技术,让音乐听起来更加立体和丰富。 - **音乐库管理**:支持导入和整理个人音乐库,方便用户快速找到想听的歌曲。 - **播放控制集成**:与...

    LeetCode算法数据结构专训笔记,

    【LeetCode算法数据结构专训笔记】 LeetCode是一个广受欢迎的在线平台,它提供了大量的算法和数据结构问题供用户练习和提升。通过刷LeetCode的题目,你可以显著提高自己的算法能力,尤其是对于链表、树等数据结构的...

    cellpose:一种用于细胞分割的通用算法

    细胞和细胞核分割的通用算法。 这段代码是由 Carsen Stringer 和 Marius Pachitariu 编写的。 要了解 Cellpose,请阅读或观看演讲。 如需支持,请打开一个问题。 如果您想为自己和其他人改进 Cellpose,请考虑...

    回溯算法的刷题笔记,回溯专训

    回溯算法的通用框架通常如下所示: ```cpp vector&lt;&gt; ans; // 存储所有可能的结果数组 void backtracking(路径, 选择列表) { if (满足回溯终止条件) { ans.push_back(当前的结果); return; } for (选择: 本层...

    笔记本电池修复软件 笔记本电池修复软件

    这类软件的主要功能是通过一系列的专业算法和技术手段,帮助用户解决电池性能下降、续航时间缩短等问题。在笔记本电脑使用过程中,电池性能随着时间推移逐渐衰退是普遍现象,这可能由于过度充电、过度放电或者长时间...

    回溯算法笔记,并解决N皇后问题(Python实现)

    用回溯法解题的一般步骤:4. 实例:解决N皇后问题 1.概念 回溯算法实际上一个类似枚举的搜索尝试过程,主要是在搜索尝试过程中寻找问题的解,当发现已不满足求解条件时,就“回溯”返回,尝试别的路径。 回溯法是一...

Global site tag (gtag.js) - Google Analytics