inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

2-A

2-A 맞왜틀

277

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점은 제가 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.

코딩 살구 클럽 컴파일 에러

0

4

1

추천 문제

0

7

1

코딩살구클럽 승인

0

9

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

21

2

문제를 고민하는 시간 관련

0

26

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

37

2

코딩살구클럽 승인

0

35

2

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

0

33

2

3-F 채점 관련 질문

0

31

1

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

0

33

2

코딩살구클럽 승인

0

45

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

54

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

코살구 로그인 문제

0

65

2

3-A 문제 풀이 관련 질문

0

56

3

2-O 질문 있습니다

0

38

2

2-T 문제에 관한 질문

0

40

2

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

0

63

2

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

0

67

2

코딩살구클럽 로그인문제

0

85

3

코딩 살구 클럽 로그인 문제

0

86

2