91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

自定義C++ Array類以支持高效的區間查詢

發布時間:2024-07-19 13:46:05 來源:億速云 閱讀:78 作者:小樊 欄目:編程語言
#include <vector>
#include <iostream>

class Array {
public:
    Array(const std::vector<int>& nums) {
        data = nums;
        buildSegmentTree(0, data.size() - 1, 0);
    }

    int query(int start, int end) {
        return queryHelper(start, end, 0, data.size() - 1, 0);
    }

private:
    std::vector<int> data;
    std::vector<int> segmentTree;

    void buildSegmentTree(int start, int end, int index) {
        if (start == end) {
            segmentTree[index] = data[start];
            return;
        }

        int mid = start + (end - start) / 2;
        buildSegmentTree(start, mid, 2 * index + 1);
        buildSegmentTree(mid + 1, end, 2 * index + 2);

        segmentTree[index] = segmentTree[2 * index + 1] + segmentTree[2 * index + 2];
    }

    int queryHelper(int queryStart, int queryEnd, int start, int end, int index) {
        if (queryStart <= start && queryEnd >= end) {
            return segmentTree[index];
        }

        if (queryStart > end || queryEnd < start) {
            return 0;
        }

        int mid = start + (end - start) / 2;
        return queryHelper(queryStart, queryEnd, start, mid, 2 * index + 1) +
               queryHelper(queryStart, queryEnd, mid + 1, end, 2 * index + 2);
    }
};

int main() {
    std::vector<int> nums = {1, 2, 3, 4, 5, 6, 7};
    Array arr(nums);

    int sum = arr.query(1, 4);
    std::cout << sum << std::endl;

    return 0;
}
向AI問一下細節

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

c++
AI

老河口市| 乌拉特后旗| 贵南县| 济宁市| 泸州市| 诸城市| 轮台县| 寻乌县| 华坪县| 水富县| 枣庄市| 陆良县| 绍兴县| 鹤峰县| 越西县| 二手房| 卢湾区| 柘城县| 琼海市| 泊头市| 湾仔区| 青冈县| 巴彦淖尔市| 莱芜市| 亳州市| 海淀区| 湟中县| 沐川县| 平顶山市| 仙游县| 阿拉善右旗| 衡东县| 玉环县| 新营市| 金沙县| 德惠市| 新晃| 通州市| 边坝县| 任丘市| 桦南县|