Hokusai

[10] 배열 돌리기1(16926) C++ 본문

알고리즘( C++ )/1. BOJ

[10] 배열 돌리기1(16926) C++

HOKUSAI 2019. 4. 1. 20:34
반응형

배열 돌리기 1 성공

시간 제한메모리 제한제출정답맞은 사람정답 비율

1 초 512 MB 136 80 64 61.538%

문제

크기가 N×M인 배열이 있을 때, 배열을 돌려보려고 한다. 배열은 다음과 같이 반시계 방향으로 돌려야 한다.

A[1][1] ← A[1][2] ← A[1][3] ← A[1][4] ← A[1][5] ↓ ↑ A[2][1] A[2][2] ← A[2][3] ← A[2][4] A[2][5] ↓ ↓ ↑ ↑ A[3][1] A[3][2] → A[3][3] → A[3][4] A[3][5] ↓ ↑ A[4][1] → A[4][2] → A[4][3] → A[4][4] → A[4][5]

예를 들어, 아래와 같은 배열을 2번 회전시키면 다음과 같이 변하게 된다.

1 2 3 4 2 3 4 8 3 4 8 6 5 6 7 8 1 7 7 6 2 7 8 2 9 8 7 6 → 5 6 8 2 → 1 7 6 3 5 4 3 2 9 5 4 3 5 9 5 4 <시작> <회전1> <회전2>

배열과 정수 R이 주어졌을 때, 배열을 R번 회전시킨 결과를 구해보자.

입력

첫째 줄에 배열의 크기 N, M과 수행해야 하는 회전의 수 R이 주어진다.

둘째 줄부터 N개의 줄에 배열 A의 원소 Aij가 주어진다.

출력

입력으로 주어진 배열을 R번 회전시킨 결과를 출력한다.

제한

  • 2 ≤ N, M ≤ 300
  • 1 ≤ R ≤ 1,000
  • min(N, M) mod 2 = 0
  • 1 ≤ Aij ≤ 108

예제 입력 1 복사

4 4 2 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16

예제 출력 1 복사

3 4 8 12 2 11 10 16 1 7 6 15 5 9 13 14

예제 입력 2 복사

5 4 7 1 2 3 4 7 8 9 10 13 14 15 16 19 20 21 22 25 26 27 28

예제 출력 2 복사

28 27 26 25 22 9 15 19 16 8 21 13 10 14 20 7 4 3 2 1

예제 입력 3 복사

2 2 3 1 1 1 1

예제 출력 3 복사

1 1 1 1

 

알고리즘 분류

  • DFS(깊이 탐색)

======================================================================================================

전형적인 BFS문제이다.

DFS를 시작하기 전에 어디서 시작해야하는지를 판단하는것이 제일 중요하다.

문제를 잘보면 외부 한 껍질(?)씩 돌리기 때문에 (1,1) => (2,2) =>(3,3) => .... 하는 식으로 탐색하면 된다.

나머지는 그냥 DFS로 풀면 된다.

코드는 아래와 같다. 

 

반응형

'알고리즘( C++ ) > 1. BOJ' 카테고리의 다른 글

[12] 드래곤 커브(15685) C++  (0) 2019.04.07
[11] 구슬 탈출2(13460) C++  (0) 2019.04.02
[9] 인구 이동(16234) C++  (0) 2019.03.31
[8] 치킨 배달(15686) C++  (0) 2019.03.28
[7] 주사위 굴리기 (14499) C++  (0) 2019.01.30
Comments