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
- Ubuntu 20.04
- MySQL
- 우분투
- 20.04
- 프레임워크
- C
- 우분투 20.04
- php
- 라라벨
- 제주도
- 옵티머스g
- 라즈비안
- 라즈베리파이
- ubuntu
- FMS
- TiL
- 셀레니움
- upbit
- codeigniter
- 옵티머스 g
- 맥
- 옵지
- 맛집
- Selenium
- 옵G
- 회고
- Raspberry Pi
- 코드이그나이터
- Laravel
- 업비트
Archives
- Today
- Total
평범한 이야기들
[C]행렬의 이동 - Matrix 본문
728x90
행렬의 이동 - 어떻게 말을 해야할지 몰라서 대충 불렀다.
행렬이 있으면 네모난 상자를 오른쪽으로 90' 또는 왼쪽으로 90' 돌려서 출력이 되는 프로그램이다.
이 프로그램을 만든 계기는.. 단지.. 책의 한 문제였기 때문이며 다들 C를 처음 배울때
이와 같은 문제를 풀지 않을까 생각이 들어서 이다.
여기서 나는 4 X 4 행렬을 기준으로 했다.
행렬의 이동
ex) -> 우측90' ->우측90'
1 2 3 4 13 9 5 1 16 15 14 13
5 6 7 8 14 10 6 2 12 11 10 9
9 10 11 12 15 11 7 3 8 7 6 5
13 14 15 16 16 12 8 4 4 3 2 1
1 2 3 4 13 9 5 1 16 15 14 13
5 6 7 8 14 10 6 2 12 11 10 9
9 10 11 12 15 11 7 3 8 7 6 5
13 14 15 16 16 12 8 4 4 3 2 1
필요한 함수-
꼭 함수를 써야되는건 아니지만 편의를 위해서 사용.
void lchange(void); //왼쪽으로 90' 돌리는 함수
void rchange(void); //오른쪽으로 90' 돌리는 함수
void print(void); //출력 함수
void lchange(void); //왼쪽으로 90' 돌리는 함수
void rchange(void); //오른쪽으로 90' 돌리는 함수
void print(void); //출력 함수
그럼 이 프로그램에서 중요한건 무엇인가 보자.
우측 또는 좌측으로 돌렸을때를 가정으로 본다면 첫행의 이동경로를 보자
이동경로
우측 좌측
a(0,0) -> a'(0,3) a(0,0) -> a'(3,0)
b(0,1) -> b'(1,3) b(0,1) -> b'(2,0)
c(0,2) -> c'(2,3) c(0,2) -> c'(1,0)
d(0,3) -> d'(3,3) d(0,3) -> d'(0,0)
a(0,0) -> a'(0,3) a(0,0) -> a'(3,0)
b(0,1) -> b'(1,3) b(0,1) -> b'(2,0)
c(0,2) -> c'(2,3) c(0,2) -> c'(1,0)
d(0,3) -> d'(3,3) d(0,3) -> d'(0,0)
이렇게 나온다. 여기서 수식이 성립이 된다. (이해를 못하셨다면 한번 더 진행된것을 써보고 생각해보라.)
규칙
우측 좌측
a(i,j) -> a'(j,3-i) a(i,j) -> a'(3-j,i)
a(i,j) -> a'(j,3-i) a(i,j) -> a'(3-j,i)
위의 정보를 가지고 코딩 후 컴파일을 해본다.
항상 그래왔지만 지저분한 소스코드.
부족한 실력으로 프로그래밍 하는것도 정말 //
언제쯤 잘 할 수 있을라나./
728x90
Comments