Skip to content

Commit b367fb9

Browse files
authored
Merge pull request #1254 from ready-oun/week2/solutions
[ready-oun] WEEK 02 Solutions
2 parents b04be1c + b115762 commit b367fb9

File tree

4 files changed

+150
-0
lines changed

4 files changed

+150
-0
lines changed

โ€Ž3sum/ready-oun.java

+64
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,64 @@
1+
import java.util.Arrays;
2+
import java.util.ArrayList;
3+
import java.util.List;
4+
5+
class Solution {
6+
public List<List<Integer>> threeSum(int[] nums) {
7+
Arrays.sort(nums);
8+
List<List<Integer>> result = new ArrayList<>();
9+
10+
for (int i = 0; i < nums.length - 2; i++) {
11+
if (i > 0 && nums[i] == nums[i - 1]) continue;
12+
13+
int left = i + 1;
14+
int right = nums.length - 1;
15+
16+
while (left < right) {
17+
int sum = nums[i] + nums[left] + nums[right];
18+
19+
if (sum == 0) {
20+
21+
// result.add(Arrays.asList(nums[i], nums[left], nums[right]));
22+
List<Integer> triplet = new ArrayList<>();
23+
triplet.add(nums[i]);
24+
triplet.add(nums[left]);
25+
triplet.add(nums[right]);
26+
27+
result.add(triplet);
28+
29+
while (left < right && nums[left] == nums[left + 1]) left++;
30+
while (left < right && nums[right] == nums[right - 1]) right--;
31+
32+
left++;
33+
right--;
34+
35+
} else if (sum < 0) {
36+
left++;
37+
} else {
38+
right--;
39+
}
40+
}
41+
}
42+
return result;
43+
}
44+
}
45+
46+
/**
47+
Two pointers - fix 1 and use 2 ptrs
48+
nums[i] + nums[L] + nums[R] == 0
49+
no duplicates
50+
51+
1. sort array
52+
2. skip repeats
53+
- nums[i] == nums[i - 1]
54+
- nums[left] == nums[left + 1]
55+
- nums[right] == nums[right - 1]
56+
3. check if sum == 0
57+
4. move L right if sum < 0
58+
5. move R left if sum > 0 else
59+
60+
List<Integer>: [0, 0, 0]
61+
List<List<Integer>>: [[0, 0, 0], [-2, -3, 5]]
62+
nums.length - 2๊นŒ์ง€๋งŒ ๋ฐ˜๋ณต: for no out of bounds
63+
(last 2 val for left, right each)
64+
*/

โ€Žclimbing-stairs/ready-oun.java

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
class Solution {
2+
public int climbStairs(int n) {
3+
if (n <= 2) return n; // base cases
4+
5+
int first = 1; // f(1)
6+
int second = 2; // f(2)
7+
8+
// bottom-up dp: s to n
9+
for (int i = 3; i <= n; i++) {
10+
int current = first + second; // f(i) = f(i-1) + f(i-2)
11+
first = second; //
12+
second = current;
13+
}
14+
return second;
15+
}
16+
}
17+
18+
/**
19+
Fibonacci-like DP problem -> f(n) = f(n-1) + f(n-2)
20+
(n ๋ฒˆ์งธ ์นธ์— ์˜ค๋ฅด๋Š” ๋ฐฉ๋ฒ•์˜ ๊ฐœ์ˆ˜) = (n-1 ๋ฒˆ์งธ ์นธ์— ์˜ค๋ฅด๋Š” ๋ฐฉ๋ฒ•์˜ ๊ฐœ์ˆ˜) + (n-2 ๋ฒˆ์งธ ์นธ์— ์˜ค๋ฅด๋Š” ๋ฐฉ๋ฒ•์˜ ๊ฐœ์ˆ˜)
21+
- Time Complexity: O(n)
22+
loop from 3 to n once
23+
- Space Complexity: O(1)
24+
only 2 var are used
25+
*/
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,36 @@
1+
class Solution {
2+
public int[] productExceptSelf(int[] nums) {
3+
int n = nums.length;
4+
int[] answer = new int[n];
5+
6+
// prefix product
7+
answer[0] = 1;
8+
for (int i = 1; i < n; i++) {
9+
answer[i] = answer[i - 1] * nums[i - 1];
10+
}
11+
12+
// suffix product
13+
int suffix = 1;
14+
for (int i = n - 1; i >= 0; i--) {
15+
answer[i] *= suffix; // answer์˜ prefix์— ๊ณฑ -> ์ž๊ธฐ ์ž์‹  ์ œ์™ธํ•œ ์ „์ฒด ๊ณฑ ์™„์„ฑ
16+
suffix *= nums[i]; // suffix ๊ฐฑ์‹  (*nums[i] ๋ˆ„์ )
17+
}
18+
19+
return answer;
20+
}
21+
}
22+
23+
/**
24+
return int[] answer
25+
-> product of all nums except nums[i]
26+
27+
prefix -> answer[i] = nums[0] * nums[1] * ... * nums[i-1]
28+
answer[i-1] * nums[i-1] ๋กœ ์ ํ™”์‹ ํ‘œํ˜„.
29+
suffix -> suffix[i] = nums[i+1] * nums[i+2] * ... * nums[n-1]
30+
31+
MUST: O(n) time w/o division like total product / nums[i]
32+
33+
answer[i] = prefix[i] * suffix[i];
34+
but in O(1) extra space complexity
35+
-> no extra arr for suffix -> var suf *= nums[i] ๋กœ ๋ˆ„์ 
36+
*/

โ€Žvalid-anagram/ready-oun.java

+25
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,25 @@
1+
import java.util.Arrays;
2+
3+
class Solution {
4+
public boolean isAnagram(String s, String t) {
5+
// If len diff, they can't be anagram
6+
if (s.length() != t.length()) return false;
7+
8+
// convert to char arr & sort
9+
char[] sArr = s.toCharArray();
10+
char[] tArr = t.toCharArray();
11+
Arrays.sort(sArr);
12+
Arrays.sort(tArr);
13+
14+
// comp sorted arr
15+
return Arrays.equals(sArr, tArr);
16+
17+
// runtime: 4ms
18+
}
19+
}
20+
21+
/**
22+
* ์ •๋ ฌ 2๋ฒˆ โ†’ O(n log n)
23+
* ๋ฐฐ์—ด ๋น„๊ต โ†’ O(n)
24+
* ์ „์ฒด: O(n log n) (์„ฑ๋Šฅ์€ ๋‚˜์˜์ง€ ์•Š์Œ)
25+
*/

0 commit comments

Comments
ย (0)