일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 해커컵
- 단위테스트
- 동시성
- Raw-Request-URI
- 개발자
- kafka
- 함수형 사고
- 2017회고
- spray
- 켄트백
- datalake
- clean code
- hackercup2017
- 박종천
- 데이터플랫폼
- 데이터유통
- wait region split
- coursera
- 코딩인터뷰
- 데이터레이크
- 회고
- 알고스팟
- 테스트주도개발
- 클린코드
- 실전사례
- 개발7년차매니저1일차
- 데이터야놀자
- 개발자로살아남기
- 2016년회고
- functional thinking
Archives
- Today
- Total
Software Engineering Note
Fast Matrix Exponentiation 본문
문제: MATEXP / 분할정복
한 번에 한 번씩 계산해서는 시간내에 해결할 수 없다. 그렇다면? 반 씩 나누어서 계산하면 빠르게 해결할 수 있다.
1*1 행렬 계산을 해서 승수 2에 대한 값을 만들고, 다시 2*2를 해서 승수 4에 대한 값을 만들고.. 이런 식으로 하면 logN번만 계산하면 된다.
100 by 100 행렬 계산에 그리 큰 시간이 소요되지 않으므로, 행렬 계산은 단순하게 3중 loop로 처리했다.
총 복잡도는
코드: https://github.com/xgate/algospot/blob/master/DIV/MATEXP.cpp
'알고리즘 > 알고스팟' 카테고리의 다른 글
Coin Change (0) | 2014.08.07 |
---|---|
Endians (0) | 2014.08.07 |
N-Queen (0) | 2014.08.07 |
남극기지 (0) | 2014.08.05 |
Shisen-sho (0) | 2014.08.05 |