본문 바로가기

알고리즘

(179)
[LeetCode] 139. Word Break (Java) leetcode.com/problems/word-break/ Word Break - LeetCode Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview. leetcode.com ## 접근방법 어떤 문자열이, 단어들의 조합으로 만들어졌는지 확인하는 문제다. 문자열을 재귀적으로 함수를 단순하게 호출한다면, 시간초과가 발생한다. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 class Solution { HashSet hs = new HashSet(); pu..
[LeetCode] 77. Combinations (Java, 조합) leetcode.com/problems/combinations/ Combinations - LeetCode Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview. leetcode.com ## 접근방법 이 문제는 흔히 나오는 조합 문제이다. 지금까지 코드를 작성할 때, 단순히 재귀함수로 코드를 작성하도록 구현했었다. 시간이 20ms가 나와서, 다른 코드들을 참고해봤다. 다른 코드들을 보니, 지금가진 개수와 남은 개수들을 모두 써도 원하는 조합의 길이를 만들지 못한다면 탐색할 필요가 없다는 사실을 이용했다. 이 ..
[LeetCode] 43. Multiply Strings(Java, Multiply) leetcode.com/problems/multiply-strings/ Multiply Strings - LeetCode Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview. leetcode.com ## 접근방법 대부분의 수학문제들은 수학적 풀이 사고가 있다면 쉽게 해결할 수 있다. 곱셈을 배웠을 때를 기억해보자. 여러 자리 수의 곱셈을 할 때, 위에 길이가 긴 수를 두고 아래에 길이가 짧은 수를 두고 연산을 시작한다. 아래의 길이가 짧은 수를, 위의 수와 자릿수에 맞게끔 곱셈을 하고, 모든 과정에서 나온 ..
[leetcode] 199. Binary Tree Right Side View(Java, BFS) leetcode.com/problems/binary-tree-right-side-view/ Binary Tree Right Side View - LeetCode Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview. leetcode.com ## 접근방법 처음에 문제를 해석하다가, Right Side라고 해서 트리노드의 오른쪽 노드들을 출력하는줄 알았다 ㅠ... 하지만 그게 아니라, 트리를 오른쪽에서 바라봤을때 보이는 노드들을 출력하는 것이다. 즉, 같은 레벨에서 가장 오른쪽에 있는 노드들을 출력하면 된다. 우..
[leetcode] 33. Search in Rotated Sorted Array(Java, LogN, Binary Search) leetcode.com/problems/search-in-rotated-sorted-array/ Search in Rotated Sorted Array - LeetCode Level up your coding skills and quickly land a job. This is the best place to expand your knowledge and get prepared for your next interview. leetcode.com ## 접근방법 이 문제는 시간 복잡도가 logN이 되도록 문제를 풀어야 한다, 단순 선형 탐색으로 문제를 풀어도 정답은 되지만, 출제의도가 아니다. 우선 피벗을 기준으로, 정렬된 배열들이 섞이게 된다. 중요한 점은, 피벗을 기준으로 각자 정렬을 유지하고 있다는 것..
[HackerRank] Components in a graph(Java, union-find) ## 접근방법 우선 이 문제는 처음 접근 방법으로는 런타임 에러를 받았다. 런타임 에러는 인덱스 초과, 스택 오버 플로우 등의 이유로 발생한다. 스택 오버 플로우에 접근했었던 접근 방법에 대해서 알아보자. 스택 오버 플로우가 발생했던 접근 방법은 노드들을 전체 탐색하는 것이다. 물론 방문했던 노드들을 다시는 방문안하도록 체크하는 배열을 사용해도 스택 오버 플로우가 발생한다. 각 노드들에서 나머지 노드들을 모두 방문할 수 있으므로 시간복잡도는 N * N이 된다. 우선, 스택 오버 플로우가 발생하지 않으려면 함수의 재귀적 호출을 줄이거나 없애야 한다. 함수의 재귀적 호출을 없애는 것으로 문제를 풀어보자. 그래프에서 Union-Find라는 개념은 그래프에서 흔히 사용된다. 두 그래프를 합치고, 각 그래프의 부..
[HackerRank] Absolute Permutation(Java) www.hackerrank.com/challenges/absolute-permutation/problem?isFullScreen=true Absolute Permutation | HackerRank Find lexicographically smallest absolute permutation. www.hackerrank.com ## 접근방법 n과 k를 직접 정의하며 규칙을 발견해야 한다. k에 의해서 반복되는 패턴이 존재한다. 1은 1 + k, 2는 2 + k, 3은 3 + k ... 진행이 될 수 있다. 모든 수들은 일대일 매칭이 되어야 하므로, 1 + k는 1, 2 + k는 2, 3 + k는 3...이 되어야 한다. k에 의해서 반복되는 패턴의 수가 결정된다. n의 길이가 2 * k의 배수여야 위의 ..
[HackerRank] Self Balancing Tree(Java, 로테이션, 이진트리) www.hackerrank.com/challenges/self-balancing-tree/problem?isFullScreen=true Self Balancing Tree | HackerRank Insert values in a self balancing binary search tree. www.hackerrank.com ## 접근방법 이 문제는 기본적으로 AVL 트리에 대한 개념이 있어야 한다. AVL 트리가 나오게 된 개념부터 생각해보자. 트리는 자료를 저장하기 위한 자료구조이다. 트리는 높이만큼의 탐색 시간을 가지므로, 일반적으로 log의 시간복잡도의 탐색을 할 수 있다. 하지만 치우져친 트리가 완성된다면, 트리의 장점을 이용할 수 없게 된다. 그래서, 나오게된 개념이 AVL 트리라는 것이다. A..