<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:dc="http://purl.org/dc/elements/1.1/">
  <channel>
    <title>DEV Community: Gauri-Khanolkar1</title>
    <description>The latest articles on DEV Community by Gauri-Khanolkar1 (@gaurikhanolkar1).</description>
    <link>https://dev.to/gaurikhanolkar1</link>
    <image>
      <url>https://media2.dev.to/dynamic/image/width=90,height=90,fit=cover,gravity=auto,format=auto/https:%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Fuser%2Fprofile_image%2F2976051%2Fe42ef204-29f4-470f-abb4-e04234d3bb6d.png</url>
      <title>DEV Community: Gauri-Khanolkar1</title>
      <link>https://dev.to/gaurikhanolkar1</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/gaurikhanolkar1"/>
    <language>en</language>
    <item>
      <title>🪙 Coin Change: Understanding the Problem with Two Dynamic Programming Approaches</title>
      <dc:creator>Gauri-Khanolkar1</dc:creator>
      <pubDate>Thu, 10 Jul 2025 20:48:27 +0000</pubDate>
      <link>https://dev.to/gaurikhanolkar1/coin-change-understanding-the-problem-with-two-dynamic-programming-approaches-3fn3</link>
      <guid>https://dev.to/gaurikhanolkar1/coin-change-understanding-the-problem-with-two-dynamic-programming-approaches-3fn3</guid>
      <description>&lt;p&gt;If you've ever struggled with dynamic programming, you're not alone. One of the most famous problems that helped me internalize DP thinking is the &lt;strong&gt;Coin Change&lt;/strong&gt; problem. In this article, I’ll walk you through the problem, how I approached it, and two distinct dynamic programming solutions — &lt;strong&gt;top-down with memoization&lt;/strong&gt; and &lt;strong&gt;bottom-up tabulation&lt;/strong&gt; — including when to use which.&lt;/p&gt;




&lt;h2&gt;
  
  
  🚨 The Problem
&lt;/h2&gt;

&lt;p&gt;Given a list of coin denominations and a target amount, return the &lt;strong&gt;minimum number of coins&lt;/strong&gt; needed to make that amount. If it's not possible, return &lt;code&gt;-1&lt;/code&gt;.&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="n"&gt;Input&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;coins&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="mi"&gt;5&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;11&lt;/span&gt;
&lt;span class="n"&gt;Output&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;3&lt;/span&gt;
&lt;span class="n"&gt;Explanation&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="mi"&gt;11&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;5&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;5&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;This is a classic unbounded knapsack problem because you can use each coin unlimited times.&lt;/p&gt;

&lt;h2&gt;
  
  
  🧠 My Thought Process
&lt;/h2&gt;

&lt;p&gt;My first instinct was to try recursion, but I quickly realized it would be inefficient due to repeated subproblems. That’s when I leaned into memoization (top-down DP) — it fit naturally with the recursive structure.&lt;/p&gt;

&lt;p&gt;After that, I also implemented the bottom-up tabulation approach — which avoids recursion altogether and is often more cache-friendly and easier to visualize.&lt;/p&gt;

&lt;p&gt;Let’s dive into both.&lt;/p&gt;

&lt;h2&gt;
  
  
  ✅ Top-Down (DFS + Memoization)
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="k"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;Solution&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;coinChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;self&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;coins&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;List&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;-&amp;gt;&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
        &lt;span class="c1"&gt;# Unbounded knapsack problem
&lt;/span&gt;        &lt;span class="n"&gt;memo&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;{}&lt;/span&gt;

        &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;dfs&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;amt&lt;/span&gt;&lt;span class="p"&gt;):&lt;/span&gt;
            &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;amt&lt;/span&gt; &lt;span class="o"&gt;==&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
                &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;
            &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;amt&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
                &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;  &lt;span class="c1"&gt;# Invalid large value
&lt;/span&gt;            &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;amt&lt;/span&gt; &lt;span class="ow"&gt;in&lt;/span&gt; &lt;span class="n"&gt;memo&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
                &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;memo&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;amt&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;

            &lt;span class="n"&gt;memo&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;amt&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;min&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="nf"&gt;dfs&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;amt&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;coin&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="n"&gt;coin&lt;/span&gt; &lt;span class="ow"&gt;in&lt;/span&gt; &lt;span class="n"&gt;coins&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
            &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;memo&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;amt&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt;

        &lt;span class="n"&gt;result&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;dfs&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;amount&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
        &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;result&lt;/span&gt; &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;result&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt; &lt;span class="k"&gt;else&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  🗒️ My Comments:
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;This is a top-down recursive solution with memoization.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;We store results for each sub-amount in memo to avoid recomputation.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;We return a sentinel value (amount + 1) to represent an invalid path.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;It’s memory-efficient and avoids calculating unused subproblems.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;⚠️ Downside: Python’s recursion limit (default = 1000) can cause a RecursionError for large inputs.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;CPUs are also less efficient at recursion compared to iteration due to stack jumps.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  🔁 Bottom-Up (Tabulation)
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight python"&gt;&lt;code&gt;&lt;span class="k"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;Solution&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
    &lt;span class="k"&gt;def&lt;/span&gt; &lt;span class="nf"&gt;coinChange&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;self&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;coins&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="n"&gt;List&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;-&amp;gt;&lt;/span&gt; &lt;span class="nb"&gt;int&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
        &lt;span class="c1"&gt;# Bottom-up DP approach
&lt;/span&gt;        &lt;span class="n"&gt;dp&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="nf"&gt;float&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;inf&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)]&lt;/span&gt; &lt;span class="o"&gt;*&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;amount&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
        &lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;  &lt;span class="c1"&gt;# base case
&lt;/span&gt;
        &lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="n"&gt;a&lt;/span&gt; &lt;span class="ow"&gt;in&lt;/span&gt; &lt;span class="nf"&gt;range&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;,&lt;/span&gt; &lt;span class="n"&gt;amount&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt;&lt;span class="p"&gt;):&lt;/span&gt;
            &lt;span class="k"&gt;for&lt;/span&gt; &lt;span class="n"&gt;c&lt;/span&gt; &lt;span class="ow"&gt;in&lt;/span&gt; &lt;span class="n"&gt;coins&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
                &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;a&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;c&lt;/span&gt; &lt;span class="o"&gt;&amp;gt;=&lt;/span&gt; &lt;span class="mi"&gt;0&lt;/span&gt;&lt;span class="p"&gt;:&lt;/span&gt;
                    &lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;a&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="nf"&gt;min&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;a&lt;/span&gt;&lt;span class="p"&gt;],&lt;/span&gt; &lt;span class="mi"&gt;1&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;a&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;c&lt;/span&gt;&lt;span class="p"&gt;])&lt;/span&gt;

        &lt;span class="k"&gt;return&lt;/span&gt; &lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;amount&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="k"&gt;if&lt;/span&gt; &lt;span class="n"&gt;dp&lt;/span&gt;&lt;span class="p"&gt;[&lt;/span&gt;&lt;span class="n"&gt;amount&lt;/span&gt;&lt;span class="p"&gt;]&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt; &lt;span class="nf"&gt;float&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="s"&gt;inf&lt;/span&gt;&lt;span class="sh"&gt;'&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="k"&gt;else&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt;&lt;span class="mi"&gt;1&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;h3&gt;
  
  
  🗒️ My Comments:
&lt;/h3&gt;

&lt;ul&gt;
&lt;li&gt;&lt;p&gt;This solution uses a DP table (dp[a]) where dp[a] stores the minimum coins for amount a.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;It fills the table iteratively from 0 to amount.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;No recursion = no stack overflow risk.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Easier to visualize and debug since it builds the solution step-by-step.&lt;/p&gt;&lt;/li&gt;
&lt;li&gt;&lt;p&gt;Slightly faster in practice due to better cache locality.&lt;/p&gt;&lt;/li&gt;
&lt;/ul&gt;

&lt;h2&gt;
  
  
  📚 Further Reading
&lt;/h2&gt;

&lt;ul&gt;
&lt;li&gt;&lt;a href="https://leetcode.com/problems/coin-change/" rel="noopener noreferrer"&gt;322. Coin Change Problem on Leetcode - try it yourself&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="https://en.wikipedia.org/wiki/Knapsack_problem" rel="noopener noreferrer"&gt;More about the Knapsack problem on Wikipedia&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;

</description>
      <category>dynamicprogramming</category>
      <category>python</category>
      <category>algorithms</category>
      <category>leetcode</category>
    </item>
    <item>
      <title>Confession: I’m a Developer Who Just Started Using Git Properly</title>
      <dc:creator>Gauri-Khanolkar1</dc:creator>
      <pubDate>Wed, 25 Jun 2025 19:52:52 +0000</pubDate>
      <link>https://dev.to/gaurikhanolkar1/some-git-notes-2jj7</link>
      <guid>https://dev.to/gaurikhanolkar1/some-git-notes-2jj7</guid>
      <description>&lt;p&gt;Even after being involved in the field of Computer Science for the past 7 years (as a student and a professional), I am still not as proficient in Git as I would like. This is because I used &lt;strong&gt;TortoiseSVN&lt;/strong&gt; in my previous job.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why TortoiseSVN Slowed My Git Learning
&lt;/h2&gt;

&lt;p&gt;TortoiseSVN uses a &lt;strong&gt;centralized version control system (CVCS)&lt;/strong&gt; model, where the &lt;code&gt;"trunk"&lt;/code&gt; typically represents the main development line or the latest stable version. While it’s great for handling large binary files, it has some limitations:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;"Branching" is implemented as directory copies, not as first-class objects
&lt;/li&gt;
&lt;li&gt;A stable network connection is required to interact with the central repository
&lt;/li&gt;
&lt;li&gt;Developers do not usually have a full local copy of the repository history
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;As a result, I rarely needed to think about distributed workflows or advanced branching strategies — two key parts of Git.&lt;/p&gt;

&lt;h2&gt;
  
  
  Why Git Feels Like a Necessity Now
&lt;/h2&gt;

&lt;p&gt;&lt;strong&gt;Git&lt;/strong&gt; is a &lt;strong&gt;distributed version control system (DVCS)&lt;/strong&gt; that gives each developer a full local copy of the repository. That means:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;You can work offline
&lt;/li&gt;
&lt;li&gt;Branching and merging are fast and flexible
&lt;/li&gt;
&lt;li&gt;Collaboration scales better across teams
&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;In hindsight, I believe Git is not just better — it’s essential for modern developers.&lt;/p&gt;

&lt;h2&gt;
  
  
  How I Started Learning Git
&lt;/h2&gt;

&lt;p&gt;Here are two excellent resources that helped me get started:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;📺 &lt;a href="https://www.youtube.com/watch?v=2sjqTHE0zok" rel="noopener noreferrer"&gt;Git Crash Course For Beginners&lt;/a&gt;
&lt;/li&gt;
&lt;li&gt;🌳 &lt;a href="https://learngitbranching.js.org/" rel="noopener noreferrer"&gt;Learn Git Branching (interactive visual tool)&lt;/a&gt;
&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;These gave me both the &lt;strong&gt;big picture&lt;/strong&gt; and the &lt;strong&gt;hands-on skills&lt;/strong&gt; I was missing.&lt;/p&gt;

&lt;h2&gt;
  
  
  More on Git vs SVN
&lt;/h2&gt;

&lt;p&gt;If you're curious about the differences between the two, this article is a good summary:&lt;br&gt;&lt;br&gt;
👉 &lt;a href="https://www.educba.com/svn-vs-git/" rel="noopener noreferrer"&gt;SVN vs Git&lt;/a&gt;&lt;/p&gt;

</description>
      <category>git</category>
      <category>svn</category>
      <category>tortoisesvn</category>
      <category>versioncontrol</category>
    </item>
  </channel>
</rss>
