inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

3-D와 반례

3-D 메모리 초과가 나는 이유에 대하여 궁금합니다.

306

김지성

작성한 질문수 6

0

3-D Fire!

 

다음 코드 제출시 메모리 초과가납니다. 혼자 생각해봐도 고민이 해결되지않아 질문 올립니다.

 

코드:

http://boj.kr/7b447402e3e04302bdc04ebb1e2c0105

 

좋은 강의 감사합니다.

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 지성님 ㅎㅎ

 

제 생각에는 이부분 때문에 특정반례에서 fire bfs가 방문한 지점을 다시 방문하는 자주 로직이 발생 -> 메모리초과가 나는 것 같습니다.

 

    for (auto f_point : f_points)
    {
      
        q.push(f_point);
        fire[f_point.first][f_point.second] = 1;
        while (!q.empty())
fire[y][x] + 1 > fire[ny][nx]

 

예를 들어

이런 입력의 경우 다음과 같은 출력을 가지게 됩니다.

입력
6 5
FFFFF
#...#
FFFFF
#...#
#J..#
#####
 
출력
0 : 0
0 : 1
1 : 0
0 : 2
1 : 1
1 : 1
2 : 0
0 : 3
1 : 2
1 : 2
2 : 1
1 : 2
2 : 1
2 : 1
3 : 0
0 : 4
1 : 3
1 : 3
2 : 2
1 : 3
2 : 2
2 : 2
3 : 1
1 : 3
2 : 2
2 : 2
3 : 1
2 : 2
3 : 1
3 : 1
4 : 0
1 : 4
2 : 3
2 : 3
2 : 3
3 : 2
2 : 3
2 : 3
3 : 2
2 : 3
3 : 2
3 : 2
4 : 1
2 : 3
2 : 3
3 : 2
2 : 3
3 : 2
3 : 2
4 : 1
2 : 3
3 : 2
3 : 2
4 : 1
3 : 2 
...
4
3
4
4
IMPOSSIBLE

 

디버깅 코드

#include <bits/stdc++.h>
using namespace std;

int n, m;
char board[1005][1005];

int dy[4] = {-1, 0, 1, 0};
int dx[4] = {0, 1, 0, -1};

int fire[1005][1005];
int jihun[1005][1005];

int y, x;
vector<pair<int, int>> f_points;
pair<int, int> j_point;

int main(void)
{
    cin.tie(0);
    cout.tie(0);
    ios::sync_with_stdio(0);

    cin >> n >> m;
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < m; j++)
        {
            cin >> board[i][j];
            if (board[i][j] == 'F')
                f_points.push_back({i, j});
            if (board[i][j] == 'J')
                j_point = {i, j};
        }
    }
    queue<pair<int, int>> q;
    for (auto f_point : f_points)
    {
      
        q.push(f_point);
        fire[f_point.first][f_point.second] = 1; 
        while (!q.empty())
        {
            tie(y, x) = q.front();
            cout << y << " : " << x << "\n";
            q.pop();
            for (int dir = 0; dir < 4; dir++)
            {
                int ny = y + dy[dir];
                int nx = x + dx[dir];
                if (ny < 0 || ny >= n || nx < 0 || nx >= m)
                    continue;
                if ((board[ny][nx] == '#' || fire[y][x] + 1 > fire[ny][nx]) && fire[ny][nx] != 0)
                    continue;
                fire[ny][nx] = fire[y][x] + 1;
                q.push({ny, nx});
            }
        }
    }

    q.push(j_point);
    jihun[j_point.first][j_point.second] = 1;
    while (!q.empty())
    {
        tie(y, x) = q.front();
        cout << y << "\n";
        q.pop();
        for (int dir = 0; dir < 4; dir++)
        {
            int ny = y + dy[dir];
            int nx = x + dx[dir];
            if (ny < 0 || ny >= n || nx < 0 || nx >= m)
            {
                cout << jihun[y][x];
                return 0;
            }

            if (board[ny][nx] == '#' || jihun[ny][nx] != 0)
                continue;
            if (jihun[y][x] + 1 > fire[ny][nx] && fire[ny][nx] != 0)
                continue;
            jihun[ny][nx] = jihun[y][x] + 1;
            q.push({ny, nx});
        }
    }
    cout << "IMPOSSIBLE";
}

 

 




또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

김지성님, 메모리 초과 문제로 고민하고 계신 것으로 보입니다. 메모리 초과는 프로그램이 할당된 메모리보다 많은 메모리를 사용할 때 발생합니다. 이는 종종 불필요한 큰 배열을 선언하거나, 깊이가 깊은 재귀호출로 인해 발생할 수 있습니다. 또한, 적절하지 않게 메모리를 할당하거나 해제하지 않는 경우에도 종종 메모리 초과가 발생할 수 있습니다.

유사한 경우의 질문에 대한 답변으로, 아래의 링크를 참고하실 수 있습니다:

위 링크들은 모두 메모리 초과와 관련된 질문에 대한 지식공유자 큰돌님의 답변을 포함하고 있습니다. 해당 답변에서는 메모리 초과를 일으키는 코드의 예시와 그 해결방안을 제시하고 있으니 유사한 문제를 겪고 계신다면 많은 도움이 될 것입니다.

질문자님의 코드를 확인하지 못해 구체적인 해결책을 제공하기는 어렵지만, 메모리 초과 문제를 해결하기 위해서는 큐에 넣는 요소의 수를 줄이거나, 배열의 크기를 적절히 조정하는 등의 방법을 시도하실 수 있습니다. 또한, 이미 방문했던 위치를 다시 방문하지 않도록 처리하는 로직이 있는지 확인하고, 시간복잡도 및 공간복잡도를 개선할 수 있는 방식을 고려해보시기 바랍니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

코딩살구클럽 입장이 안됩니다

0

19

2

4-F 경우의 수 질문입니다.

0

26

2

코딩살구클럽 가입이 안됩니다.

0

53

2

살구 클럽에 대한 질문있습ㄴ디ㅏ

0

42

1

교안 158페이지 문의드립니다

0

37

2

코딩살구클럽 관련 건의사항

0

98

1

코살에 19942 다이어트 문제에 N의 범위가 빠져있슴니다

0

40

1

진행 방법 질문드립니다!

0

72

2

2-I) 왜 이 문제가 그래프이론 카테고리에 있는지 잘 모르겠습니다.

0

61

2

2주차 개념#12 트리 순회

0

32

2

백준사이트가 종료된다고 합니다.

0

301

2

백준 서비스 종료

9

921

1

sk 하이닉스 코테 대비

0

378

2

3-G 최댓값 질문

0

52

1

모듈러 연산 값이 10이 아닌 경우도 있지 않나요?

0

84

2

3-I 코드 질문드립니다.

0

63

2

3-N 질문 있습니다.

0

68

2

학습방법

0

104

2

4-H 질문 있습니다 (코드 리뷰)

0

67

2

코딩테스트 어디까지 준비해야 하는지 질문이 있습니다.

0

178

2

2-O 반례가 무엇일지 어떤 부분이 틀렸는지 잘 모르겠습니다.

0

70

2

2주차 개념 #4-2. 인접행렬 질문있습니다.

0

65

2

1-A 문제풀이 후 궁금한 점이 생겨서 질문드립니다.

0

52

2

조합 재귀 풀이 확인 해주시면 감사하겠습니다.

0

70

2