선생님 저 코드에서 최단거리인지 판별하는 것은
493
26 câu hỏi đã được viết
선생님 저 코드에서 최단거리인지 판별하는 것은 dis[7][7]에 어떤 수가 들어가면 바로 코드가 종료되는 조건도 없는데 어떻게 판별하는 것인가요...?
이 문제는 도착지점까지 도착하는 경로가 2개 뿐이라서 while(!Q.isEmpty()) 이 조건때문에 둘 중에 먼저 도착하면 자동으로 다른 경로를 계산할 때, Queue가 비어있게 되어서 반복문이 종료되어서 그게 가능하지만 도착하는 경로가 3개 이상일 경우에는 불가능 할 것 같은데 그때는 따로 조건을 추가해줘야 되나요...?
Câu trả lời 3
2
같은 궁금증이 있던 수강생입니다.
성찬우님 댓글 읽고 이해가 갔네요 감사합니다.
큐의 특성상 먼저 들어간 것이 먼저 나오므로 최단 거리에서 도착지점이 1로 바뀌고 그 후에는 if문에서 걸러져서 카운트 되지 않겠네요.
DFS, 재귀함수만 계속 보다보니 헷갈렸나봅니다..ㅠㅠ
1
같은 수강자의 생각입니다.. 정말 참고만 바래요 ㅠㅠ ..
1. 종료가 되는 조건.
Q)dis[7][7]에 어떤 수가 들어가면 바로 코드가 종료되는 조건도 없는데 어떻게 판별하는 것인가요...?
A) 종료가 되는 조건은 while(q가 비엇을경우)입니다. 그리고 q(Queue<Point>)에 새로운 Point객체를 넣는 조건은
" if(nx>=1 && nx<=7 && ny>=1 && ny<=7 && board[nx][ny] == 0) " 입니다.
board[nx][ny] 마지막엔 [7][7]이 0이여야 q에 새로운 Point객체가 들어갈 수 있지만 이미 도착한 nx,ny가 있다면 1이 되므로 늦은 nx,ny는 공중분해 됩니다. (if 에 걸리지 않아서 q에 들어가지 않기때문)
2. 경로가 3개 이상?
각각의 경로는 각각 if문을 통해 q에 넣고 이를 다시 while문으로 돌리는 상황입니다. 그렇기 때문에 q에 넣은 x,y값을 재 사용하는 것이죠.
또한 경로가 겹치는데 정답인 제일 짧은 경로가 늦게 올경우 즉 이미 board[nx][ny]값이 1이여서 q에 못들어가는 경우?
는 없습니다. 정답(짧은 경로)을 위해 거쳐야하는 구간은 어쨋든 먼저 1로 만든 nx,ny경로가 제일 짧은 경로입니다. dis배열을 이용하고 board[nx][ny]를 1로 바꾸는 이유입니다.
다른 늦은 경로들은 사전에 if문으로 걸러내는겁니다.
많이 부족하고 저도 잘 모르겟지만.. 화이팅!
봉우리 문제 질문입니다
0
73
2
씨름 선수 문제에서 각 선수의 몸무게나 키가 같을 수도 있다면?
0
58
0
이 코드랑 영상 코드중에 뭐가 더 좋은 코드인가요?
0
66
0
가중치 방향 그래프에서 가중치가 0인 간선을 표현하는 방법
0
64
1
좌표 정렬 문제 이 코드가 왜 틀린지 모르겠습니다 ㅠㅠ
0
77
2
6-7 강의에서
0
44
1
6-6. 장난꾸러기 질문 있습니다.
0
40
1
강의 수강후 코딩테스트
0
100
1
answer 변수 사용 여부
0
38
1
2중 for문
1
79
2
2-11. 임시반장정하기 (Runtime Error)
0
58
1
혹시 LinkedList 같은 자료 구조들은 따로 배우지 않나요?
0
64
1
이런 풀이는 어떨까요
0
38
1
자바 스트림 방식의 효율성 질문 드립니다.
0
50
1
알고리즘 자료 구조들..
0
54
1
StringBuilder vs BufferdWriter
0
42
1
원더랜드(프림)
0
42
1
이런 코드는 어떤가요?
0
54
1
bfs 풀이
0
50
1
병합정렬
0
51
1
26강 임시반장 정하기에서 질문이 있습니다
0
40
1
이번달말에 완강 후 공부 방향
0
67
1
제가 이런 코테가 처음인데 공부방법을..ㅠ
1
106
1
20강 소수 에라토스테네스의 체 런타임 에러가 뜹니다
0
45
1

