inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

3-J

3-J 질문이요

375

Kouga

작성한 질문수 17

0

http://boj.kr/840aa4abc0c7452d960643187ee2b215

왜 이렇게 짜면 예제입력2에서 무한루프가 걸리나요??

아무리 생각해도 그 이유를 모르겠어요..

코테 준비 같이 해요! C++

답변 1

0

큰돌

안녕하세요 ㅎㅎ

지금 아예 맵을 변경하는 로직 자체가 작동되지 않아서 그렇습니다.

이런식으로 무한루프가 발생할 때 디버깅 팁이 있는데 이런식으로 하시면 디버깅할 수 있습니다.

	int aa = 0;
	while (!check) {
		go(b1-1, a1-1);
		if(++aa == 50)break;

 

지금 디버깅을 해보면 visited가 제대로 색칠되지 않고 있습니다.

디버깅 코드는 다음과 같습니다. 참고해주세요.

#include <bits/stdc++.h>


using namespace std;

int N, M;
int a1, a2, b1, b2;
char c[305][305];
const int dy[4]{ -1,0,1,0 };
const int dx[4]{ 0,1,0,-1 };
bool visited[305][305];
bool check=false;
int cnt;

void go(int y, int x)
{
	

	visited[y][x] = 1;
	for (int i = 0; i < 4; ++i) {
		int ny = y + dy[i];
		int nx = x + dx[i];

		if (ny<0 || nx<0 || ny>=N || nx>=M || visited[ny][nx]==1 ) continue;
		if (c[ny][nx] == '1') {
			visited[ny][nx] = 1;
			continue;
		}
		else if (c[ny][nx] == '0') {
			visited[ny][nx] = 1;
			go(ny, nx);
		}
		else if (c[ny][nx] == '#') {
			check = true;
			break;
		} 
	}
}


int main()
{
	cin >> N >> M;

	cin >> a1 >> b1 >> a2 >> b2;

	for (int i = 0; i < N; ++i) {
		for (int j = 0; j < M; ++j) {
			cin >> c[i][j];
		}
	}
	int aa = 0;
	while (!check) {
		go(b1-1, a1-1);
		if(++aa == 10)break;
		for (int i = 0; i < N; ++i) {
			for (int j = 0; j < M; ++j) {
				if (visited[i][j] == 1) {
					c[i][j] = '0';
				}
			}
		} 
		for (int i = 0; i < N; ++i) {
			for (int j = 0; j < M; ++j) {
				cout << c[i][j];
					
			}
			cout << endl;
		} 
		cout << "-----\n";
		for (int i = 0; i < N; ++i) {
			for (int j = 0; j < M; ++j) {
				cout << visited[i][j];
					
			}
			cout << endl;
		} 

		cout << "-----\n";
		fill(&visited[0][0], &visited[0][0] + 305 * 305, 0);
		cnt++;
 
	}


	cout << cnt;
}
/*
3 5
3 5 1 1
#0000
11111
0000*
#0000
11111
0000*
-----
00000
00000
00000
-----
*/

 

0

Kouga

그런데 예제입력1을 받으면 맵이 잘 변경되었습니다.

0

큰돌

예제1이 통과 되었다고 맞는 코드는 아닙니다.

왜 visited가 색칠되지 않는지를 고민해보셔야 합니다.

이 코드는 Y, X가 서로 바뀌었기 때문에 틀렸습니다.

이렇게 고쳐보시겠어요?

		go(b1-1, a1-1); // 바뀐 것같지 않나요? 

감사합니다.

1-E질문입니다!

0

518

2

3-L 틀린 부분 피드백 부탁드립니다.

0

821

2

1-A문제 순열재귀함수 질문입니다.

0

384

1

1-A 일곱난쟁이문제입니다

0

456

1

문제 풀 때 방향성에 대해

0

800

1

맥에서 vs code로 실행 관련 질문입니다

0

523

1

17071번 메모리 초과

0

386

1

1-C질문입니다!

0

421

2

2-B BFS 시간초과질문

0

630

2

1-O 13번 라인

0

442

1

6-J 놀이공원 문제 질문

0

381

1

구현관련 질문

0

484

1

강의 교안

0

319

1

실력을 더 올리고나서 강의를 보는 것이 맞을까요?

0

545

1

안녕하세요! 재귀함수에 관해서 질문드립니다

0

536

1

1-K

0

473

2

3-G번 질문있습니다.

1

473

3

3-C 실행 시간 질문드립니다.

0

493

1

4-A 문제 풀이 질문있습니다.

0

590

2

비트마스킹 연산자 "1의 보수" 영문 표기법

0

435

1

격자탐색 문제에서 BFS 시간복잡도 질문드립니다.

0

334

1

3-O go 함수 질문 드립니다.

1

447

2

4-A 출력 질문

0

305

1

1주차 1-O 질문드립니다

0

259

1