1 Star 0 Fork 0

snow-boy/visualgo-sort

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
该仓库未声明开源许可证文件(LICENSE),使用请关注具体项目描述及其代码上游依赖。
克隆/下载
mergesort.cpp 1.39 KB
一键复制 编辑 原始数据 按行查看 历史
1589221904@qq.com 提交于 2016-09-04 20:43 . 可视化排序
#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();
}
}
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
C++
1
https://gitee.com/softlord/visualgo-sort.git
git@gitee.com:softlord/visualgo-sort.git
softlord
visualgo-sort
visualgo-sort
master

搜索帮助

0d507c66 1850385 C8b1a773 1850385