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
- DFS
- Backtracking
- 우아한테크캠프
- TypeScript
- react
- 프레임워크
- BFS
- Database
- 우아한형제들
- 연습문제
- Vue
- BAEKJOON
- codeground
- SQL
- Spring
- 탐색알고리즘
- JavaScript
- BOJ
- Java
- Vue.js
- 단위테스트
- framework
- springboot
- mobx
- 웹프로그래밍
- 백준
- 데이터베이스
- JPA
- 알고리즘
- Algorithm
Archives
- Today
- Total
설모의 기록
[백준 14891] 톱니바퀴 본문
이 문제는 4개의 톱니바퀴가 연쇄적으로 회전한 후의 점수를 산출하는 문제입니다.
4개의 톱니바퀴는 각각 8개의 톱니를 갖고 있으며 N 또는 S극입니다. 하나의 톱니바퀴를 회전하면 위의 그림과 같이 다른 톱니와 맞닿아 있는 부분이 다른 양 옆의 톱니도 반대방향으로 회전하고, 그 톱니들의 양 옆도 맞닿아 있는 부분이 다르다면 연쇄적으로 회전을 하게 됩니다.
그림이 어지럽게 그려져서 그렇지, LinkedList로 생각하면 쉽습니다. 시계방향으로 회전하는 것은 리스트의 마지막 요소를 뺴와 첫번째 인덱스에 추가하는 것이고, 반시계방향으로 회전하는 것은 리스트의 첫번째 요소를 빼와 마지막에 추가하는 것과 같습니다. 그리고 회전하기 전에 각각의 톱니바퀴가 양 옆의 톱니바퀴와 맞닿아 있는 곳이 같은지를 체크해주고, 회전해야 할 톱니바퀴를 회전한 후에 연쇄적으로 회전시키면 됩니다.
저는 우선 톱니바퀴 상태를 입력받은 후에, 입력받은 회전수 K만큼 for문을 돌면서 Relations 들을 설정하고 움직이려는 톱니바퀴를 움직인 뒤 이웃들을 움직이도록 했습니다. 우선 Relation 클래스로 인스턴스를 3개 만들어 각 톱니바퀴 사이의 맞닿은 부분이 같은지 다른지를 저장했습니다. 그 후 해당 톱니바퀴를 회전한 뒤, 재귀함수를 통해 이웃들을 연쇄적으로 회전시켰습니다. 회전시킬 톱니바퀴를 1 ~ 4 로 입력받지만, 인덱스와 헷갈리지 않기 위해 -1 씩 해서 0 ~ 3 톱니바퀴로 바꿨다는 점 알아주세요!
'알고리즘' 카테고리의 다른 글
[백준 14503] 로봇청소기 (1) | 2018.04.14 |
---|---|
[백준 14890] 경사로 (3) | 2018.04.12 |
[codeground 연습문제 4] 다트게임 (0) | 2018.04.10 |
[codeground 연습문제 3] 시험공부 (0) | 2018.04.10 |
[codeground 연습문제 2] 프로그래밍 경진대회 (0) | 2018.04.10 |