303 & 304. Range Sum Query - Immutable

303. Range Sum Query - Immutable

303 題目截圖

class NumArray {
    private int[] sumSoFar;
    
    public NumArray(int[] nums) {
        sumSoFar = new int[nums.length + 1];
        for (int i = 0; i < nums.length; i++) {
            sumSoFar[i + 1] = sumSoFar[i] + nums[i];
        }
    }
    
    public int sumRange(int i, int j) {
        return sumSoFar[j + 1] - sumSoFar[i];
    }
}
304 題目截圖
class NumMatrix {
    private int[][] dpSum;
    
    public NumMatrix(int[][] matrix) {
        if (matrix == null || matrix.length == 0 || matrix[0] == null || matrix[0].length == 0) {
            return;
        }
        
        int rows = matrix.length;
        int cols = matrix[0].length;
        dpSum = new int[rows + 1][cols + 1];
        for (int i = 0; i < rows; i++) {
            for (int j = 0; j < cols; j++) {
                dpSum[i+1][j+1] = dpSum[i+1][j] + dpSum[i][j+1] - dpSum[i][j] + matrix[i][j];
            }
        }
    }
    
    public int sumRegion(int row1, int col1, int row2, int col2) {
        return dpSum[row2+1][col2+1] - dpSum[row1][col2+1] - dpSum[row2+1][col1] + dpSum[row1][col1];
    }
}
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

相關閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容