<?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>Forem: Jatin</title>
    <description>The latest articles on Forem by Jatin (@jatinpatil-chef).</description>
    <link>https://forem.com/jatinpatil-chef</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%2F3948901%2Febda0657-aca8-4240-9d6d-1d55e1badb4f.png</url>
      <title>Forem: Jatin</title>
      <link>https://forem.com/jatinpatil-chef</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://forem.com/feed/jatinpatil-chef"/>
    <language>en</language>
    <item>
      <title>Most People Misunderstand Binary Search on Answer</title>
      <dc:creator>Jatin</dc:creator>
      <pubDate>Sun, 24 May 2026 10:16:50 +0000</pubDate>
      <link>https://forem.com/jatinpatil-chef/most-people-misunderstand-binary-search-on-answer-32f1</link>
      <guid>https://forem.com/jatinpatil-chef/most-people-misunderstand-binary-search-on-answer-32f1</guid>
      <description>&lt;p&gt;Most people think Binary Search is about searching arrays.&lt;/p&gt;

&lt;p&gt;Wrong.&lt;/p&gt;

&lt;p&gt;Binary Search on Answer is fundamentally:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;searching the boundary between valid and invalid answers&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That is the real understanding.&lt;/p&gt;

&lt;p&gt;You are not searching data.&lt;/p&gt;

&lt;p&gt;You are searching a decision space.&lt;/p&gt;




&lt;h1&gt;
  
  
  The Real Structure of Binary Search on Answer
&lt;/h1&gt;

&lt;p&gt;Every Binary Search on Answer problem has 3 components:&lt;/p&gt;

&lt;ol&gt;
&lt;li&gt;Search Space&lt;/li&gt;
&lt;li&gt;Feasibility Function&lt;/li&gt;
&lt;li&gt;Monotonic Property&lt;/li&gt;
&lt;/ol&gt;

&lt;p&gt;Miss even one of them and Binary Search will fail.&lt;/p&gt;




&lt;h1&gt;
  
  
  1. Search Space
&lt;/h1&gt;

&lt;p&gt;First identify:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;What are all possible answers?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Example:&lt;br&gt;
“Ship Packages Within D Days”&lt;/p&gt;

&lt;p&gt;Possible answer:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;capacity&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;What can its range be?&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;low&lt;/span&gt;  &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;max&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;arr&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;span class="n"&gt;high&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;sum&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;arr&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Why?&lt;/p&gt;

&lt;p&gt;Because:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;Capacity cannot be smaller than the largest package.&lt;/li&gt;
&lt;li&gt;Capacity can at most be the sum of all packages.&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;This is critical.&lt;/p&gt;

&lt;p&gt;In Binary Search on Answer:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;low&lt;/span&gt;&lt;span class="o"&gt;/&lt;/span&gt;&lt;span class="n"&gt;high&lt;/span&gt; &lt;span class="n"&gt;are&lt;/span&gt; &lt;span class="n"&gt;NOT&lt;/span&gt; &lt;span class="n"&gt;indexes&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;They are:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;minimum&lt;/span&gt; &lt;span class="n"&gt;and&lt;/span&gt; &lt;span class="n"&gt;maximum&lt;/span&gt; &lt;span class="n"&gt;possible&lt;/span&gt; &lt;span class="n"&gt;answers&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That mental shift changes everything.&lt;/p&gt;




&lt;h1&gt;
  
  
  2. Feasibility Function
&lt;/h1&gt;

&lt;p&gt;This is the heart of the problem.&lt;/p&gt;

&lt;p&gt;You are repeatedly asking:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Can this answer work?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Can&lt;/span&gt; &lt;span class="n"&gt;capacity&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;15&lt;/span&gt; &lt;span class="n"&gt;ship&lt;/span&gt; &lt;span class="n"&gt;everything&lt;/span&gt; &lt;span class="n"&gt;within&lt;/span&gt; &lt;span class="n"&gt;D&lt;/span&gt; &lt;span class="n"&gt;days&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Only two outcomes exist:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;YES&lt;/span&gt;
&lt;span class="n"&gt;NO&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That binary outcome is exactly why Binary Search works.&lt;/p&gt;

&lt;p&gt;This function is usually written as:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="kt"&gt;bool&lt;/span&gt; &lt;span class="n"&gt;possible&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h1&gt;
  
  
  3. Monotonic Property
&lt;/h1&gt;

&lt;p&gt;Without monotonicity,&lt;br&gt;
Binary Search is impossible.&lt;/p&gt;

&lt;p&gt;Example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;capacity = 10 -&amp;gt; impossible
capacity = 11 -&amp;gt; impossible
capacity = 12 -&amp;gt; possible
capacity = 13 -&amp;gt; possible
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Pattern:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;FFFFTTTT
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Or sometimes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;TTTTFFFF
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Binary Search works because there is a clean boundary.&lt;/p&gt;

&lt;p&gt;You are finding:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;first TRUE&lt;/li&gt;
&lt;li&gt;last TRUE&lt;/li&gt;
&lt;li&gt;first FALSE&lt;/li&gt;
&lt;li&gt;last FALSE&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;That is the deeper understanding.&lt;/p&gt;




&lt;h1&gt;
  
  
  Binary Search is NOT Searching Numbers
&lt;/h1&gt;

&lt;p&gt;This is the biggest misconception.&lt;/p&gt;

&lt;p&gt;You are not searching numbers.&lt;/p&gt;

&lt;p&gt;You are searching:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;the transition point between valid and invalid states&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;This is why Binary Search on Answer is actually:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Boundary Finding
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h1&gt;
  
  
  How to Recognize Binary Search on Answer
&lt;/h1&gt;

&lt;p&gt;Do not memorize keywords.&lt;/p&gt;

&lt;p&gt;Use structural recognition.&lt;/p&gt;




&lt;h1&gt;
  
  
  Signal 1 — Optimization
&lt;/h1&gt;

&lt;p&gt;Ask:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Am I minimizing or maximizing something?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Examples:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;minimum speed&lt;/li&gt;
&lt;li&gt;minimum time&lt;/li&gt;
&lt;li&gt;maximum minimum distance&lt;/li&gt;
&lt;li&gt;minimum largest sum&lt;/li&gt;
&lt;li&gt;minimum capacity&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Optimization problems are the first signal.&lt;/p&gt;




&lt;h1&gt;
  
  
  Signal 2 — Can I Guess an Answer?
&lt;/h1&gt;

&lt;p&gt;Ask:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Suppose&lt;/span&gt; &lt;span class="n"&gt;answer&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Can you test it?&lt;/p&gt;

&lt;p&gt;Example:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Can&lt;/span&gt; &lt;span class="n"&gt;speed&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="mi"&gt;5&lt;/span&gt; &lt;span class="n"&gt;finish&lt;/span&gt; &lt;span class="n"&gt;all&lt;/span&gt; &lt;span class="n"&gt;bananas&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;If yes,&lt;br&gt;
Binary Search becomes possible.&lt;/p&gt;


&lt;h1&gt;
  
  
  Signal 3 — Can I Verify It?
&lt;/h1&gt;

&lt;p&gt;Can you build:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;possible&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;that returns:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="nb"&gt;true&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="nb"&gt;false&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;If not,&lt;br&gt;
Binary Search probably will not work.&lt;/p&gt;


&lt;h1&gt;
  
  
  Signal 4 — Monotonicity
&lt;/h1&gt;

&lt;p&gt;This is mandatory.&lt;/p&gt;

&lt;p&gt;Ask:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;If X works, will larger values also work?&lt;br&gt;
Or smaller values?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;Examples:&lt;/p&gt;
&lt;h2&gt;
  
  
  Koko Eating Bananas
&lt;/h2&gt;


&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;speed 4 -&amp;gt; impossible
speed 5 -&amp;gt; possible
speed 6 -&amp;gt; possible
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;


&lt;p&gt;Pattern:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;FFFFTTTT
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h2&gt;
  
  
  Aggressive Cows
&lt;/h2&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;distance 3 -&amp;gt; possible
distance 4 -&amp;gt; possible
distance 5 -&amp;gt; impossible
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Pattern:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;TTTTFFFF
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Still valid.&lt;/p&gt;




&lt;h1&gt;
  
  
  Real Examples
&lt;/h1&gt;

&lt;h1&gt;
  
  
  1. Koko Eating Bananas
&lt;/h1&gt;

&lt;p&gt;Goal:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;minimum eating speed
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Check:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Can&lt;/span&gt; &lt;span class="n"&gt;speed&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt; &lt;span class="n"&gt;finish&lt;/span&gt; &lt;span class="n"&gt;in&lt;/span&gt; &lt;span class="n"&gt;h&lt;/span&gt; &lt;span class="n"&gt;hours&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Monotonic:&lt;/p&gt;

&lt;p&gt;Higher speed always helps.&lt;/p&gt;

&lt;p&gt;Binary Search on Answer.&lt;/p&gt;




&lt;h1&gt;
  
  
  2. Ship Packages Within D Days
&lt;/h1&gt;

&lt;p&gt;Goal:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;minimum ship capacity
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Check:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Can&lt;/span&gt; &lt;span class="n"&gt;capacity&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt; &lt;span class="n"&gt;ship&lt;/span&gt; &lt;span class="n"&gt;within&lt;/span&gt; &lt;span class="n"&gt;D&lt;/span&gt; &lt;span class="n"&gt;days&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Monotonic:&lt;/p&gt;

&lt;p&gt;Higher capacity always helps.&lt;/p&gt;

&lt;p&gt;Binary Search on Answer.&lt;/p&gt;




&lt;h1&gt;
  
  
  3. Aggressive Cows
&lt;/h1&gt;

&lt;p&gt;Goal:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;maximize minimum distance
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Check:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;Can&lt;/span&gt; &lt;span class="n"&gt;cows&lt;/span&gt; &lt;span class="n"&gt;be&lt;/span&gt; &lt;span class="n"&gt;placed&lt;/span&gt; &lt;span class="n"&gt;with&lt;/span&gt; &lt;span class="n"&gt;distance&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="o"&gt;?&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Monotonic:&lt;/p&gt;

&lt;p&gt;Larger distance becomes harder.&lt;/p&gt;

&lt;p&gt;Still Binary Search.&lt;/p&gt;




&lt;h1&gt;
  
  
  When Binary Search on Answer Fails
&lt;/h1&gt;

&lt;p&gt;Understanding failure cases matters more than memorizing templates.&lt;/p&gt;




&lt;h1&gt;
  
  
  Case 1 — No Monotonicity
&lt;/h1&gt;

&lt;p&gt;If pattern becomes:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;TFTFTFTF
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Binary Search breaks.&lt;/p&gt;

&lt;p&gt;There is no clean boundary.&lt;/p&gt;




&lt;h1&gt;
  
  
  Case 2 — Cannot Verify
&lt;/h1&gt;

&lt;p&gt;If you cannot efficiently test:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="n"&gt;possible&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;then Binary Search becomes impractical.&lt;/p&gt;




&lt;h1&gt;
  
  
  Case 3 — No Ordered Search Space
&lt;/h1&gt;

&lt;p&gt;Binary Search requires an ordered answer space.&lt;/p&gt;

&lt;p&gt;No ordering →&lt;br&gt;
No Binary Search.&lt;/p&gt;


&lt;h1&gt;
  
  
  The Ultimate Mental Shift
&lt;/h1&gt;

&lt;p&gt;Stop thinking:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Binary Search on Arrays
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;Start thinking:&lt;br&gt;
&lt;/p&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;Binary Search on Decision Space
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;



&lt;p&gt;That is the actual concept.&lt;/p&gt;




&lt;h1&gt;
  
  
  Master Template
&lt;/h1&gt;



&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight cpp"&gt;&lt;code&gt;&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;low&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;minimum_possible_answer&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;
&lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;high&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;maximum_possible_answer&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

&lt;span class="k"&gt;while&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;low&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;=&lt;/span&gt; &lt;span class="n"&gt;high&lt;/span&gt;&lt;span class="p"&gt;){&lt;/span&gt;

    &lt;span class="kt"&gt;int&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;low&lt;/span&gt; &lt;span class="o"&gt;+&lt;/span&gt; &lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;high&lt;/span&gt; &lt;span class="o"&gt;-&lt;/span&gt; &lt;span class="n"&gt;low&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt; &lt;span class="o"&gt;/&lt;/span&gt; &lt;span class="mi"&gt;2&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

    &lt;span class="k"&gt;if&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;possible&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="p"&gt;)){&lt;/span&gt;

        &lt;span class="n"&gt;ans&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&lt;/span&gt;&lt;span class="p"&gt;;&lt;/span&gt;

        &lt;span class="c1"&gt;// for minimization&lt;/span&gt;
        &lt;span class="n"&gt;high&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&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="c1"&gt;// for maximization:&lt;/span&gt;
        &lt;span class="c1"&gt;// low = mid + 1;&lt;/span&gt;
    &lt;span class="p"&gt;}&lt;/span&gt;
    &lt;span class="k"&gt;else&lt;/span&gt;&lt;span class="p"&gt;{&lt;/span&gt;
        &lt;span class="n"&gt;low&lt;/span&gt; &lt;span class="o"&gt;=&lt;/span&gt; &lt;span class="n"&gt;mid&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="p"&gt;}&lt;/span&gt;
&lt;span class="p"&gt;}&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;






&lt;h1&gt;
  
  
  Final Recognition Rule
&lt;/h1&gt;

&lt;p&gt;Whenever you see:&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;minimum possible&lt;/li&gt;
&lt;li&gt;maximum possible&lt;/li&gt;
&lt;li&gt;smallest&lt;/li&gt;
&lt;li&gt;largest&lt;/li&gt;
&lt;li&gt;speed&lt;/li&gt;
&lt;li&gt;capacity&lt;/li&gt;
&lt;li&gt;allocation&lt;/li&gt;
&lt;li&gt;distance&lt;/li&gt;
&lt;li&gt;time&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;Immediately ask:&lt;/p&gt;

&lt;blockquote&gt;
&lt;p&gt;Can I binary search the answer?&lt;/p&gt;
&lt;/blockquote&gt;

&lt;p&gt;That single habit solves half the recognition problem in DSA.&lt;/p&gt;

</description>
      <category>algorithms</category>
      <category>computerscience</category>
      <category>cpp</category>
      <category>dsa</category>
    </item>
    <item>
      <title># Most People Misunderstand Binary Search on Answer

Most people think Binary Search is about searching arrays.

Wrong.

Binary Search on Answer is fundamentally:

&gt; searching the boundary between valid and invalid answers

That is the real understanding.</title>
      <dc:creator>Jatin</dc:creator>
      <pubDate>Sun, 24 May 2026 10:15:49 +0000</pubDate>
      <link>https://forem.com/jatinpatil-chef/-most-people-misunderstand-binary-search-on-answer-most-people-think-binary-search-is-about-4500</link>
      <guid>https://forem.com/jatinpatil-chef/-most-people-misunderstand-binary-search-on-answer-most-people-think-binary-search-is-about-4500</guid>
      <description></description>
    </item>
  </channel>
</rss>
