2-Q 모범답안 코드리뷰 부탁드립니다.
203
작성한 질문수 3
안녕하세요 큰돌님
2-Q 2636문제 모범답안 코드 질문있습니다.
void dfs함수에서 return이 두개가 있는데 각각 return을 하면 다시 main함수의 dfs(0,0)직후로 넘어가지는건가요 아니면 void dfs함수 내에 있는 if문의 return과 for문 바깥에 있는 return이 다른의미를 갖는건가요? void dfs함수 내의 return부분이 어디로 가는지 헷갈립니다.
답변 1
0
안녕하세요 chan님 ㅎㅎ
void dfs함수에서 return이 두개가 있는데 각각 return을 하면 다시 main함수의 dfs(0,0)직후로 넘어가지는건가요
>>
void go(int y,int x){
visited[y][x] = 1;
if(a[y][x] == 1){
v.push_back({y,x});
return;
}
for(int i=0; i<4; i++){
int ny = y + dy[i];
int nx = x + dx[i];
if(ny < 0 || ny >= n || nx < 0 || nx >= m || visited[ny][nx])continue;
go(ny,nx);
}
return;
}여기서 return 이 두개가 있는데요.
상단 return : 기저사례를 나타냅니다. 만약 해당 부분에 요소가 1이라면 더이상 함수를 호출하지 않고 종료합니다.
하단 리턴 : 사실 아무 의미가 없습니다. void 타입은 아무것도 리턴하지 않음을 명시적으로 나타냅니다. 저기까지 도달한다는 의미는 기저사례에 안걸렸다는 의미로 저 for문이 동작하면서 아래의 dfs가 동작하게 된다는 의미입니다.
아니면 void dfs함수 내에 있는 if문의 return과 for문 바깥에 있는 return이 다른의미를 갖는건가요? void dfs함수 내의 return부분이 어디로 가는지 헷갈립니다.
>> return 은 똑같은 의미를 가집니다. return 은 함수를 종료시키면서 어떠한 값을 반환한다는 의미입니다.
int는 int타입을. ex) return 1;
void는 타입이 아닌 아무값도 아닌 것을 리턴하게 됩니다. ex) return;
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 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





