인프런 커뮤니티 질문&답변

축구하는야채볶음밥님의 프로필 이미지
축구하는야채볶음밥

작성한 질문수

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

3주차개념 #2. 완탐과 원복

질문있습니다.

작성

·

148

0

문제 : 긍정왕 홍철이의 구걸 여행

제가 코드는 다 맞았는데 ny,nx를 전역변수로 해주니 값이 다르던데 왜 다른지 잘 모르겠습니다.

보통 ny,nx는 지역변수로 해줘야 하나여?

#include <bits/stdc++.h>

using namespace std;

int a[3][3] = {{10,20,21},{70,90,12},{80,110,120}};

const int dy[] = {-1,0,1,0};

const int dx[] = {0,1,0,-1};

int visited[3][3];

int ny, nx;

vector<int> v;

void print() {

for(int i : v) cout << i << ' ';

cout << '\n';

}

void dfs(int y, int x) {

visited[y][x] = 1;

v.push_back(a[y][x]);

if(y == 2 && x == 2) {

print();

return;

}

for(int i = 0 ; i < 4 ; i++) {

ny = y + dy[i];

nx = x + dx[i];

if(ny < 0 || ny >= 3 || nx < 0 || nx >= 3) continue;

if(visited[ny][nx]) continue;

dfs(ny,nx);

visited[ny][nx] = 0;

v.pop_back();

}

}

int main() {

dfs(0,0);

}

답변 1

0

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 승우님 ㅎㅎ

해당 부분은 제가 강의로 만들었습니다. ㅎㅎ

강의 내의

맞왜틀팁 : 전역변수를 사용할 때 주의할 점 | 3-Q 보완설명

를 참고해주세요. ㅎㅎ

 

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


축구하는야채볶음밥님의 프로필 이미지
축구하는야채볶음밥

작성한 질문수

질문하기