问题: 如何使用 C 标准模板库的 std::sort()按升序排列数组?
<code class="cpp">int v[2000];</code>
答案:在 C 11 中,您可以使用两个方便的函数:
<code class="cpp">std::sort(std::begin(v), std::end(v));</code>
附加问题: C 有办法确定数组的开始和结束位置吗?
答案: 是的,在 C 11 中,std::begin 和 std::end 是数组重载。
<code class="cpp">std::sort(std::begin(v), std::end(v));</code>
如果您使用的是早期版本的 C ,您可以创建自己的 begin 和 end 版本:
非常量:
<code class="cpp">template<class Cont> typename Cont::iterator begin(Cont& c){ return c.begin(); } template<class Cont> typename Cont::iterator end(Cont& c){ return c.end(); }</code>
常量:
<code class="cpp">template<class Cont> typename Cont::const_iterator begin(Cont const& c){ return c.begin(); } template<class Cont> typename Cont::const_iterator end(Cont const& c){ return c.end(); }</code>
C 样式数组的重载:
<code class="cpp">template<class T, std::size_t N> T* begin(T (&arr)[N]){ return &arr[0]; } template<class T, std::size_t N> T* end(T (&arr)[N]){ return arr + N; }</code>
以上是如何在 C 中使用 std::sort 对数组进行排序?的详细内容。更多信息请关注PHP中文网其他相关文章!