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
- 우리시대의역설
- LeetCode
- 토이프로젝트
- 밥무하마드
- DIY
- 코테
- 메일우유
- 제프딕슨
- 발더스3
- 취미
- 서울제빵소
- 메탈퍼즐
- 발더스모드
- 롱라이플
- 발더스게이트
- 게임
- 버즈2프로
- 코딩테스트
- javascript
- 맛집
- 바질토마토뭐시기
- 노노그램
- 송리단
- 누룽지소금빵
- 박주영판사
- 눈알빠지겠네
- 뜨아거
- 나쫌
- 미앤아이
- 알고리즘테스트
Archives
- Today
- Total
.Zzumbong
[leetCode/JS] 587. Erect the Fence 본문
문제 설명
You are given an array trees
where trees[i] = [xi, yi]
represents the location of a tree in the garden.
You are asked to fence the entire garden using the minimum length of rope as it is expensive. The garden is well fenced only if all the trees are enclosed.
Return the coordinates of trees that are exactly located on the fence perimeter.
입출력 예
Example 1:
Input: points = [[1,1],[2,2],[2,0],[2,4],[3,3],[4,2]]
Output: [[1,1],[2,0],[3,3],[2,4],[4,2]]
Example 2:
Input: points = [[1,2],[2,2],[4,2]]
Output: [[4,2],[2,2],[1,2]]
Constraints
1 <= points.length <= 3000
points[i].length == 2
0 <= xi, yi <= 100
- All the given points are unique.
솔루션
- 좌표의 합으로 min, max를 구해서 정답을 도출했지만 예제1의 [4,2], [3,3], [2,4] 같이 같은 선상에 있는 점들을 찾을 수 없어서 결국 못풀었다.
- 서칭해보니 3개의 점을 받아서 각도 180도가 넘지 않는 점들을 감싸는 알고리즘이 필요했다.
- 자세한 해석을 보니 음.. 대수학이 필요했다. 쥐엔장 괜히
Hard
가 아니구나! - 알고리즘
- 알고리즘 GIF
- leetCode해석
const outerTrees = (trees) => {
trees.sort((x, y) => {
if (x[0] == y[0]) return x[1] - y[1];
return x[0] - y[0];
});
let lower = [], upper = [];
for (const tree of trees) {
while (lower.length >= 2 && cmp(lower[lower.length - 2], lower[lower.length - 1], tree) > 0) lower.pop();
while (upper.length >= 2 && cmp(upper[upper.length - 2], upper[upper.length - 1], tree) < 0) upper.pop();
lower.push(tree);
upper.push(tree);
}
return [...new Set(lower.concat(upper))];
};
const cmp = (p1, p2, p3) => {
let [x1, y1] = p1;
let [x2, y2] = p2;
let [x3, y3] = p3;
return (y3 - y2) * (x2 - x1) - (y2 - y1) * (x3 - x2);
};
감상평
- 어렵따!
easy
문제를 하나 풀어서 머리를 식히고 랜덤 돌려야겠다.
'coding test > leetCode' 카테고리의 다른 글
[lettCode/JS] 36. Valid Sudoku (0) | 2022.11.23 |
---|---|
[leetCode/JS] 9. Palindrome Number (0) | 2022.11.23 |
[leetCode/JS] 696. Count Binary Substrings (0) | 2022.11.23 |
[leetCode/JS] 1360. Number of Days Between Two Dates (0) | 2022.11.23 |
[leetCode/JS] 263. Ugly Number (0) | 2022.11.23 |
Comments