Grind75: medium and easy problems

Grind75: medium and easy problems

task id: grind75

2024-09-26 09:33: Grind75 #grind75 #timelog:01:25:41

Tasking this out now, as well as timing it.

542, 973

2024-09-27 13:41: Grind75 #grind75 #timelog:01:41:23

2024-09-27 16:47: 3summing research #grind75 #timelog:00:47:50

What's tough here is the acceptance criteria. It needs to be 3 unique indices and the combination itself needs to be unique. Having the nested 3-loop is cleaner because the variables are in scope. Doing it with the backtracking approach requires cramming data in the recursive function.

dead end. Moving on

2024-09-27 17:17: 3sum: looking at the editorial #grind75

The loops are moved around and hidden, but there still seems to be 3 distinct loops. The thing that's interesting (ish) here is that they are treating the problem as an extension of twosum, and re-using that logic, calling a version of twosum inside of 3sum.

2024-09-27 17:25: wait wikipedia has a whole page on 3sum #grind75

I like their algorithm, which looks the two-pointer in the editorial.

2024-09-30 09:25: Grind75 #grind75 #timelog:01:30:00

2024-10-01 11:01: Grind75 #grind75 #timelog:01:08:04

I hate when people talk in the library. I can't focus.

This graph problem isn't clicking for me yet (LC 207). Grr. Taking a break.

2024-10-01 13:20: Grind75-ing #grind75 #timelog:01:50:13

2024-10-02 09:49: Grind75 #grind75 #timelog:01:03:30

Attempting that coin change problem again, among other things.

2024-10-03 13:00: Grind75 #grind75 #timelog:01:33:13

Per the recommendation of several people, I am going to just the Leetcode website to write code. It has the verification and eveything, and will help me pick up on weird edge cases.

2024-10-05 10:17: Grind75 #grind75 #timelog:01:23:34

39 (combination sum) is a backtracking problem that I am not understanding properly.

2024-10-05 14:53: The grind continues. #grind75 #timelog:02:18:10

I did 46, poorly. 39 passed when I used a different data structure.

2024-10-06 10:02: Grind75 #grind75 #timelog:01:37:11

Uh oh, I've just been running locally. I've been forgetting to submit stuff. I knew things were feeling wrong.

56, 981

2024-10-06 12:46: Grind75 #grind75 #timelog:02:37:49

2024-10-06 17:14: See if I can re-implement 236 #grind75 #timelog:01:02:24

Even with the editorial in my face, it still took me an hour to implement. jeez.

2024-10-21 09:25: Grind75 #grind75 #timelog:01:44:04

2024-10-22 10:20: Grind75 #grind75 #timelog:00:30:00

Pen and paper

2024-10-22 11:14: Grind75 #grind75 #timelog:01:58:40

Coding it up

2024-10-22 12:56: Wow this is taking a while. Ugh. #grind75

2024-10-22 13:24: Finally. #grind75

Only took me 2.5 hours.

2024-10-24 10:05: Grind75 #grind75 #timelog:02:02:58

2024-10-25 11:26: Grind75 #grind75 #timelog:00:21:58

2024-10-25 14:24: Grind75 #grind75 #timelog:01:38:51

2024-10-26 09:26: Grind75 #grind75 #timelog:01:07:57

2024-10-26 15:42: Grind75 #grind75 #timelog:01:11:09

2024-10-26 18:35: Grind75 #grind75 #timelog:00:20:40

2024-10-28 10:52: Grind75 #grind75 #timelog:01:01:11

2024-10-28 14:32: Grind75 #grind75 #timelog:01:08:29

2024-10-28 20:17: Grind75 #grind75 #timelog:00:03:57

2024-11-01 08:05: Grind75 #grind75 #timelog:00:24:30

2024-11-01 19:37: Grind75 #grind75 #timelog:00:12:36

2024-11-05 10:03: Grind75 #grind75 #timelog:01:20:00

2024-11-06 11:58: Grind75-ing #grind75 #timelog:00:19:18

Just want to get that last problem working (LC 310: minimum height trees)

2024-11-11 10:38: Grind75 #grind75 #timelog:01:03:56

I'm trying to grok this findMinHeightTrees problem better. Also, LC 739 (Daily Temperatures)

2024-11-12 09:45: Grind75 #grind75 #timelog:00:24:40

198: House Robber

2024-11-12 10:37: Grind75 #grind75 #timelog:00:40:00

134: Gas Station

2024-11-12 12:53: Grind75 #grind75 #timelog:00:39:44

134: Gas Station (Continued) #grind75

2024-11-12 14:26: Grind75 #grind75 #timelog:00:41:26

More Gas Station (134)

2024-11-12 17:35: Grind75 #grind75 #timelog:00:58:25

Gas Station, again (134). I thought it was dynamic programming. It was not. Another day wasted. I will have to look at this: https://www.youtube.com/watch?v=lJwbPZGo05A.

2024-11-13 09:33: Grind75 #grind75 #timelog:00:15:00

Watching the neetcode video.

2024-11-13 10:48: Grind75 #grind75 #timelog:00:41:52

36: Valid Sudoku

2024-11-13 12:34: Grind75 #grind75 #timelog:00:13:00

49: Group anagrams

2024-11-13 12:49: 152: Maximum Product Subarray #grind75 #timelog:00:51:16

152: maximum product subarray

2024-11-14 10:31: Grind75 #grind75 #timelog:01:27:44

211: Design and Search Words Data Structure. I think it's a Trie problem. Spent most of this time just getting the Trie structure the way I imagined it. Have not implemented the search yet, which I believe will be a DFS using a stack (for backtracking when a '.' is encountered).

2024-11-14 12:56: 211 continued #grind75 #timelog:01:12:21

Ran out of time. Right data struture (trie), but my search doesn't work properly ('..' is a problem on the huge edge case).

2024-11-14 14:23: wait wait, one idea to try. #grind75 #timelog:00:28:15

I'm breaking out too early.

Nevermind. I'm not getting it right. Time to stop.

2024-11-15 10:32: Read up on 211 #grind75 #timelog:01:18:31

Ah. I was not making a Trie in my original implementation. I only kept track of possible combinations for each position, which was more efficience memory-wise, but it did not keep track of paths between unique words.

Example: "dig" and "dog" show up as (d (o (g)) (i (g))) There are two g's here. My structure represented the set as ([d], [o i], [g]).

If I were to add "mop" to the the structure. A trie would look like: = ((m (o (p)) (d (o (g)) (i (g)))) = My structure would look like: = ([m d] [o i] [g p]) = There's no way to tell if "mip" is a valid path or not

Even with pointers, "mog" could be valid with this path. = ([m:[o] d:[o i]] [o:[g p] i:[g]] [g p]) =

2024-11-15 16:55: Grind75 #grind75 #timelog:01:07:04

417: Pacific Island Water Problem. I think I am close. It seems to lend itself well to a dynamic programming problem, but I turned up an edge case where I wasn't checking in all the available directions. Will look into that later.

2024-11-16 08:53: Finishing up LC417 #grind75 #timelog:00:41:32

I'm hoping I just need to code up an edge case and that my overall solution is solid.

2024-11-16 09:06: LC417: They wanted you to use BFS or DFS, not dynamic programming #grind75

My edge case isn't working.

2024-11-16 09:14: I just bought a year of premium. #grind75

If I do 6 months, it'll be cheaper than the monthly rate.

2024-11-16 09:36: Onto LC19 #grind75 #timelog:00:28:14

Remove Nth node from linked list

2024-11-16 10:55: LC1730 #grind75 #timelog:00:19:54

Shortest path to get food. Note that the time here is for implementation. Took me about 3-5 extra minutes to get the implementation, but I casually timed that one.

2024-11-16 11:24: LC287 #grind75 #timelog:00:35:21

Find the duplicate number. Did brute force, then looked up the answer.

2024-11-17 09:37: 692: top K frequent words #grind75 #timelog:00:31:54

Lexicographic order threw me off. It turns out the built-in structures in Python used to solve this problem (Counter, heapify) seem to handle this for you already? Was I supposed to know that?

Follow-up problem 347 Top K frequent elements. Apparently this follows a similar pattern: https://leetcode.com/problems/top-k-frequent-elements/description/

2024-11-17 14:57: LC53: Maximum Subarray #grind75 #timelog:00:25:16

I did this already I think. But I didn't submit it, so it's a redo now.

Note to self: a subarray is different from a subsequence. Subarrays are continguous.

Wow, I did not get this right the first time. I gave up early and looked at the answer.

2024-11-17 15:30: I have to redo the first 3 weeks #grind75

I didn't submit. So, I didn't really learn anything. yay.

2024-11-17 15:31: LC57: Insert Interval #grind75 #timelog:01:18:50

Got something working, but I want to review this tomorrow

2024-11-18 11:48: LC 542. 01 Matrix #grind75 #timelog:00:13:30

2024-11-18 12:05: LC 973. K Closest Points To Origin #grind75 #timelog:00:09:45

2024-11-18 12:21: LC 3. Longest substring without repeating characters #grind75 #timelog:00:24:19

2024-11-18 12:53: LC 15: 3sum #grind75 #timelog:00:42:44

2024-11-19 09:47: LC102: Binary Tree Level Order Traversal #grind75 #timelog:00:26:02

2024-11-19 10:21: LC133: Clone Graph #grind75 #timelog:00:31:28

2024-11-19 11:30: LC150: Evaluate Reverse Polish Notation #grind75 #timelog:00:34:10

2024-11-20 09:36: 207: Course Schedule #grind75 #timelog:01:15:13

2024-11-20 12:56: 208: Implement Trie #grind75 #timelog:00:06:32

2024-11-21 09:29: 322: Coin Change #grind75 #timelog:01:55:22

2024-11-21 10:24: Coin change editorial and research #grind75

2024-11-21 12:43: LC238: Product of Array Except Self #grind75 #timelog:00:21:19

2024-11-21 13:11: LC238 Editorial and Research #grind75 #timelog:00:16:37

2024-11-21 13:33: LC155: Min Stack #grind75 #timelog:00:06:54

2024-11-21 13:40: LC155 Editorial and Research #grind75 #timelog:00:09:30

2024-11-22 09:17: LC89: validate binary search tree #grind75 #timelog:00:59:02

Initial attmpts. Program hit edge cases quickly.

2024-11-22 15:08: LC200: Number of islands #grind75 #timelog:00:37:44

2024-11-22 15:48: LC200 Continued #grind75 #timelog:00:41:33

2024-11-22 16:30: LC200 Editorial and Research #grind75 #timelog:00:38:45

I was close to getting BFS right. I didn't think to simply erase islands as I went.

2024-11-22 17:11: LC994: Rotting Oranges #grind75 #timelog:00:30:56

2024-11-23 09:21: 33: Search in Rotated Sorted Array (cont.) #grind75 #timelog:01:01:31

Another swing and a miss. Turns out I don't even grok vanilla binary search terribly well. I got a lot of things to pass, but I kept running into edge cases. Details, or maybe patches to things I don't fully get.

Giving up on trying to get this right. I've put in about 2.5 hours of struggle, where I developed some insights. Looking at the answer now.

2024-11-23 11:17: LC39: Combination Sum #grind75 #timelog:00:04:50

2024-11-23 12:16: LC39: Combination Sum Cont. #grind75 #timelog:00:14:14

2024-11-23 12:32: LC39: Editorial and research #grind75 #timelog:00:16:36

2024-11-23 17:20: LC 1: two-sum #grind75 #timelog:00:09:00

2024-11-23 17:39: LC 20: valid parentheses #grind75 #timelog:00:13:44

2024-11-23 18:20: LC 21: Merge two sorted lists #grind75 #timelog:00:10:29

2024-11-23 20:59: LC 21: some cleanup attempts? #grind75 #timelog:00:10:36

2024-11-23 21:20: LC 121: Best time to buy/sell stock #grind75 #timelog:00:09:17

I got this pretty quickly. But I have a hard time working through how it works.

2024-11-24 09:00: 125: valid palindrome #grind75 #timelog:00:11:56

2024-11-24 09:13: 125: Editorial and research #grind75 #timelog:00:51:52

The approach in the editorial had some slick python things happening that I wanted to add to my knowledge graph.

2024-11-24 10:19: 242: Valid anagram #grind75 #timelog:00:02:20

2024-11-24 10:21: 242: Editorial and research #grind75 #timelog:00:15:00

Note to self: Counter doesn't need to be imported explicitely in the leetcode python environment.

2024-11-24 10:37: 704: Binary Search #grind75 #timelog:00:04:32

We've done a lot of binary search.

2024-11-24 10:43: 235: Lowest Common Ancestor of a Binary Search Tree #grind75 #timelog:00:44:50

Initial attempt. I'm just patching edge cases, so I missed the point of it.

2024-11-24 12:16: 235: Editorial and Research #grind75 #timelog:00:21:36

2024-11-25 09:11: LC 110: Balanced Binary Tree #grind75 #timelog:00:37:51

2024-11-25 09:56: LC 110 Editorial and Study #grind75 #timelog:00:10:50

2024-11-25 10:08: LC 141 Linked list cycle #grind75 #timelog:00:58:06

I don't know how to do this problem.

2024-11-25 11:14: LC 141 Editorial and research #grind75 #timelog:00:16:53

2024-11-25 11:47: LC 232 Implement Queue Using Stacks #grind75 #timelog:00:35:15

LOOK AT MY HACKS, YE MIGHTY, AND DESPAIR

2024-11-25 12:24: LC 232 Editorial and research #grind75 #timelog:00:35:18

2024-11-25 12:58: LC 237 First bad version #grind75 #timelog:00:05:14

2024-11-25 13:04: LC 237 notes #grind75

2024-11-25 13:07: LC 169 Majority element #grind75 #timelog:00:16:45

WIP. Worked out a hashmap answer. Working out what I think is a greedy solution that takes advantage of majority property.

2024-11-25 17:23: LC 169 Continued #grind75 #timelog:00:28:48

Greedy solution did not work. Looking at editorial now.

2024-11-26 08:33: 67: Add binary #grind75 #timelog:00:25:06

2024-11-26 09:11: 67: Editorial and research #grind75 #timelog:00:32:39

2024-11-26 10:31: 542: Diameter of Binary Tree #grind75 #timelog:00:26:42

2024-11-26 11:13: 542: editorial and research #grind75 #timelog:00:21:25

2024-11-26 12:10: 876: Middle of linked list. #grind75 #timelog:00:27:11

2024-11-26 12:39: 876: Editorial #grind75 #timelog:00:10:00

2024-11-26 12:50: 104: Maximum Depth of Binary Tree #grind75 #timelog:00:06:46

2024-11-26 12:57: 104 Editorial and notes #grind75 #timelog:00:17:30

2024-11-26 13:17: 217: contains duplicate #grind75 #timelog:00:02:29

2024-11-26 13:20: 217 notes #grind75 #timelog:00:04:02

2024-11-26 13:27: I think we're done here #grind75

My goal was to do all the easy and mediums of grind75. At this point, I think they have all been completed and submitted to LC.