日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

排序算法模板

發布時間:2025/3/17 编程问答 29 豆豆
生活随笔 收集整理的這篇文章主要介紹了 排序算法模板 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

原文地址:https://www.acwing.com/blog/content/277/

快速排序算法模板 —— 模板題 AcWing 785. 快速排序
void quick_sort(int q[], int l, int r)
{
? ? if (l >= r) return;

? ? int i = l - 1, j = r + 1, x = q[l + r >> 1];
? ? while (i < j)
? ? {
? ? ? ? do i ++ ; while (q[i] < x);
? ? ? ? do j -- ; while (q[j] > x);
? ? ? ? if (i < j) swap(q[i], q[j]);
? ? }
? ? quick_sort(q, l, j), quick_sort(q, j + 1, r);
}
歸并排序算法模板 —— 模板題 AcWing 787. 歸并排序
void merge_sort(int q[], int l, int r)
{
? ? if (l >= r) return;

? ? int mid = l + r >> 1;
? ? merge_sort(q, l, mid);
? ? merge_sort(q, mid + 1, r);

? ? int k = 0, i = l, j = mid + 1;
? ? while (i <= mid && j <= r)
? ? ? ? if (q[i] <= q[j]) tmp[k ++ ] = q[i ++ ];
? ? ? ? else tmp[k ++ ] = q[j ++ ];

? ? while (i <= mid) tmp[k ++ ] = q[i ++ ];
? ? while (j <= r) tmp[k ++ ] = q[j ++ ];

? ? for (i = l, j = 0; i <= r; i ++, j ++ ) q[i] = tmp[j];
}

作者:yxc
鏈接:https://www.acwing.com/blog/content/277/
來源:AcWing
著作權歸作者所有。商業轉載請聯系作者獲得授權,非商業轉載請注明出處。

總結

以上是生活随笔為你收集整理的排序算法模板的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。