MergeSort-vector

孤街浪徒 提交于 2019-12-02 03:30:28

include

include

using std::cout;
using std::endl;
using std::vector;

void Merge(vector &v, int L, int M, int R)
{
//拆分成两个vector:left和right
//vector(begin,end):复制[begin,end)区间内另一个数组的元素到vector中
vector left(v.begin() + L, v.begin() + M + 1);
vector right(v.begin() + M + 1, v.begin() + R + 1);
//两个迭代器
auto left_it = left.cbegin();
auto right_it = right.cbegin();
int i = L;
//合并vector
while (left_it != left.cend() && right_it != right.cend())
{
if (left_it < right_it)
v[i++] = (left_it++);
else
v[i++] =
(right_it++);
}
while (left_it != left.cend())
v[i++] = (left_it++);
while (right_it != right.cend())
v[i++] =
(right_it++);
}
//Ascending
void MergeSort(vector &v, int L, int R)
{
if (L == R)
return;
else
{
MergeSort(v, L, (L + R) / 2);
MergeSort(v, (L + R) / 2 + 1, R);
Merge(v, L, (L + R) / 2, R);
}
}
int main(void)
{
vector v = {4, 3, 2, 1, 0};
MergeSort(v, 0, 4);
for (int i = 0; i < 5; i++)
cout << v[i] << endl;
return 0;
}

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!