代码拉取完成,页面将自动刷新
#include "quicksort.h"
#include <QThread>
QuickSort::QuickSort(QObject *parent):
IAlgo(parent)
{
}
QString QuickSort::name()
{
return "Quick Sort";
}
void QuickSort::run()
{
QVector<int> &data = _data->GetData();
_run_time = 0;
sort(data, 0, data.size() - 1);
}
// closed interval
void QuickSort::sort(QVector<int> &data, int left, int right)
{
if(left >= right){
return;
}
int first_pos = left;
int last_pos = right;
int key = data[left];
while(first_pos < last_pos){
while(first_pos < last_pos && data[last_pos] > key){
--last_pos;
++_run_time;
}
data[first_pos] = data[last_pos];
_data->Refresh();
while(first_pos < last_pos && data[first_pos] <= key){
++first_pos;
++_run_time;
}
data[last_pos] = data[first_pos];
_data->Refresh();
}
data[first_pos] = key;
_data->Refresh();
sort(data, left, first_pos - 1);
sort(data, first_pos + 1, right);
if(_interval > 0){
QThread::msleep(_interval);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。