首页 >后端开发 >C++ >如何在 C 中使用 std::sort 对数组进行排序?

如何在 C 中使用 std::sort 对数组进行排序?

Patricia Arquette
Patricia Arquette原创
2024-10-23 21:30:02975浏览

How to Sort Arrays Using std::sort in C  ?

在 C 中使用 std::sort 对数组进行排序

对声明为 int v[2000] 的数组进行排序;使用 std::sort 函数,只需提供数组的开始和结束迭代器。在 C 0x/11 中,这可以通过 std::begin 和 std::end 函数来实现,这些函数为数组重载:

<code class="cpp">#include <algorithm>

int main(){
  int v[2000];
  std::sort(std::begin(v), std::end(v));
}</code>

如果您无权访问 C 0x,您可以自己实现这些功能:

<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();
}

// overloads for C style arrays
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中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn