-
Notifications
You must be signed in to change notification settings - Fork 126
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[kayden] Week 05 Solutions #448
Changes from 6 commits
cdb6714
136a246
38f42a2
483f9c3
41e0e8c
3d2514c
83f14be
f415907
e23a34e
fdbc181
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,57 @@ | ||
class Solution: | ||
|
||
# 해시맵 | ||
# 시간복잡도: O(N^2) | ||
# 공간복잡도: O(N) | ||
def threeSum(self, nums: List[int]) -> List[List[int]]: | ||
n = len(nums) | ||
nums.sort() | ||
|
||
check = {} | ||
for idx, num in enumerate(nums): | ||
check[num] = idx | ||
|
||
answer = set() | ||
for i in range(n-2): | ||
if nums[i] > 0: | ||
break | ||
if i > 0 and nums[i] == nums[i-1]: | ||
continue | ||
for j in range(i + 1, n): | ||
target = -(nums[i] + nums[j]) | ||
if not check.get(target, None): | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 단순 질문
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 없습니다! 전자가 훨씬 읽기 좋네요! get(key, default)가 습관이 돼서 이렇게 작성했네요 |
||
continue | ||
if j >= check[target]: | ||
continue | ||
|
||
answer.add((nums[i], nums[j], target)) | ||
|
||
return list(answer) | ||
|
||
# 투포인터 | ||
# 시간복잡도: O(N^2) | ||
# 공간복잡도: O(N) | ||
def threeSum2(self, nums: List[int]) -> List[List[int]]: | ||
n = len(nums) | ||
nums.sort() | ||
|
||
answer = set() | ||
for i in range(n-2): | ||
if nums[i] > 0: | ||
break | ||
if i > 0 and nums[i] == nums[i-1]: | ||
continue | ||
l, r = i+1, n-1 | ||
while l<r: | ||
if nums[l] + nums[r] == -nums[i]: | ||
answer.add((nums[i], nums[l], nums[r])) | ||
l += 1 | ||
r -= 1 | ||
Comment on lines
+46
to
+49
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. '이렇게 하면 answer에 중복되는 triplet이 많이 쌓이고 answer를 list로 변환할 때 비효율적이지 않을까?' 싶어서 대안 코드도 써보고 검색도 해봤는데, 결과적으론 도긴개긴이었어요 ㅎㅎ if nums[l] + nums[r] == -nums[i]:
answer.add((nums[i], nums[l], nums[r]))
while True:
l += 1
if nums[l - 1] != nums[l]:
break
while True:
r -= 1
if nums[r + 1] != nums[r]:
break There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 투포인터에서도 최적화해야 했었는데 깜빡했네요! There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 도긴개긴 추가 ㅎㅎ 😂 if nums[l] + nums[r] == -nums[i]:
while l < r and nums[l] == nums[l + 1]:
l += 1
while low < high and nums[r] == nums[r - 1]:
r -= 1
l, r = l + 1, r - 1 There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 읽기 편해졌네요 👏 |
||
|
||
if nums[l] + nums[r] < -nums[i]: | ||
l += 1 | ||
|
||
if nums[l] + nums[r] > -nums[i]: | ||
r -= 1 | ||
|
||
return list(answer) |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
# 시간복잡도: O(N) | ||
# 공간복잡도: O(1) | ||
class Solution: | ||
def maxProfit(self, prices: List[int]) -> int: | ||
|
||
answer = 0 | ||
cur = float(inf) | ||
for price in prices: | ||
if cur < price: | ||
answer = max(answer, price - cur) | ||
|
||
if price < cur: | ||
cur = price | ||
|
||
return answer |
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,10 @@ | ||
# 시간복잡도: O(N*AlogA) A: 0<= strs[i]의 길이 <= 100 | ||
# 공간복잡도: O(N) | ||
class Solution: | ||
def groupAnagrams(self, strs: List[str]) -> List[List[str]]: | ||
groups = {} | ||
for anagram in strs: | ||
key = str(sorted(anagram)) | ||
groups.setdefault(key, []).append(anagram) | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. @obzva 같이 읽어보시면 도움이 될 만한 글 추천드려요. There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. 이런 좋은 블로그가 있네요 ^~^ |
||
|
||
return list(groups.values()) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
👍