Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- Java
- 알고리즘
- 자바스크립트 이벤트처리
- 알고리즘 그래프
- char to str
- 자바스크립트 이벤트중지
- 자바
- parseInt()
- 서로소
- 자바입출력
- java 내부 클래스
- inner class
- 상속
- 자바 재귀 조합
- java lambda
- 순열 재귀
- Interface
- 조합 재귀
- 순열코드
- 자바 순열 코드
- java Collections.sort()
- 재귀
- jquery 필터선택자
- jquery 속성선택자
- 후위표기
- 자바 조합 재귀
- str to char array
- jquery 이벤트 처리
- jquery dom 계층 선택자
- 재귀함수
Archives
- Today
- Total
유블로그
BOJ 17825 주사위윷놀이 java 자바 본문
BOJ 17825 주사위윷놀이 java 자바
https://www.acmicpc.net/problem/17825
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class BOJ_17825_주사위윷놀이 {
static class Node {
int number, score, start, next;
public Node(int number, int score, int next) {
this.number = number;
this.score = score;
this.next = next;
start = -1;
}
public Node(int number, int score, int start, int next) {
this.number = number;
this.score = score;
this.start = start;
this.next = next;
}
}
static int[] diceNums = new int[10];
public static void main(String[] args) throws Exception {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer st = new StringTokenizer(br.readLine());
for (int i = 0; i < 10; i++) {
diceNums[i] = Integer.parseInt(st.nextToken());
}
solve(0, 0, new int[] {0,0,0,0});
System.out.println(MAX);
} // main
static int MAX = 0;
private static void solve(int turn, int score, int[] markers) {
if(turn == 10) {
if(MAX < score) MAX = score;
return;
}
for (int i = 0; i < 4; i++) {
if(markers[i] >= 32) continue;
int dice = diceNums[turn];
int nextNum;
if(nodes[markers[i]].start > 0) {
nextNum = nodes[markers[i]].start;
} else {
nextNum = nodes[markers[i]].next;
}
if(nextNum >= 32) {
int[] copy = new int[4];
for (int k = 0; k < 4; k++) {
copy[k] = markers[k];
}
copy[i] = nextNum;
solve(turn+1, score, copy);
continue;
}
dice--;
boolean isEnd = false;
while(dice > 0) {
nextNum = nodes[nextNum].next;
if(nextNum >= 32) {
isEnd = true;
int[] copy = new int[4];
for (int k = 0; k < 4; k++) {
copy[k] = markers[k];
}
copy[i] = nextNum;
solve(turn+1, score, copy);
break;
}
dice--;
}
if(isEnd) continue;
boolean isSuccess = true;
for (int j = 0; j < 4; j++) {
if(i == j) continue;
if(markers[j] == nextNum) {
isSuccess = false;
break;
}
}
if(isSuccess) {
int[] copy = new int[4];
for (int k = 0; k < 4; k++) {
copy[k] = markers[k];
}
copy[i] = nextNum;
solve(turn+1, score+nodes[nextNum].score, copy);
}
} // i
// 10 턴 까지 다 못가고 모든 말이 도착하는 경우 때문에 추가
if(MAX < score) MAX = score;
} // solve
static Node[] nodes = {
new Node(0,0,1),
new Node(1,2,2),
new Node(2,4,3),
new Node(3,6,4),
new Node(4,8,5),
new Node(5,10,6,10),
new Node(6,13,7),
new Node(7,16,8),
new Node(8,19,9),
new Node(9,25,29),
new Node(10,12,11),
new Node(11,14,12),
new Node(12,16,13),
new Node(13,18,14),
new Node(14,20,15,17),
new Node(15,22,16),
new Node(16,24,9),
new Node(17,22,18),
new Node(18,24,19),
new Node(19,26,20),
new Node(20,28,21),
new Node(21,30,22,25),
new Node(22,28,23),
new Node(23,27,24),
new Node(24,26,9),
new Node(25,32,26),
new Node(26,34,27),
new Node(27,36,28),
new Node(28,38,31),
new Node(29,30,30),
new Node(30,35,31),
new Node(31,40,32)
};
}
말판을 어떻게 만들까하다가 그냥 열심히..^^ 만들었다
말판의 땅 하나당 숫자 하나씩 내 맘대로 부여했고 교차점 5, 10, 20 에는 start 라는 변수로 그 곳에서 출발하는 말은 start 로 이동할 수 있게 했다.
원래 연결리스트로 만드려고 Node라는 class 를 만들었으나 번호를 부여할거면 그냥 배열로 하는 게 더 편할 것 같아 Node 배열을 만들었다.
solve는 가능한 모든 말을 다 이동시켜보는 재귀함수다. 현재 턴, 점수, 말들의 위치를 들고다닌다.
모든 말을 이동시켜보며 도착지 32번(내가 임의로 부여한 수) 가 넘은 말은 이동하지 않는다.
지금 생각해보니 그냥 5, 10, 20이 있는 땅에선 따로 방향을 바꿔주는 배열을 하나 뒀으면 저렇게 하드 코딩으로 안 할 수 있었지 않을까.. 하하
'알고리즘' 카테고리의 다른 글
BOJ 1707 이분그래프 java 자바 bfs dfs 두 가지 방법 (0) | 2021.08.09 |
---|---|
BOJ 2606 바이러스 java 자바 (0) | 2021.07.27 |
BOJ_16235_나무재테크 java 자바 (0) | 2021.07.03 |
BOJ 9019 DSLR java 자바 (0) | 2021.06.20 |
BOJ 1717 집합의 표현 java 자바 (0) | 2021.06.20 |