温馨提示×

温馨提示×

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

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

自定义C++ Array类以优化特定操作

发布时间:2024-07-18 18:36:05 来源:亿速云 阅读:95 作者:小樊 栏目:编程语言
#include <iostream>

template <typename T>
class Array {
private:
    T *data;
    int size;
public:
    Array(int size) : size(size) {
        data = new T[size];
    }

    ~Array() {
        delete[] data;
    }

    T& operator[](int index) {
        if (index < 0 || index >= size) {
            throw std::out_of_range("Index out of bounds");
        }
        return data[index];
    }

    void fill(T value) {
        for (int i = 0; i < size; i++) {
            data[i] = value;
        }
    }

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

    // Optimized function to find the maximum value in the array
    T findMax() {
        T max = data[0];
        for (int i = 1; i < size; i++) {
            if (data[i] > max) {
                max = data[i];
            }
        }
        return max;
    }
};

int main() {
    Array<int> arr(5);
    arr.fill(10);
    arr[2] = 15;

    arr.print();

    std::cout << "Max value in the array: " << arr.findMax() << std::endl;

    return 0;
}
向AI问一下细节

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

c++
AI