일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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
- 데이터레이크
- 코딩인터뷰
- hackercup2017
- 박종천
- 개발7년차매니저1일차
- clean code
- 회고
- 실전사례
- 개발자로살아남기
- datalake
- 알고스팟
- wait region split
- 데이터야놀자
- Raw-Request-URI
- 2016년회고
- 데이터유통
- coursera
- 동시성
- 해커컵
- 2017회고
- spray
- 데이터플랫폼
- kafka
- 함수형 사고
- 테스트주도개발
- 단위테스트
- 켄트백
- 클린코드
- 개발자
- functional thinking
Archives
- Today
- Total
Software Engineering Note
최소, 최대 정사각형 찾기 2 본문
문제: MMRECT2 / 구현
MMRECT1 문제랑 똑같은데 점의 갯수가 최대 20,000 개까지 입력될 수 있다.
MMRECT1 처럼알고리즘으로 풀면 TLE를 면치 못하겠다.
해서, 메모리를 좀 이용하기로 했다.
해결전략
1. x좌표가 같은 점들을 한 곳에 모아놓는다. (map<key=x좌표, value=좌표 리스트>)
2. 루프를 돌면서 입력된 점을 하나씩 꺼내고, map에서 좌표리스트를 꺼낸다.
3. 좌표리스트를 돌면서 다음을 수행 (정사각형의 조건을 생각해보자)
- x좌표는 어차피 같으니까 y 차이를 구한다. (=dist)
- 좌표 p1, p2에서 같은 방향으로 dist만큼 떨어진 점이 있는지 찾아본다.
- 예를 들어, y 값이 2 차이나면 두 점의 왼쪽에 2만큼 떨어진 곳에 점이 있거나, 오른쪽으로 2만큼 떨어진 곳에 점이 있어야한다.
4. 정사각형 조건에 맞으면 최소,최대 값 갱신
결과적으로 필요한 좌표들만 검사하는 전략을 취했다.
코드: https://github.com/xgate/algospot/blob/master/IMPL/MMRECT2.cpp
'알고리즘 > 알고스팟' 카테고리의 다른 글
원주율 외우기 (0) | 2015.06.28 |
---|---|
최소, 최대 정사각형 찾기 1 (0) | 2014.12.27 |
Mismatched Parenthesis (0) | 2014.09.21 |
Weekly Calendar (0) | 2014.08.25 |
째능 교육 (0) | 2014.08.23 |