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

jsshin0201님의 프로필 이미지
jsshin0201

작성한 질문수

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

5-R

[5_R]문제해설에서 100의 의미가 무엇인가요?

작성

·

200

0

안녕하세요!

 

문제 해설 : http://boj.kr/db0d13a9155748f38feda4624064efd9

에서, move함수나 ismal함수에 '인덱스가 100이면' 이라는 조건이 있는데 이 부분이 잘 이해가 안됩니다. ㅜㅜ.


말이 윳놀이 판에서 통과한 경우를 의미하신건가요??
만약 그렇다면, 다른 값이 아니라 100이라고 주신 이유가 있나요?

감사합니다!

답변 1

0

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

안녕하세요 ㅎㅎ

말이 윳놀이 판에서 통과한 경우를 의미하신건가요??

>> 네 맞습니다. 판에서 벗어나는 경우를 의미합니다.

 

만약 그렇다면, 다른 값이 아니라 100이라고 주신 이유가 있나요?
>> 판에서 벗어나는 특정값으로 하기만 하면 됩니다. 100은 제 스타일인데요. ㅎㅎ

일단 제가 만든 맵을 보면 1 ~ 31까지의 번호를 적어서 구현을 했죠?

그 외의 번호로 한 것이다 라고 보시면 됩니다.

 

참고로 100이아닌 이렇게 하셔도 됩니다.

#include<bits/stdc++.h>
using namespace std; 
const int INF = 987654321;
int a[14], mal[4], n = 10;
int v[104]; 
vector<int> adj[54]; 
int move(int here, int cnt){  
	if(here == 1201) return 1201; 
	if(adj[here].size() >= 2){
		here = adj[here][1]; cnt--; 
	} 
	if(cnt){
		queue<int>q; 
		q.push(here); 
		int there; 
		while(q.size()){
			int x = q.front(); q.pop(); 
			there = adj[x][0];
			q.push(there); 
			if(there == 1201)break;
			cnt--;   
			if(cnt == 0)break;
		}
		return there; 
	}else return here; 
}
bool isMal(int mal_idx, int idx){
	if(mal_idx == 1201) return false; 
	for(int i = 0; i < 4; i++){ 
		if(i == idx) continue; 
		if(mal[i] == mal_idx) return true; 
	}
	return false; 
}
void add(int here, int there){
	adj[here].push_back(there); 
}
void setMap(){
	for(int i = 0; i <= 19; i++) add(i, i + 1); 
	add(5, 21); add(21, 22); add(22, 23); add(23, 24); 
	add(15, 29); add(29, 30); add(30, 31);add(31, 24); 

	add(10, 27); add(27, 28); add(28, 24); add(24, 25); 
	add(25, 26); add(26, 20); add(20, 1201);  

	v[1] = 2; v[2] = 4;  v[3] = 6; v[4] = 8; v[5] = 10; 
	v[6] = 12; v[7] = 14; v[8] = 16; v[9] = 18; v[10] = 20; 
	v[11] = 22; v[12] = 24; v[13] = 26; v[14] = 28; v[15] = 30; 
	v[16] = 32; v[17] = 34; v[18] = 36; v[19] = 38; v[20] = 40; 
	v[21] = 13; v[22] = 16; v[23] = 19;  v[24] = 25; 
	v[27] = 22; v[28] = 24; v[25] = 30; v[26] = 35; 
	v[29] = 28; v[30] = 27; v[31] = 26; 
}
int go(int here){ 
	if(here == n) return 0; 
	int ret = 0; 
	for(int i = 0; i < 4; i++){
		int temp_idx = mal[i];
		int mal_idx = move(temp_idx, a[here]);   
		if(isMal(mal_idx, i)) continue;    
		mal[i] = mal_idx;  
		ret = max(ret, go(here + 1) + v[mal_idx]); 
		mal[i] = temp_idx; 
	} 
	//cout << "RET : " << ret << "\n";
	return ret; 
}
int main(){
    ios_base::sync_with_stdio(false);
    cin.tie(NULL); cout.tie(NULL);setMap(); 
	for(int i = 0; i < n; i++) cin >> a[i]; 
	cout << go(0) << "\n"; 
    return 0;
}

참고로 1201은 제 생일입니다.

 

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

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

감사합니다.

강사 큰돌 올림.


jsshin0201님의 프로필 이미지
jsshin0201

작성한 질문수

질문하기