문제
TC: 접두사[][] 합계 행렬을 생성하기 위한 O(n*m), 주어진 직사각형의 합을 계산하기 위한 O(row1 row2)
SC: 접두어[][] 합계 행렬을 사용하는 경우 O(n*m)
class NumMatrix { int prefix[][]; public NumMatrix(int[][] matrix) { prefix = new int[matrix.length][matrix[0].length]; for(int i=0;i<matrix.length;i++){ int current = 0; for(int j = 0;j<matrix[0].length;j++){ current+=matrix[i][j]; prefix[i][j] = current; } } } public int sumRegion(int row1, int col1, int row2, int col2) { int sum =0; for(int i =row1;i<=row2;i++){ int right = prefix[i][col2]; int left = (col1>0) ? prefix[i][col1-1] : 0; sum+=right-left; } return sum; } } /** * Your NumMatrix object will be instantiated and called as such: * NumMatrix obj = new NumMatrix(matrix); * int param_1 = obj.sumRegion(row1,col1,row2,col2); */
위 내용은 범위 합계 쿼리 - 불변의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!