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
- 스택/큐
- BFS
- Level 4
- Level 2
- 코드리뷰
- 2019 KAKAO BLIND
- 백트래킹
- 삼성 SW 역량 테스트
- c++
- 코드 리뷰
- 2020 카카오 인턴십
- next_permutation
- 구현
- Gold 4
- Level 3
- 그리디
- Web
- DP
- 시뮬레이션
- DFS
- 월간 코드 챌린지
- pass
- level 1
- 2020 KAKAO BLIND
- 백준
- Gold 5
- SWEA
- 프로그래머스
- 브루트포스
- 부스트코스
Archives
- Today
- Total
Min:D's Devlog
[백준][삼성 SW 역량 테스트][Gold 4][C++] 15685 드래곤 커브 본문
문제
백준 삼성 SW 역량 테스트 기출 문제 - 15685 드래곤 커브 (Gold 4)
문제 풀이
접근 방식
정사각형의 네 꼭짓점이 모두 드래곤 커브의 일부인 정사각형의 개수를 구하는 문제이다.
드래곤 커브는 이전 세대의 커브를 시계 방향으로 90도 회전시켜 끝 점에 붙인 형태로 만들어진다.
우선, 이렇게 만들어지는 드래곤 커브에 규칙성이 있는지를 확인해보았다.
방향이 0으로 시작하는 커브의 경우 0 - 01 - 0121 - 01212321 - ... 의 형태로 만들어지는 것을 확인하였고,
이를 통해 다음 세대의 커브는 이전 세대의 값에 그 값을 뒤집어서 1씩 더해준 값을 합친 결과라는 것을 알게 되었다.
(방향이 0인 커브의 3세대 생성 과정 : 0121 + 0121을 뒤집은 값인 1210에 1씩 더한 값(2321) = 01212321)
그래서 주어진 드래곤 커브를 위의 규칙성을 활용하여 map에 그려주었고,
그 후 map에서 네 꼭짓점이 모두 드래곤 커브의 일부인 정사각형의 개수를 세어주어 답을 구하였다.
풀이 코드 - C++
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int main() {
// 입력 받기
int N;
cin >> N;
vector<vector<int>> dragon(N, vector<int>(4));
for (int i = 0; i < N; i++) {
for (int j = 0; j < 4; j++) {
cin >> dragon[i][j];
}
}
// 드래곤 커브 그리기
int map[101][101] = {0};
int dir[4][2] = {{0, 1}, {-1, 0}, {0, -1}, {1, 0}};
for (int i = 0; i < N; i++) {
int y = dragon[i][0];
int x = dragon[i][1];
int d = dragon[i][2];
int g = dragon[i][3];
map[x][y] = 1;
vector<int> DP;
DP.push_back(d);
for (int j = 0; j < g; j++) {
vector<int> temp = DP;
reverse(temp.begin(), temp.end());
int tlen = temp.size();
for (int t = 0; t < tlen; t++) {
temp[t] = (temp[t] + 1) % 4;
DP.push_back(temp[t]);
}
}
for (int k = 0; k < DP.size(); k++) {
int dx = dir[DP[k]][0];
int dy = dir[DP[k]][1];
x = x + dx;
y = y + dy;
map[x][y] = 1;
}
}
// 정사각형 개수 찾기
int answer = 0;
for (int i = 0; i < 100; i++) {
for (int j = 0; j < 100; j++) {
if (map[i][j] == 1) {
if (map[i][j + 1] && map[i + 1][j] && map[i + 1][j + 1])
answer++;
}
}
}
cout << answer;
}
실행 결과
'알고리즘 > 백준' 카테고리의 다른 글
[백준][삼성 SW 역량 테스트][Silver 3][C++] 14889 스타트와 링크 (0) | 2020.10.01 |
---|---|
[백준][삼성 SW 역량 테스트][Silver 1][C++] 14891 톱니바퀴 (0) | 2020.09.30 |
[백준][삼성 SW 역량 테스트][Gold 5][C++] 15684 사다리 조작 (0) | 2020.09.28 |
[백준][삼성 SW 역량 테스트][Gold 5][C++] 15686 치킨 배달 (0) | 2020.09.26 |
[백준][삼성 SW 역량 테스트][Gold 5][C++] 15683 감시 (0) | 2020.09.25 |
Comments