inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

BOJ 16935 - 배열 돌리기 3

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

해결된 질문

132

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

29

2

코딩살구클럽 로그인문제

0

26

3

OEM에서 하는 A-SPICE

0

22

2

코딩 살구 클럽 로그인 문제

0

52

2

2-J 채점관련 질문

0

43

3

Part2 기출 문제 및 해설 자료 파일 없음 형태

0

43

2

코딩 살구 클럽 Python 지원 가능 여부

0

55

1

살구클럽 아이디 없음 문제

0

62

1

1-O 코딩살구클럽 채점관련 질문

0

49

2

히든 테스트 케이스가 사라졌습니다

0

45

1

38번 문제 보기 3,4번

1

34

3

14번 문제

1

40

2

채점서버 혹시 다른 언어 지원도 가능하게 해주실 수 있나요

1

60

2

살구 클럽 채점 관련 문의(테스트 케이스)

0

57

2

1-H 문제 채점하기 오류

0

50

3

코딩살구클럽 2주차 2-L 문제 채점하기 오류

0

47

2

살구 클럽 채점 관련 문의

0

56

2

코딩 살구 클럽 실전 세션

0

52

2

코딩살구클럽 채점 관련 질문

0

45

2

모바일 앱 쿠폰

0

41

1

SQL 기본 문법

0

41

2

Visual studio 2017 을 설치할 수 없어요

0

88

2

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

1

117

2

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

2

160

1