안녕하세요 질문입니다.
287
작성한 질문수 34
제가 재귀가 너무 약해서 그런데 혹시 재귀나 DFS 할때 디버깅은 어떻게 하시는 편인가요? 이런 문제들이나 사이즈카 큰 재귀 문제들은 일일이 하기엔 너무 방대하고 복잡하던데. 재귀에서 막혀서 고민입니다. 스택 옆에 그림을 그려놓고 일일이 그려가면서 해야할까요? 다른 문제들은 디버깅 하면서 하면 이해가 가던데 재귀만 쓰면 유난히 어려운거 같습니다.
답변 1
0
안녕하세요^^
재귀 기초문제부터 재귀가 뻗는 트리형태와 스택을 그려가면서 하는게 제일 좋습니다.
재귀는 디버깅으로 이해하는게 아니라 재귀가 호출되는 상태트리를 그려가면서 이해를 해야 합니다.
그러다 보면 이런 미로탐색도 대충 이렇게 뻗어가다가 막히면 뒤로 백하고 뭐 이러겠네... 하는 식으로 예측하고 짠 다음에 재귀함수 안에서 내가 알고 싶은 변수값이나 배열을 출력해 그 값의 변화를 살펴보는 식으로 합니다.
"58번, 59번, 64번(중요), 82번, [선수지식]조합구하기" 이 5개를 상태트리와 스택을 그려가면서 연구해보시기 바랍니다. DFS가 단번에 되지는 않습니다. 시간이 많이 필요한 영역입니다. 조급해 하지 마시고 천천히 하나하나 해보세요. 느낌이 오는 날이 있을 겁니다.
0
감사합니다. 이때껏 계속 재귀 하면서 일일이 디버깅 하면서 하는데 되게 오래걸리고 헷갈리더라구요..
그리고 이번에 자바 강의 여셨던데 정말 감사합니다. (자바 알고리즘 강의가 많이 없어서.. 특히 컬렉션 부분 특히 벡터 쓴다던가 어레이리스트 2번 써서 인접리스트 쓰는게 C++ 과 비슷 한듯 달라서 많이 헷갈렸습니다.) ㅠ 자바 강의도 잘 듣겠습니다.
테스트 케이스 질문
0
368
1
병합정렬 시간복잡도 질문
0
458
1
41.연속된 자연수의 합 문제풀이에서 수학적인 원리를 모르고 있습니다.
0
1339
2
질문드립니다.
0
371
1
질문드립니다!
0
425
1
dev 프로그램 질문
0
270
1
문제가 이해가 안되요
0
371
1
4번 나이차이 문제 접근법 질문 드립니다.
0
302
1
source file not compiled
0
1030
3
59번 질문드립니다.
0
367
1
25번 문제 질문
0
343
1
4. 나이차이 문제 질문입니다.
0
364
1
90번 라이언 킹 심바 1번 테스트 케이스
0
464
1
71번 문제 전역 변수 질문 있습니다
0
353
1
75번, 79번 priority_queue관련
1
351
1
75.최대 수입 스케줄
0
390
2
복면산 정답의 수
0
424
1
테스트 케이스에 대해서
0
438
1
수업 내용 질문입니다!
1
226
1
풀어보면 좋은 문제 목록 - 2580 스토쿠 DFS 질문입니다!!
0
813
2
12. 플로이드-와샬(그래프 최단거리) . 27:25초
0
248
1
다른 풀이 방식
0
310
1
크루스칼 vs 프림
0
301
1
숫자 총개수 small 질문있습니다.
0
231
1





