inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

4-J

4-J 질문있습니다.

96

AA66

작성한 질문수 29

0

http://boj.kr/d4a41da7d56b4acfa374613ed7723eeb

비트마스킹을 사용하지않고 무식하게 풀어보았는데 vscode에서는 계속해서 segmentation fault 오류가 나오고 백준에서는 메모리 초과가 뜹니다.

이렇게는 해결이 어려울까요?

c++ 코딩-테스트

답변 2

0

큰돌

안녕하세요 ㅎㅎ

네 이렇게는 불가능합니다.

보통 세그먼트나 메모리 초과부분은 재귀함수를 많이 호출했나? 라는 것을 중점적으로 보시면 풀립니다.

 

    for(int i = 0; i < m; i++){
        for(int j = 0; j < n; j++){
            if(visited[i][j]) continue; 
            int ssum = 0;
            int count  = 0;
                // 가로
                for(int k = 0; j + k < n; k++){
                    if(visited[i][j + k]) break;
                    ssum = ssum * 10 + a[i][j + k];
                    visited[i][j + k] = 1;
                    count++;
                    go(count + cnt, ssum + sum); 
                }

일단 이걸 보시면 go라는 함수를 매번 최대 n번 호출합니다. -> 많은 재귀함수 호출 -> 에러

또한 시간복잡도는 n^(n * m) 이런식이 되어버려서 너무 커지게 됩니다.

다른 방법으로 시도 부탁드립니다.

 



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

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

감사합니다.

강사 큰돌 올림.

 

 

 

 

0

AA66

저는 아무리 재귀함수가 많이 호출된다고 해도 n과 m이 최대 4이기 때문에 1억번의 연산은 안일어날 것이라고 생각하였는데 재귀함수도 대략적으로 몇번까지 호출해도 괜찮다라는 기준이 있을까요?

0

큰돌

안녕하세요 AA66님 ㅎㅎ

먼저 1억번은 괜찮습니다.

 

제가 답변을 잘못드린게 있는데요.

각 함수당 cnt가 1이라 가정 + k부분은 한번씩만발생한다고 가정하더라도 이 코드의 시간복잡도는 (N* M) ^(N* M)입니다. 즉, 16^16이기 때문에 100억을 초과하는 코드이기 때문에 안되는 것 같습니다.

 

감사합니다.

 

0

인프런 AI 인턴

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

현재 질문에서 언급하신 Segmentation fault와 메모리 초과는 코드를 작성할 때 잘못된 메모리 접근이나 비효율적인 메모리 사용으로 인해 발생할 수 있습니다. 이 문제를 해결하기 위해 몇 가지 일반적인 점검 사항을 제공하겠습니다.

Segmentation Fault

  1. 배열 인덱스 점검: 배열이나 포인터를 사용할 때 범위를 초과해서 접근하지 않도록 주의해야 합니다. 종종 for 루프의 종료 조건이 잘못 설정되어 이런 오류가 발생할 수 있습니다.

  2. 포인터 초기화: 포인터를 사용하기 전에 충분히 초기화되었는지 확인하세요. NULL 포인터를 역참조하면 Segmentation fault가 발생할 수 있습니다.

  3. 메모리 할당 후 해제: 동적 메모리 할당 시 malloc이나 new와 같은 함수로 메모리를 할당받고, 프로그램 종료 전에 항상 해제(delete, free)해야 합니다. 이러한 문제가 없으면 프로그램이 잘못된 위치를 참조할 수 있습니다.

메모리 초과

  1. 배열 크기 점검: 문제에서 요구하는 최대 크기를 초과한 배열을 생성할 경우 메모리 초과가 발생할 수 있습니다. 문제의 제약 조건을 다시 확인하고, 크기를 합리적으로 설정하세요.

  2. 비효율적인 데이터 저장: 필요 없는 데이터까지 저장하고 있을 수 있습니다. 유효하지 않은 데이터가 증가할 수 있는 만큼 저장된 데이터의 양을 최소화할 수 있는 방법을 찾아보세요.

대체 해결책

비트마스킹은 메모리와 시간 효율성을 크게 개선할 수 있는 기술입니다. 무차별적으로 해결하는 방법을 고려하고 있다면 비트마스킹을 사용하여 각 경우의 수를 효율적으로 표현하거나 처리하는 방법을 학습하는 것도 좋은 방법입니다. 비트마스킹을 통해 문제의 효율성을 높일 수 있으니 이에 대한 학습을 권장드립니다.

유사 질문과 답변을 연구하시려면 다음 링크를 참고하세요:
- 4-A 문제 풀이 질문있습니다.
- 비트마스킹 사용에 관한 질문입니다.

위의 링크에서는 비슷한 환경에서 나온 비트마스킹 활용에 대한 설명이 포함되어 있습니다. 질문자는 비슷한 문제를 해결할 수 있는 많은 힌트를 얻을 수 있습니다.

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

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

0

10

2

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

0

29

1

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

0

13

1

진행 방법 질문드립니다!

0

46

2

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

0

56

2

2주차 개념#12 트리 순회

0

26

2

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

0

286

2

백준 서비스 종료

9

890

1

sk 하이닉스 코테 대비

0

368

2

3-G 최댓값 질문

0

50

1

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

0

83

2

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

0

62

2

3-N 질문 있습니다.

0

66

2

학습방법

0

102

2

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

0

66

2

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

0

170

2

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

0

69

2

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

0

64

2

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

0

51

2

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

0

68

2

함수별 시간복잡도

0

73

2

3-h 질문입니다.

0

49

1

안녕하세요 선생님. 시간 복잡도 4번 질문있습니다.

0

53

2

1-I 문제 질문 드립니다.

0

76

2