在C 中使用std::sort 對數組進行排序
本文介紹了標準模板庫(STL) 函數std 的使用: :sort 將宣告為int v[2000] 的陣列進行排序。此外,它還探討了 C 是否提供了一種原生方法來取得陣列的開始和結束索引。
std::sort 和基於範圍的排序
使用std::sort,您可以利用 C 11 中引入的基於範圍的 for 迴圈。這種方法簡化了排序過程:
<code class="cpp">int v[2000]; std::sort(std::begin(v), std::end(v));</code>
其中 std::begin 和 std::end 是傳回的實用函數分別指向容器或陣列的第一個和最後一個元素的迭代器。
自訂開始和結束函數
對於早期的C 版本,您可以建立自己的開始和結束函數:
<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(); } 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 函數取得陣列界限嗎?的詳細內容。更多資訊請關注PHP中文網其他相關文章!