中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

自定義C++ Array類以支持稀疏數組

發布時間:2024-07-19 11:02:06 來源:億速云 閱讀:93 作者:小樊 欄目:編程語言

稀疏數組是一種數組,其中大部分元素的值為零。為了有效地表示稀疏數組,可以使用一個數組來存儲非零元素的值和它們的索引。下面是一個自定義的C++ Array類,用來支持稀疏數組:

#include <iostream>
#include <vector>

class SparseArray {
private:
    std::vector<int> indexes;
    std::vector<int> values;
    int size;

public:
    SparseArray(int size) : size(size) {}

    void set(int index, int value) {
        if (value != 0) {
            int i = 0;
            while (i < indexes.size() && indexes[i] < index) {
                i++;
            }
            if (i < indexes.size() && indexes[i] == index) {
                values[i] = value;
            } else {
                indexes.insert(indexes.begin() + i, index);
                values.insert(values.begin() + i, value);
            }
        } else {
            for (int i = 0; i < indexes.size(); i++) {
                if (indexes[i] == index) {
                    indexes.erase(indexes.begin() + i);
                    values.erase(values.begin() + i);
                    break;
                }
            }
        }
    }

    int get(int index) {
        for (int i = 0; i < indexes.size(); i++) {
            if (indexes[i] == index) {
                return values[i];
            }
        }
        return 0;
    }

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

int main() {
    SparseArray sparseArray(10);

    sparseArray.set(1, 5);
    sparseArray.set(3, 8);
    sparseArray.set(5, 3);
    sparseArray.set(1, 0);

    sparseArray.print();

    return 0;
}

在上面的代碼中,SparseArray類存儲了非零元素的索引和值,通過set方法可以設置某個索引的值,通過get方法可以獲取某個索引的值。通過print方法可以打印整個稀疏數組。在main函數中可以看到如何使用SparseArray類來表示一個稀疏數組。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

c++
AI

拜城县| 科尔| 阳西县| 乐东| 中宁县| 台东县| 上犹县| 吉水县| 峡江县| 伊吾县| 会昌县| 汽车| 富顺县| 福建省| 武功县| 宣城市| 江口县| 双江| 故城县| 宿迁市| 茶陵县| 堆龙德庆县| 金溪县| 聊城市| 肇庆市| 咸丰县| 湘潭县| 吉水县| 鄂伦春自治旗| 磐安县| 张家港市| 张北县| 故城县| 岚皋县| 远安县| 郁南县| 清水河县| 肃宁县| 正安县| 任丘市| 宜章县|