백준 11660 (DP, 행렬)하고싶은거/알고리즘 문제풀이2024. 4. 9. 12:46
Table of Contents
과정
- x2-x1, y2-y1 범위에 들어있는 숫자를 for문으로 더할까 하다가 그럼 시간초과가 날 것 같아서 애초에 숫자를 받을 때, 같은 열!!!!! 기준으로 누적값을 벡터에 저장한 후, 범위를 받아서 최대좌표의 누적값 - 최소 좌표의 누적값 을 했다.
- 이 문제를 풀 때 가장 시간이 오래걸린 점은 바로 행렬을 개같이 못했다는 점이다.
행 = Row = x값 = 가로
열 = Column = y값 = 세로
코드
#include <iostream>
#include <vector>
using namespace std;
int main()
{
ios::sync_with_stdio(false);
cin.tie(nullptr); cout.tie(nullptr);
int N = 0; // N*N 크기
int M = 0; // 합을 구해야하는 횟수
// 열 기준 각 인덱스까지 숫자의 합이 채워진 표
// MaxBoard[X][Y]
vector<vector<int>> MaxBoard;
cin >> N >> M;
MaxBoard.resize(N+1, vector<int>(N+1, 0));
// X값 (행)
for (int i = 1; i < N+1; i++)
{
// Y값 (열)
for (int j = 1; j < N+1; j++)
{
cin >> MaxBoard[i][j];
// 같은 열, 이전 행값을 추가로 더함
// 같은 열의 누적값
MaxBoard[i][j] += MaxBoard[i-1][j];
}
}
for (int i = 0; i < M; i++)
{
int x1, x2, y1, y2;
int answer = 0;
cin >> x1 >> y1 >> x2 >> y2;
// 같은 좌표일 때
if (x1 == x2 && y1 == y2)
answer = MaxBoard[x1][y1] - MaxBoard[x1-1][y1];
// 다른 좌표일 때
else
{
for (int num = y1; num < y2+1; num++)
{
answer = answer + (MaxBoard[x2][num] - MaxBoard[x1-1][num]);
}
}
cout << answer << "\n";
}
return 0;
}
'하고싶은거 > 알고리즘 문제풀이' 카테고리의 다른 글
백준 12865 (DP) (0) | 2024.04.11 |
---|---|
백준 11725 (트리, DFS) (0) | 2024.04.10 |
백준 11053 (DP) (0) | 2024.04.08 |
백준 1629 (재귀함수) (1) | 2024.04.07 |
백준 1149 (DP) (0) | 2024.04.05 |
@ssIIIn :: 두 번째 저장공간
이것저것 기억하고 싶은거 글쓰는 블로그
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!