命名空间
变体
操作

std::ranges::is_sorted

来自 cppreference.com
< cpp‎ | algorithm‎ | ranges
 
 
算法库
约束算法和范围上的算法 (C++20)
约束算法,例如 ranges::copy, ranges::sort, ...
执行策略 (C++17)
排序和相关操作
分区操作
排序操作
二分搜索操作
(在已分区范围内)
集合操作(在已排序范围内)
合并操作(在已排序范围内)
堆操作
最小/最大操作
(C++11)
(C++17)
字典序比较操作
排列操作
C 库
数值操作
未初始化内存操作
 
约束算法
此菜单中的所有名称都属于命名空间 std::ranges
非修改序列操作
修改序列操作
分区操作
排序操作
is_sorted
       
二分搜索操作(在已排序范围内)
       
       
集合操作(在已排序范围内)
堆操作
最小/最大操作
       
       
排列操作
折叠操作
数值操作
(C++23)            
未初始化存储操作
返回类型
 
定义在头文件 <algorithm>
调用签名
template< std::forward_iterator I, std::sentinel_for<I> S,

          class Proj = std::identity,
          std::indirect_strict_weak_order<std::projected<I, Proj>>
              Comp = ranges::less >
constexpr bool

    is_sorted( I first, S last, Comp comp = {}, Proj proj = {} );
(1) (自 C++20 起)
template< ranges::forward_range R, class Proj = std::identity,

          std::indirect_strict_weak_order<
              std::projected<ranges::iterator_t<R>, Proj>>
                  Comp = ranges::less >
constexpr bool

    is_sorted( R&& r, Comp comp = {}, Proj proj = {} );
(2) (自 C++20 起)

检查范围 [firstlast) 中的元素是否按非降序排序。

相对于比较器 comp,一个序列被排序,如果对于任何指向序列的迭代器 it 以及任何非负整数 n(使得 it + n 是指向序列元素的有效迭代器),std::invoke(comp, std::invoke(proj, *(it + n)), std::invoke(proj, *it)) 评估为 false.

1) 元素使用给定的二元比较函数 comp 进行比较。
2)(1) 相同,但使用 r 作为源范围,就好像使用 ranges::begin(r) 作为 firstranges::end(r) 作为 last.

本页描述的类似函数的实体是 *niebloids*,即

在实践中,它们可能以函数对象的形式实现,或者使用特殊的编译器扩展。

内容

[edit] 参数

first, last - 迭代器-哨兵,定义要检查是否排序的范围
r - 要检查是否排序的范围
comp - 要应用于投影元素的比较函数
proj - 要应用于元素的投影

[edit] 返回值

如果范围中的元素根据 comp 排序,则为 true

[edit] 复杂度

firstlast 之间的距离上是线性的。

[edit] 可能的实现

struct is_sorted_fn
{
    template<std::forward_iterator I, std::sentinel_for<I> S,
             class Proj = std::identity,
             std::indirect_strict_weak_order<std::projected<I, Proj>>
                 Comp = ranges::less>
    constexpr bool operator()(I first, S last, Comp comp = {}, Proj proj = {}) const
    {
        return ranges::is_sorted_until(first, last, comp, proj) == last;
    }
 
    template<ranges::forward_range R, class Proj = std::identity,
             std::indirect_strict_weak_order<
                 std::projected<ranges::iterator_t<R>, Proj>>
                     Comp = ranges::less>
    constexpr bool operator()(R&& r, Comp comp = {}, Proj proj = {}) const
    {
        return (*this)(ranges::begin(r), ranges::end(r), std::ref(comp), std::ref(proj));
    }
};
 
inline constexpr is_sorted_fn is_sorted;

[edit] 备注

ranges::is_sorted 对于空范围和长度为 1 的范围返回 true

[edit] 示例

#include <algorithm>
#include <array>
#include <functional>
#include <iostream>
#include <iterator>
 
int main()
{
    namespace ranges = std::ranges;
 
    std::array digits {3, 1, 4, 1, 5};
 
    ranges::copy(digits, std::ostream_iterator<int>(std::cout, " "));
    ranges::is_sorted(digits)
        ? std::cout << ": sorted\n"
        : std::cout << ": not sorted\n";
 
    ranges::sort(digits);
 
    ranges::copy(digits, std::ostream_iterator<int>(std::cout, " "));
    ranges::is_sorted(ranges::begin(digits), ranges::end(digits))
        ? std::cout << ": sorted\n"
        : std::cout << ": not sorted\n";
 
    ranges::reverse(digits);
 
    ranges::copy(digits, std::ostream_iterator<int>(std::cout, " "));
    ranges::is_sorted(digits, ranges::greater {})
        ? std::cout << ": sorted (with 'greater')\n"
        : std::cout << ": not sorted\n";
}

输出

3 1 4 1 5 : not sorted
1 1 3 4 5 : sorted
5 4 3 1 1 : sorted (with 'greater')

[edit] 参见

查找最大的排序子范围
(niebloid)[edit]
(C++11)
检查范围是否按升序排序
(函数模板) [edit]