inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-A

2-A 맞왜틀

269

eunjin

작성한 질문수 9

0

안녕하세요 강사님 2-A 맞왜틀 원인을 알고싶습니다!

http://boj.kr/7829432fbf3947d7a15bad0490d056d6

c++ 코딩-테스트

답변 1

0

큰돌

안녕하세요 은진님ㅎㅎ

	}
	cout << visited[y][x]; // 마지막 pop 직전 최종 값(최단거리값)이 담긴게 y, x 

이 부분이요. 마지막에 탐색한지점 y, x가 최종지점인게 자명한가요?

이런식으로 되어야 하지 않을까요?

	cout << visited[n-1][m-1];

 

자 반례입니다.

예제 4번이 통과가 되지 않습니다.

7 7
1011111
1110001
1000001
1000001
1000001
1000001
1111111

답 : 13 / 은진님 코드 : 14

Y, X를 디버깅하는 코드를 넣어봤는데 참고 부탁드려요 ㅎㅎ

#include<bits/stdc++.h>
using namespace std;
int n, m, a[104][104], visited[104][104], y, x, cnt; // n, m 둘다 2~100 범위 
int dy[4] = {-1, 0, 1, 0};
int dx[4] = {0, 1, 0, -1};
int main(){
	cin >> n >> m;
	for(int i=0; i<n; i++){
		for(int j=0; j<m; j++){
			scanf("%1d", &a[i][j]); // 따닥따닥 붙어있는거 입력받는 방법!  (cin으로 하니까 안됨)
		}
	}
	queue<pair<int, int>> q; // 이 문제는 yx좌표가 주어지기때문에 pair로 q를 정의함  
	visited[0][0] = 1;
	q.push({0, 0});
	while(q.size()){ // q가 빌때까지 while 반복 
		tie(y, x) = q.front(); // tie로 y, x에 좌표 저장해줘야 계속 시작점을 갱신할 수 있음  
		cout << y << " : " << x << '\n';
		q.pop(); // 저장하고나면 q를 비워버리기 때문!  
		for(int i=0; i<4; i++){
			int ny = y + dy[i]; // ny, nx는 반복될때마다 초기화돼야하므로 지역변수로! 
			int nx = x + dx[i];
			if(ny<0 || nx<0 || ny>=n || nx>=m) continue;
			if(a[ny][nx] == 1 && visited[ny][nx] == 0){
				visited[ny][nx] = visited[y][x] + 1; // 이렇게 해야 이전 경로에서 1씩 누적되면서 최단거리 구할 수 있음   
				q.push({ny, nx});
			}
		}
	}
	cout << visited[y][x]; // 마지막 pop 직전 최종 값(최단거리값)이 담긴게 y, x 
	
	return 0;
}

 

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

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

감사합니다.

강사 큰돌 올림.

5-B

0

15

2

4 - A

0

33

2

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

0

82

2

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

0

35

2

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

0

85

2

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

0

63

1

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

0

46

2

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

0

119

1

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

0

45

1

진행 방법 질문드립니다!

0

83

2

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

0

64

2

2주차 개념#12 트리 순회

0

33

2

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

0

318

2

백준 서비스 종료

9

953

1

sk 하이닉스 코테 대비

0

388

2

3-G 최댓값 질문

0

54

1

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

0

84

2

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

0

66

2

3-N 질문 있습니다.

0

68

2

학습방법

0

105

2

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

0

69

2

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

0

186

2

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

0

74

2

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

0

66

2