inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-G 와 테스트케이스 팁

3-G 와 백준 컴파일러에 대한 질문이 있습니다

107

yajang12

작성한 질문수 2

0

https://www.acmicpc.net/source/82778585
해당 풀이를 통해 정답을 맞혔는데요

몇 가지 조건에 따라 오답과 정답이 나뉘는 현상이 있어서 이와 관련하여 강사님 의견을 여쭙고 싶습니다

const int MAX 를 선언할 때 정수 크기에 따라 백준에 입력했을 때 결과가 다르게 나옵니다

크게 차이나게 입력한 것은 아니고요

200,000 이랑 200,002 를 입력해봤는데 200,002 은 정답이고, 200,000 은 오답으로 나오네요

그리고 int n, k; 와 int visited[MAX], cnt[MAX]; 이 두 라인을 서로 변경했을 시 또 결과가 다르게 나옵니다

int n, k; 를 나중에 선언해야 정답으로 나오더라구요

그런데 int n, k; 를 먼저 선언해도 되는 경우가 있습니다

int visited[MAX], cnt[MAX]; 이 부분에 MAX 뒤에 정수를 더해주면 int n, k; 를 먼저 선언해도 되었습니다

아무리 고민해도 짐작 가는 부분이 없는데 강사님의 의견을 듣고 싶습니다

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 ㅎㅎ

#include<bits/stdc++.h>
using namespace std;
const int MAX = 200001;

int visited[MAX], cnt[MAX];
int n, k;

이렇게 20만 + 1로 해도 통과합니다. 문제에서 20만을 참조할 수 있고 -> 20만 + 1이 필요함 : 이 때 20만으로 설정하면 -> 배열범위초과 -> UB -> 이상하게 틀리는 경우가 발생하는 것입니다.

 

감사합니다.

0

yajang12

큰돌님 답변 감사합니다.

제가 의사전달 능력이 낮아 제대로 전달드리지 못한 점 죄송합니다

큰돌님께서 답변해주신 부분에서 변수 선언의 순서가 변경되었을 때 오답으로 처리가 됩니다

 

#include<bits/stdc++.h>
using namespace std;
const int MAX = 200001;

int n, k;
int visited[MAX], cnt[MAX];

 

이렇게 했을 경우 범위가 동일함에도 불구하고 오답처리가 됩니다

범위 문제가 아닌듯 한데 원인을 파악할 수가 없습니다

바쁘신 와중에 시간내주셔서 정말 감사합니다

나중에라도 혹여나 알게된다면 저도 답변에 달아두도록 하겠습니다

0

큰돌

<= MAX 때문에 범위초과 -> UB가 발생하는 것입니다.

 

#include<bits/stdc++.h>
using namespace std;
const int MAX = 200000;
 
int n, k;
int visited[MAX + 1], cnt[MAX + 1];
int main() {
    cin >> n >> k;
    if(n == k) {
        cout << 0 << "\n" << 1 << "\n";
        return 0;
    }
    visited[n] = 1;
    cnt[n] = 1;
    queue<int> q;
    q.push(n);
    while(q.size()) {
        int now = q.front();
        q.pop();
        for(int next: {now-1, now+1, now*2}) {
            if(0 <= next && next <= MAX) {
                if(visited[next] == 0) {
                    q.push(next);
                    visited[next] = visited[now]+1;
                    cnt[next] += cnt[now];
                } else if(visited[next] == visited[now]+1) {
                    cnt[next] += cnt[now];
                }
            }
        }
    }
    cout << visited[k]-1 << "\n";
    cout << cnt[k] << "\n";
    
    return 0;
}

이렇게 하시면 됩니다.

 

감사합니다.

0

yajang12

큰돌님, 정말 감사합니다

조건문으로 제한해둔 next 가 배열의 범위를 넘어선게 문제였군요

max 가 포함되지 않게 작성했던 부분이 어느새 수정이 되어있었는데 이걸 못봤습니다

귀찮게 해드려서 정말 죄송합니다

그리고 다시 한 번 답변 정말 감사드립니다!

0

큰돌

ㅎㅎ 전반적인 로직자체가 맞아도 -> 범위 넘어서거나 이런 ub 발생할 수 있는 코드가 하나라도 있으면 -> 이상하게 변수 순서 바꿔도 틀리는 경우가 있더라구요 . ㅎㅎㅎ

 

귀찮지는 않습니다.

감사합니다.

코딩살구클럽 문의

0

7

1

코딩살구클럽 승인

0

18

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

27

2

3-F 채점 관련 질문

0

24

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

28

2

코딩살구클럽 승인

0

41

2

코딩살구클럽승인

0

33

3

코딩살구클럽 승인

0

48

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

43

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

53

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

코딩 살구 클럽 접속 및 사용방법 문의

0

61

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

64

2

코딩살구클럽 로그인문제

0

78

3

코딩 살구 클럽 로그인 문제

0

82

2

2-J 채점관련 질문

0

65

3

코딩 살구 클럽 Python 지원 가능 여부

0

77

1

살구클럽 아이디 없음 문제

0

76

1

1-O 코딩살구클럽 채점관련 질문

0

60

2

히든 테스트 케이스가 사라졌습니다

0

57

1

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

74

2