inflearn logo
강의

講義

知識共有

10週間完成 C++ コーディングテスト | アルゴリズムコーディングテスト

7-O

7-O 질문입니다!

436

gdgd

投稿した質問数 24

0

안녕하세요, 큰돌님

17837을 풀던중 문제 예제 입력 5에서 답이 나오지 않습니다.

반례를 다 찾았다고 생각했는데, 대체 왜 안되는지 궁금합니다...

 

https://www.acmicpc.net/source/72120636

c++ 코딩-테스트

回答 4

0

gdgd

죄송합니다..
저렇게 디버깅 할 생각을 못 했네요

로직 고치고 맞췄습니다!
항상 답글 달아 주시는 것 감사합니다!

 

https://www.acmicpc.net/source/72431720

 

0

kundol

혹시 디버깅코드 넣어서 벡터내의 있는 말들이 잘 움직이나 테스팅해보셨나요?

ex5의 경우.

이거 정상적인 코드는

START
0 1 0 1 0 0 
1 0 0 0 0 1 
0 0 0 0 0 0 
0 0 2 0 2 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 2 0 1 
0 0 0 0 0 0 
0 2 0 0 0 0 
1 0 0 0 0 1 
START
0 1 0 0 0 0 
1 0 1 0 0 1 
0 0 1 1 0 0 
0 1 0 0 0 0 
0 0 1 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 1 
1 0 0 0 0 0 
0 2 1 0 0 0 
0 0 0 1 0 0 
0 1 0 0 0 0 
1 0 0 0 0 1 
START
0 1 0 0 0 0 
1 0 0 0 0 1 
0 0 0 1 0 0 
1 1 1 0 0 0 
0 0 1 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 0 0 1 
0 1 0 0 0 0 
0 3 0 0 0 0 
1 0 0 0 0 1 
7

다음과 같이 움직입니다.

 

근데 동훈님 코드는 다음과 같이 움직입니다.

START
0 1 0 1 0 0 
1 0 0 0 0 1 
0 0 0 0 0 0 
0 0 2 0 2 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 0 0 1 
0 0 2 0 0 0 
0 0 0 0 0 0 
1 0 2 0 0 1 
START
0 1 0 0 0 0 
1 0 0 0 0 1 
0 0 0 1 0 0 
1 1 2 0 0 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 1 
1 0 1 0 0 0 
0 0 1 0 0 0 
0 2 0 1 0 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
0 1 0 0 0 0 
1 0 0 0 0 1 
0 0 2 1 0 0 
0 0 2 0 0 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 0 0 1 
0 0 1 1 2 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
0 1 0 1 0 0 
1 0 0 0 0 1 
0 0 0 0 0 0 
0 0 0 3 0 0 
0 0 1 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 1 
1 0 0 1 0 0 
0 0 0 0 0 0 
0 3 0 0 0 0 
0 0 0 0 0 0 
1 0 1 0 0 1 
START
0 1 0 0 0 0 
1 0 0 0 0 1 
0 0 0 1 0 0 
0 3 0 0 0 0 
0 0 1 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 0 0 0 
0 0 0 0 0 1 
0 0 2 3 0 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
11

여기서 하나만 뽑으면.

그냥 첫번째부터 잘못되었는데요.

 

이부분 다음과 같이 진행되어야 하는데요.

START
0 1 0 1 0 0 
1 0 0 0 0 1 
0 0 0 0 0 0 
0 0 2 0 2 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 2 0 1 
0 0 0 0 0 0 
0 2 0 0 0 0 
1 0 0 0 0 1 

 

이렇게 진행되고 있습니다.

START
0 1 0 1 0 0 
1 0 0 0 0 1 
0 0 0 0 0 0 
0 0 2 0 2 0 
0 0 0 0 0 0 
1 0 0 0 0 1 
START
1 0 0 0 0 0 
1 0 0 1 0 0 
0 0 0 0 0 1 
0 0 2 0 0 0 
0 0 0 0 0 0 
1 0 2 0 0 1 

확인부탁드립니다.

 

디버깅코드

        if (move()){
            cout << cnt;
            break;
        } 
        cout << "START\n";
        for (int i = 1; i <= N; i++){
            for (int j = 1; j <= N; j++){
                cout << M[i][j].size() << " ";
            }
            cout << "\n";
        }

 

 

감사합니다.

0

gdgd

바깥으로 나갈때, 파란색으로 경우 처리를 하라고 했으니, 조건문을 바깥으로 나간다면 이라고 처리 해주었습니다. 뒤는 else if 문을 사용해 밖으로 벗어나는 경우를 없앴습니다.

 

image

image

https://www.acmicpc.net/source/72245823

0

kundol

안녕하세요 동훈님 ㅎㅎ

코드 좀 봤는데요.

 

    for (int i = 1; i <= N; i++){
        for (int j = 1; j <= N; j++){
            cin >> A[i][j];
        }
    }

입력을 1 부터 받아놨고 그걸기반으로 했다면...

        if (my > N || my <= 0 || mx > N || mx <= 0){

이거 1 ~ N 이렇게 되어야 하는게 아닐까요?

 

감사합니다.

0

gdgd

바깥으로 나갈때, 파란색으로 경우 처리를 하라고 했으니, 조건문을 바깥으로 나간다면 이라고 처리 해주었습니다. 뒤는 else if 문을 사용해 밖으로 벗어나는 경우를 없앴습니다.

 

image

image

https://www.acmicpc.net/source/72245823

진행 방법 질문드립니다!

0

30

2

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

0

55

2

2주차 개념#12 트리 순회

0

25

2

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

0

284

2

백준 서비스 종료

9

882

1

sk 하이닉스 코테 대비

0

367

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

169

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

2-P 질문입니다.

0

56

1

mac에서 시작하기 관련

0

91

2

5-Q 질문

0

64

2