温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

自定义C++ Array类以支持快速排序

发布时间:2024-07-19 11:50:06 来源:亿速云 阅读:82 作者:小樊 栏目:编程语言

下面是一个简单的C++ Array类,它支持快速排序的实现:

#include <iostream>

template <typename T>
class Array {
public:
    Array(int size) : size(size), data(new T[size]) {}

    ~Array() {
        delete[] data;
    }

    void push(T value) {
        data[index++] = value;
    }

    void quickSort() {
        quickSortHelper(0, size - 1);
    }

    void print() {
        for (int i = 0; i < size; i++) {
            std::cout << data[i] << " ";
        }
        std::cout << std::endl;
    }

private:
    int size;
    int index = 0;
    T* data;

    void quickSortHelper(int left, int right) {
        if (left < right) {
            int pivotIndex = partition(left, right);
            quickSortHelper(left, pivotIndex - 1);
            quickSortHelper(pivotIndex + 1, right);
        }
    }

    int partition(int left, int right) {
        T pivot = data[right];
        int i = left - 1;

        for (int j = left; j < right; j++) {
            if (data[j] < pivot) {
                i++;
                std::swap(data[i], data[j]);
            }
        }

        std::swap(data[i + 1], data[right]);
        return i + 1;
    }
};

int main() {
    Array<int> arr(10);
    arr.push(5);
    arr.push(2);
    arr.push(8);
    arr.push(1);
    arr.push(7);
    arr.push(3);
    arr.push(6);
    arr.push(4);
    arr.push(9);
    arr.push(10);

    std::cout << "Before sorting:" << std::endl;
    arr.print();

    arr.quickSort();

    std::cout << "After sorting:" << std::endl;
    arr.print();

    return 0;
}

在这个例子中,我们定义了一个Array类,它有一个动态分配的数组和一些基本的数组操作方法。我们使用快速排序算法来对数组进行排序。在main函数中,我们创建了一个Array对象,并向其中添加一些元素,然后进行快速排序并打印排序后的结果。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

c++
AI