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