归并排序

归并排序代码

MergeSort.hpp

//
// Created by Administrator on 2021/7/28.
//

#ifndef C__TEST01_MERGESORT_HPP
#define C__TEST01_MERGESORT_HPP
#include <vector>
#include <iostream>
using namespace std;

class MergeSort {
public:
    MergeSort(vector<int> An);
    void process(vector<int> &A, int L, int R);
    void merge(vector<int> &A, int L, int mid, int R);
private:
    vector<int> A;
};

MergeSort::MergeSort(vector<int> An) :
A(An){
    A.resize(An.size());
}

void MergeSort::process(vector<int> &A, int L, int R) {
    if(L == R){
        return;
    }
    int mid = L + ((R-L) >> 1);
    process(A, L, mid);
    process(A, mid+1, R);
    merge(A, L, mid, R);
}

void MergeSort::merge(vector<int> &A, int L, int mid, int R) {
    vector<int> arr(R-L+1);
    int i = 0;
    int p1 = L;
    int p2 = mid+1;
    while(p1 <= mid && p2 <= R){
        arr[i++] = A[p1] <= A[p2]?A[p1++]:A[p2++];
    }
    while(p1 <= mid){
        arr[i++] = A[p1++];
    }
    while(p2 <= R){
        arr[i++] = A[p2++];
    }
    for(i = 0; i<arr.size(); ++i){
        A[L+i] = arr[i];
    }
}
#endif //C__TEST01_MERGESORT_HPP

posted @   蘑菇王国大聪明  阅读(16)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律
点击右上角即可分享
微信分享提示