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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

多线程生成随机数组+多线程快速排序(C++实现)

發(fā)布時間:2025/4/16 c/c++ 38 豆豆
生活随笔 收集整理的這篇文章主要介紹了 多线程生成随机数组+多线程快速排序(C++实现) 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

描述

這里對于對于每個快排遞歸過程都進行考量,如果對應(yīng)的區(qū)域規(guī)模達到一定數(shù)值(也就是下面的代碼中的MINLEN),設(shè)置這個,主要是考慮到對應(yīng)的電腦的cpu的核數(shù)。如果申請的線程數(shù)大于對應(yīng)的CPU核數(shù)的時候,就是沒有意義的,反而有可能導(dǎo)致效率會降低。

代碼

#include <iostream> using namespace std; #include <Windows.h> #include <ctime> #include <random> #include <thread> #include <vector>int *a; int N; const int MINLEN = 120000;void random_test(int begin, int end) {srand((unsigned)time(NULL) + begin);for (int i = begin; i < end; ++i) {a[i] = rand() % N;} }void sort(int s, int e) {if (s >= e)return;int i = s, j = e, k = a[s];while (i < j) {while (i < j && a[j] >= k)--j;if (i < j) {a[i] = a[j];}while (i < j && a[i] <= k)++i;if (i < j) {a[j] = a[i];}}a[i] = k;vector<thread> vt;if (i - s >= MINLEN)vt.push_back(thread(sort, s, i - 1));else sort(s, i - 1);if (e - i >= MINLEN)vt.push_back(thread(sort, i + 1, e));else sort(i + 1, e);for (int i = 0; i < vt.size(); ++i) vt[i].join(); }int main() {vector<thread> vt;N = 1000000;a = new int[N];int T = 5;int st, et;st = clock();for (int i = 0; i < T; ++i)vt.push_back(thread(random_test, i * N / T, (i + 1) * N / T));for (int i = 0; i < T; ++i)vt[i].join();et = clock();double ct = (et - st) / 1000.0;st = clock();sort(0, N-1);et = clock();/*for (int i = 0; i < N; ++i) cout << a[i] << " ";cout << endl;*/cout << "Sorting uses " << (et - st) / 1000.0 << " second(s)" << endl;cout << "Creating the random array uses " << ct << " second(s)" << endl;system("pause"); }

總結(jié)

以上是生活随笔為你收集整理的多线程生成随机数组+多线程快速排序(C++实现)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。