inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

SW 역량테스트 합격하기 A형 with C++ (Advanced Algorithm)

BOJ 16935 - 배열 돌리기 3

(반)시계 회전 함수의 N, M 처리 방식

해결된 질문

140

xeexae0808

작성한 질문수 1

0

안녕하세요, BOJ 16935번 문제를 풀던 중 시계 방향 회전(clockwise)반시계 방향 회전(counterClockwise) 함수의 구현 방식 차이에 대해 헷갈리는 부분이 있어 질문드립니다. (강의 6:22)

// 시계 방향 회전

void clockwise() {

copyMAP(temp, MAP);

int t = N; N = M; M = t;

for (int r = 1; r <= N; r++) {

for (int c = 1; c <= M; c++) {

MAP[r][c] = temp[M + 1 - c][r];

}

}

}

// 반시계 방향 회전

void counterClockwise() {

copyMAP(temp, MAP);

int t = N; N = M; M = t;

for (int r = 1; r <= N; r++) {

for (int c = 1; c <= M; c++) {

MAP[r][c] = temp[c][N + 1 - r];

}

}

}

궁금한 점은,

이 부분이 좀 헷갈려서 질문 드립니다. 감사합니다.

c++ 코딩-테스트 소프트웨어-테스트 알고리즘

답변 1

0

피로물든딸기

안녕하세요!

회전 전, 후 (N, M) 기준으로 생각하는 것보다, row와 col의 범위를 보고 생각하시면 편할 것 같습니다.

clockwise에서 for문의 c의 범위는 1부터 M까지이니 M + 1 - c가 되어야하고,

counterClockwise에서 r의 범위가 1부터 N이니 N + 1 - r이 됩니다.

 

그래서 회전 전,후를 기준으로 N과 M을 그대로 쓰냐, 바꿔서 쓰냐는 관계가 없습니다.

input.txt에 N x M 배열을 입력해서 N이나 M을 바꿔보면서 결과를 보시면 더 이해가 잘 되실 것 같습니다.

 

또 문의사항이 있으면 답변 드리겠습니다.

 

감사합니다.

추천 문제

0

2

1

Replit 강의 자료가 안나와요

0

6

1

코딩살구클럽 승인

0

5

1

이 강의를 다 들으면 어떤 강의를 들어야 하나요?

0

15

2

선생님 13.3을 써도 큰 차이가 없나요?

0

18

2

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

0

17

2

Replit UI 변경으로 인한 실습 진행 문의

1

23

1

문제를 고민하는 시간 관련

0

25

2

코딩살구클럽

0

38

2

코딩살구클럽 문의

0

36

2

코딩살구클럽 승인

0

35

2

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

0

33

2

안녕하세요 선생님

0

31

2

코딩 문제 사이트 접속 오류

0

28

1

3-F 채점 관련 질문

0

31

1

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

0

33

2

코딩살구클럽 승인

0

44

2

코딩살구클럽승인

0

39

3

코딩살구클럽 승인

0

53

2

3-D 관련 질문

0

35

2

코살구 회원가입 문의

0

45

2

Visual studio 2017 을 설치할 수 없어요

0

96

2

안녕하세요 선생님 코드트리 원자충돌(2020 하반기 오전 2번)에서 질문 있습니다.

1

129

2

BOJ 2234 성곽 문제 코드에서 질문 있습니다.

2

175

1