八、算法和容器中存在的功能相同的函数:

8.1、array:
  8.1.1、fill。

    1、在array中:void fill (const value_type& val);

    2、在algorithm中:
        template <class ForwardIterator, class T>
        void fill (ForwardIterator first, ForwardIterator last, const T& val);
  8.1.2、swap。

    1、在array中:

      void swap (array& x);

    2、在algorithm中:

      template <class T> void swap (T& a, T& b);

  8.2、vector:

    8.2.1、swap。

      1、在vector中:
        void swap (vector& x);

      2、在algorithm中:
        template <class T> void swap (T& a, T& b);

  8.3、list:

    8.3.1、swap。

      1、在list中:
        void swap (list& x);

      2、在algorithm中:
        template <class T> void swap (T& a, T& b);

    8.3.2、remove。

      1、在list中:
        void remove (const value_type& val);

      2、在algorithm中:
        template <class ForwardIterator, class T>
        ForwardIterator remove (ForwardIterator first, ForwardIterator last, const T& val);

    8.3.3、remove_if。

      1、在list中:
        template <class Predicate>
        void remove_if (Predicate pred);

      2、在algorithm中:
        template <class ForwardIterator, class UnaryPredicate>
        ForwardIterator remove_if (ForwardIterator first, ForwardIterator last,
        UnaryPredicate pred);

    8.3.4、unique

      1、在list中:
        (1)void unique();

        (2)template <class BinaryPredicate>
        void unique (BinaryPredicate binary_pred);

      2、在algorithm中:
        (1)template <class ForwardIterator>
          ForwardIterator unique (ForwardIterator first, ForwardIterator last);

        (2)template <class ForwardIterator, class BinaryPredicate>
          ForwardIterator unique (ForwardIterator first, ForwardIterator last,
                      BinaryPredicate pred);

    8.3.5、merge。

      1、在list中:
        (1)void merge (list& x);

        (2)template <class Compare>
          void merge (list& x, Compare comp);

      2、在algorithm中:
        (1)template <class InputIterator1, class InputIterator2, class OutputIterator>
          OutputIterator merge (InputIterator1 first1, InputIterator1 last1,
                      InputIterator2 first2, InputIterator2 last2,
                      OutputIterator result);

        (2)template <class InputIterator1, class InputIterator2,
          class OutputIterator, class Compare>
          OutputIterator merge (InputIterator1 first1, InputIterator1 last1,
                      InputIterator2 first2, InputIterator2 last2,
                      OutputIterator result, Compare comp);

    8.3.6、sort。

      1、在list中:
        (1)void sort();

        (2)template <class Compare>
          void sort (Compare comp);

      2、在algorithm中:
        (1)template <class RandomAccessIterator>
        void sort (RandomAccessIterator first, RandomAccessIterator last);

        (2)template <class RandomAccessIterator, class Compare>
        void sort (RandomAccessIterator first, RandomAccessIterator last, Compare comp);

    8.3.7、reverse。

      1、在list中:
        void reverse();

      2、在algorithm中:
        template <class BidirectionalIterator>
        void reverse (BidirectionalIterator first, BidirectionalIterator last);

  8.4、forward_list:

    8.4.1、swap。

      1、在forward_list中:
        void swap (forward_list& x);

      2、在algorithm中:
        template <class T> void swap (T& a, T& b);

  8.5、deque:

    8.5.1、swap。

      1、在deque中:
        void swap (deque& x);

      2、在algorithm中:
        template <class T> void swap (T& a, T& b);

  8.6、set和map中是一样的:

    8.6.1、swap。

      1、在set中:
        void swap (set& x);

      2、在algorithm中:
        template <class T> void swap (T& a, T& b);

    8.6.2、find。

      1、在set中:
        iterator find (const value_type& val) const;

      2、在algorithm中:
        template <class InputIterator, class T>
        InputIterator find (InputIterator first, InputIterator last, const T& val);

    8.6.3、count。

      1、在set中:
        size_type count (const value_type& val) const;

      2、在algorithm中:
        template <class InputIterator, class T>
        typename iterator_traits<InputIterator>::difference_type
        count (InputIterator first, InputIterator last, const T& val);

    8.6.4、lower_bound。

      1、在set中:
        iterator lower_bound (const value_type& val) const;

      2、在algorithm中:
        (1)template <class ForwardIterator, class T>
          ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last,
                          const T& val);

        (2)template <class ForwardIterator, class T, class Compare>
          ForwardIterator lower_bound (ForwardIterator first, ForwardIterator last,
          const T& val, Compare comp);

    8.6.5、upper_bound。

      1、在set中:
        iterator upper_bound (const value_type& val) const;

      2、在algorithm中:
        (1)template <class ForwardIterator, class T>
          ForwardIterator upper_bound (ForwardIterator first, ForwardIterator last,
          const T& val);

        (2)template <class ForwardIterator, class T, class Compare>
          ForwardIterator upper_bound (ForwardIterator first, ForwardIterator last,
          const T& val, Compare comp);

    8.6.6、equal_range。

      1、在set中:
        pair<iterator,iterator> 
        equal_range (const value_type& val) const;

      2、在algorithm中:
        (1)template <class ForwardIterator, class T>
          pair<ForwardIterator,ForwardIterator>
          equal_range (ForwardIterator first, ForwardIterator last, const T& val);

        (2)template <class ForwardIterator, class T, class Compare>
          pair<ForwardIterator,ForwardIterator>
          equal_range (ForwardIterator first, ForwardIterator last, const T& val,
                  Compare comp);

stl_container容器和std_algorithm算法相同的函数的更多相关文章

  1. C++ Primer 学习笔记_46_STL实践与分析(20)--容器特有的算法

    STL实践与分析 --容器特有的算法 与其它顺序容器所支持的操作相比,标准库为list容器定义了更精细的操作集合,使它不必仅仅依赖于泛型操作.当中非常大的一个原因就是list容器不是依照内存中的顺序进 ...

  2. Java实现 蓝桥杯VIP 算法训练 sign函数

    试题 算法训练 sign函数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 给定实数x,输出sign(x)的值. sign(x)是符号函数,如果x>0,则返回1:如果x=0, ...

  3. Java实现蓝桥杯VIP算法训练 二元函数

    试题 算法训练 二元函数 资源限制 时间限制:1.0s 内存限制:256.0MB 问题描述 令二元函数f(x,y)=ax+by,a和b为整数,求一个表达式S的值. 只有满足以下要求的表达式才是合法的: ...

  4. C++的那些事:容器和泛型算法

    一.顺序容器 1,标准库定义了3种类型的顺序容器:vector.list和deque.它们的差别主要在于访问元素的方式,以及添加或删除元素相关操作运算代价.标准库还提供了三种容器适配器:stack.q ...

  5. C++ STL算法系列6---copy函数

    现在我们来看看变易算法.所谓变易算法(Mutating algorithms)就是一组能够修改容器元素数据的模板函数,可进行序列数据的复制,变换等. 我们现在来看看第一个变易算法:元素复制算法copy ...

  6. STL容器及泛型算法

    一.顺序容器 1.容器的选择 (1) 随机访问,选vector ,deque (2) 在中间插入或者删除元素,选list (3) 在头尾插入或删除元素 , 选deque 2.list的成员函数 (1) ...

  7. C++(五十一) — 容器中常见算法(查找、排序、拷贝替换)

    1.find(); find()算法的作用是在指定的一段序列中查找某个数,包含三个参数,前两个参数是表示元素范围的迭代器,第三个参数是要查找的值. 例:fing(vec.begin(), vec.en ...

  8. KMP算法中next函数的理解

    首先要感谢http://blog.csdn.net/v_july_v/article/details/7041827以及http://blog.chinaunix.net/uid-27164517-i ...

  9. C++ STL算法系列1---count函数

    一.count函数 algorithm头文件定义了一个count的函数,其功能类似于find.这个函数使用一对迭代器和一个值做参数,返回这个值出现次数的统计结果. 编写程序读取一系列int型数据,并将 ...

随机推荐

  1. Windows下GIT安装与使用(上传远程端)

    Windows下GIT安装与使用(上传远程服务器) 1.  登陆http://msysgit.github.io/并下载Git 2.  打开下载的exe文件,一路默认(路径可以去修改).有可能电脑需要 ...

  2. java中String s = new String("abc")创建了几个对象?

    答案是两个,现在我们具体的说一下: String s = new String("abc");一.我们要明白两个概念,引用变量和对象,对象一般通过new在堆中创建,s只是一个引用变 ...

  3. mybatis 使用@Select 注解,因为字符编码不一致导致mybatis 报错

    使用 mybatis 的@Select 注解, @Select({ "<script>select " + ALL_COLUMNS + " from &quo ...

  4. JavaWeb之JSTL标签

    JSP中有了EL可以很方便的引用对象和属性,但是也有一些不足的地方,比如不能遍历对象列表这些,再加上JSTL(Java Standard Tag Library)的话那就完美了.JSTL主要包括cor ...

  5. Windows7 java-jdk1.7安装及设置变量过程

    jdk安装的次数较少,容易忘记,这里专门记录一下. 1:jdk1.7网上到处都是可以随便下载一个.然后进行安装,不过在安装过程中把安装路径单独记忆一下,在配置变量的时候会用到. 2:安装完JDK后配置 ...

  6. MFC画笔作用域的问题

    今天发现了程序中的一个BUG.功能是在鼠标经过图形时,对图形进行加粗重绘.默认使用白色画刷.为防止白色背景下看不清,在白色背景下改用黑色画刷.代码如下 CPen* pOldPen;if (pDC-&g ...

  7. Linux之wc命令

    wc - print newline, word, and byte counts for each file 为文件打印行数,字符数,字节数 参数: -l  仅列出行 -w  仅列出多少字(英文单字 ...

  8. 一种类似Retrofit声明接口即可实现调用的WebApi客户端框架

    为.Net出力 java有okhttp,还在okhttp这上搞了一个retrofit,.net有HttpClient,但目前我没有发现有类似的retrofit框架.最近在搞mqtt的webApi封装, ...

  9. CDN内容分发网络

    CDN的全称是Content Delivery Network,即内容分发网络,其设计思想是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快.更稳定. CDN系统是在网络 ...

  10. CF766 E. Mahmoud and a xor trip [预处理][树形dp]

    题解: 二营长!你他娘的意大利炮呢? dp[i][j][0]: 从i,跋涉到以i为根的子树的每一个节点,在第j个数位上一共产生了多少个0. dp[i][j][1]: 从i,跋涉到以i为根的子树的每一个 ...