inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

5-R

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

260

jsshin0201

작성한 질문수 8

0

안녕하세요!

 

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

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


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

감사합니다!

c++ 코딩-테스트

답변 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점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


코딩살구클럽 가입 문의

0

22

1

코딩 살구 클럽 컴파일 에러

0

15

1

추천 문제

0

17

1

코딩살구클럽 승인

0

21

1

코살구 1주차 1940번 문제 조건과 프라이빗 테스트 불일치 문의

0

30

2

문제를 고민하는 시간 관련

0

27

2

코딩살구클럽

0

42

2

코딩살구클럽 문의

0

44

2

코딩살구클럽 승인

0

37

2

DP 경우의 수 설명이 이해가 되지 않습니다.

0

35

2

3-F 채점 관련 질문

0

32

1

BFS, DFS 활용이 되는 상황에서의 방향성

0

34

2

코딩살구클럽 승인

0

46

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

56

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

66

2

안녕하세요~. 현재 코살코딩클럽 사이트가 접속이 안됩니다~

0

67

2

코딩살구클럽 로그인문제

0

85

3