<divrole="region"aria-label="Skip to main content"><aclass="skipToContent_fXgn"href="#__docusaurus_skipToContent_fallback">Skip to main content</a></div><navaria-label="Main"class="navbar navbar--fixed-top"><divclass="navbar__inner"><divclass="navbar__items"><buttonaria-label="Toggle navigation bar"aria-expanded="false"class="navbar__toggle clean-btn"type="button"><svgwidth="30"height="30"viewBox="0 0 30 30"aria-hidden="true"><pathstroke="currentColor"stroke-linecap="round"stroke-miterlimit="10"stroke-width="2"d="M4 7h22M4 15h22M4 23h22"></path></svg></button><aclass="navbar__brand"href="/"><bclass="navbar__title text--truncate">mf</b></a><divclass="navbar__item dropdown dropdown--hoverable"><ahref="#"aria-haspopup="true"aria-expanded="false"role="button"class="navbar__link">Additional FI MU materials</a><ulclass="dropdown__menu"><li><aaria-current="page"class="dropdown__link dropdown__link--active"href="/ib002/">IB002: Algorithms</a></li><li><aclass="dropdown__link"href="/pb071/">PB071: C</a></li><li><aclass="dropdown__link"href="/pb161/">PB161: C++</a></li></ul></div><aclass="navbar__item navbar__link"href="/contributions">Contributions</a><aclass="navbar__item navbar__link"href="/talks">Talks</a></div><divclass="navbar__items navbar__items--right"><aclass="navbar__item navbar__link"href="/blog">Blog</a><divclass="toggle_vylO colorModeToggle_DEke"><buttonclass="clean-btn toggleButton_gllP toggleButtonDisabled_aARS"type="button"disabled=""title="Switch between dark and light mode (currently light mode)"aria-label="Switch between dark and light mode (currently light mode)"aria-live="polite"><svgviewBox="0 0 24 24"width="24"height="24"class="lightToggleIcon_pyhR"><pathfill="currentColor"d="M12,9c1.65,0,3,1.35,3,3s-1.35,3-3,3s-3-1.35-3-3S10.35,9,12,9 M12,7c-2.76,0-5,2.24-5,5s2.24,5,5,5s5-2.24,5-5 S14.76,7,12,7L12,7z M2,13l2,0c0.55,0,1-0.45,1-1s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S1.45,13,2,13z M20,13l2,0c0.55,0,1-0.45,1-1 s-0.45-1-1-1l-2,0c-0.55,0-1,0.45-1,1S19.45,13,20,13z M11,2v2c0,0.55,0.45,1,1,1s1-0.45,1-1V2c0-0.55-0.45-1-1-1S11,1.45,11,2z M11,20v2c0,0.55,0.45,1,1,1s1-0.45,1-1v-2c0-0.55-0.45-1-1-1C11.45,19,11,19.45,11,20z M5.99,4.58c-0.39-0.39-1.03-0.39-1.41,0 c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0s0.39-1.03,0-1.41L5.99,4.58z M18.36,16.95 c-0.39-0.39-1.03-0.39-1.41,0c-0.39,0.39-0.39,1.03,0,1.41l1.06,1.06c0.39,0.39,1.03,0.39,1.41,0c0.39-0.39,0.39-1.03,0-1.41 L18.36,16.95z M19.42,5.99c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06c-0.39,0.39-0.39,1.03,0,1.41 s1.03,0.39,1.41,0L19.42,5.99z M7.05,18.36c0.39-0.39,0.39-1.03,0-1.41c-0.39-0.39-1.03-0.39-1.41,0l-1.06,1.06 c-0.39,0.39-0.39,1.03,0,1.41s1.03,0.39,1.41,0L7.05,18.36z"></path></svg><svgviewBox="0 0 24 24"width="24"height="24"class="darkToggleIcon_wfgR"><pathfill="currentColor"d="M9.37,5.51C9.19,6.15,9.1,6.82,9.1,7.5c0,4.08,3.32,7.4,7.4,7.4c0.68,0,1.35-0.09,1.99-0.27C17.45,17.19,14.93,19,12,19 c-3.86,0-7-3.14-7-7C5,9.07,6.81,6.55,9.37,5.51z M12,3c-4.97,0-9,4.03-9,9s4.03,9,9,9s9-4.03,9-9c0-0.46-0.04-0.92-0.1-1.36 c-0.98,1.37-2.58,2.26-4.4,2.26c-2.98,0-5.4-2.42-5.4-5.4c0-1.81,0.89-3.42,2.26-4.4C12.92,3.04,12.46,3,12,3L12,3z"></path></svg></button></div><divclass="searchBox_ZlJk"><buttontype="button"class="DocSearch DocSearch-Button"aria-label="Search"><spanclass="DocSearch-Button-Container"><svgwidth="20"height="20"class="DocSearch-Search-Icon"viewBox="0 0 20 20"><pathd="M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z"stroke="currentColor"fill="none"fill-rule="evenodd"stroke-linecap="round"stroke-linejoin="round"></path></svg><spanclass="DocSearch-Button-Placeholder">Search</span></span><spanclass="DocSearch-Button-Keys"></span></button></div></div></div><divrole="presentation"class="navbar-sidebar__backdrop"></div></nav><divid="__docusaurus_skipToContent_fallback"class="main-wrappermainWrapper_
elements from <code>b</code>.</p><p>Time complexity: <spanclass="math math-inline"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mimathvariant="script">O</mi><mostretchy="false">(</mo><mi>m</mi><mo>+</mo><mi>n</mi><mostretchy="false">)</mo></mrow><annotationencoding="application/x-tex">\mathcal{O}(m + n)</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:1em;vertical-align:-0.25em"></span><spanclass="mord mathcal"style="margin-right:0.02778em">O</span><spanclass="mopen">(</span><spanclass="mord mathnormal">m</span><spanclass="mspace"style="margin-right:0.2222em"></span><spanclass="mbin">+</span><spanclass="mspace"style="margin-right:0.2222em"></span></span><spanclass="base"><spanclass="strut"style="height:1em;vertical-align:-0.25em"></span><spanclass="mord mathnormal">n</span><spanclass="mclose">)</span></span></span></span></span>, where <spanclass="math math-inline"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mi>m</mi><moseparator="true">,</mo><mi>n</mi></mrow><annotationencoding="application/x-tex">m, n</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:0.625em;vertical-align:-0.1944em"></span><spanclass="mord mathnormal">m</span><spanclass="mpunct">,</span><spanclass="mspace"style="margin-right:0.1667em"></span><spanclass="mord mathnormal">n</span></span></span></span></span> denote the length of
<code>a</code> and <code>b</code> respectively.</p><p>Space complexity: <spanclass="math math-inline"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mimathvariant="script">O</mi><mostretchy="false">(</mo><mi>m</mi><mo>+</mo><mi>n</mi><mostretchy="false">)</mo></mrow><annotationencoding="application/x-tex">\mathcal{O}(m + n)</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:1em;vertical-align:-0.25em"></span><spanclass="mord mathcal"style="margin-right:0.02778em">O</span><spanclass="mopen">(</span><spanclass="mord mathnormal">m</span><spanclass="mspace"style="margin-right:0.2222em"></span><spanclass="mbin">+</span><spanclass="mspace"style="margin-right:0.2222em"></span></span><spanclass="base"><spanclass="strut"style="height:1em;vertical-align:-0.25em"></span><spanclass="mord mathnormal">n</span><spanclass="mclose">)</span></span></span></span></span>, where <spanclass="math math-inline"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mi>m</mi><moseparator="true">,</mo><mi>n</mi></mrow><annotationencoding="application/x-tex">m, n</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:0.625em;vertical-align:-0.1944em"></span><spanclass="mord mathnormal">m</span><spanclass="mpunct">,</span><spanclass="mspace"style="margin-right:0.1667em"></span><spanclass="mord mathnormal">n</span></span></span></span></span> denote the length of
<code>a</code> and <code>b</code> respectively, since we construct new list.</p></li></ul><h2class="anchor anchorWithStickyNavbar_LWe7"id="example-1">Example #1<ahref="#example-1"class="hash-link"aria-label="Direct link to Example #1"title="Direct link to Example #1"></a></h2><p>Let us assume function that uses divide & conquer strategy to return indices at which we can find specific element in any list.</p><divclass="language-py codeBlockContainer_Ckt0 theme-code-block"style="--prism-color:#000000;--prism-background-color:#ffffff"><divclass="codeBlockContent_biex"><pretabindex="0"class="prism-code language-py codeBlock_bY9V thin-scrollbar"><codeclass="codeBlockLines_e6Vv codeBlockLinesWithNumbering_o6Pm"><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token keyword"style="color:rgb(0, 0, 255)">def</span><spanclass="token plain"></span><spanclass="token function"style="color:rgb(0, 0, 255)">recursive_find_in_list</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">(</span><spanclass="token plain"></span></span><br></span><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token plain"> values</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"> List</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">[</span><spanclass="token plain">Any</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">]</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">,</span><spanclass="token plain"> key</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"> Any</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">,</span><spanclass="token plain"> lower</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"></span><spanclass="token builtin"style="color:rgb(0, 112, 193)">int</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">,</span><spanclass="token plain"> upper</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"></span><spanclass="token builtin"style="color:rgb(0, 112, 193)">int</span><spanclass="token plain"></span></span><br></span><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token plain"></span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">)</span><spanclass="token plain"></span><spanclass="token operator"style="color:rgb(0, 0, 0)">-</span><spanclass="token operator"style="color:rgb(0, 0, 0)">></span><spanclass="token plain"> List</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">[</span><spanclass="token builtin"style="color:rgb(0, 112, 193)">int</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">]</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"></span></span><br></span><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token plain"></span><spanclass="token keyword"style="color:rgb(0, 0, 255)">if</span><spanclass="token plain"> lower </span><spanclass="token operator"style="color:rgb(0, 0, 0)">==</span><spanclass="token plain"> upper</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">:</span><spanclass="token plain"></span></span><br></span><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token plain"></span><spanclass="token keyword"style="color:rgb(0, 0, 255)">return</span><spanclass="token plain"></span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">
<imgloading="lazy"alt="Rendered construction of the list"src="/assets/images/construction_dark-fac28e7cafcc43d7e2fb5f0b6c25504e.svg#gh-dark-mode-only"width="851"height="276"class="img_ev3q"></p><p>Let us assume that you extend the result with the list that you get from the recursive call.</p><ul><li><p>B iterates through 1, 2 and 3; returns <code>[1, 2, 3]</code></p></li><li><p>C iterates through 4, 5 and 6; returns <code>[4, 5, 6]</code></p></li><li><p>D iterates through 7, 8 and 9; returns <code>[7, 8, 9]</code></p></li><li><p>now we return those lists to the calls from A), so each of the <code>extend</code> calls iterates through:</p><ul><li>1, 2, 3 that was returned from B</li><li>4, 5, 6 that was returned from C</li><li>7, 8, 9 that was returned from D</li></ul><p>and returns <code>[1, 2, 3, 4, 5, 6, 7, 8, 9]</code></p></li></ul><p>If the recursion had bigger depth and/or more elements, it would iterate through them more than twice, therefore it does not take constant time to do nor some constant multiple of the input, since it traverses all of the elements in each of the levels.</p><h2class="anchor anchorWithStickyNavbar_LWe7"id="implementation-of-extend">Implementation of <code>extend</code><ahref="#implementation-of-extend"class="hash-link"aria-label="Direct link to implementation-of-extend"title="Direct link to implementation-of-extend"></a></h2><p>There is an example of dynamic array:</p><ul><li><ahref="/files/ib002/time-complexity/extend/dynlist.h"target="_blank"rel="noopener noreferrer">interface (<code>dynlist.h</code>)</a></li><li><ahref="/files/ib002/time-complexity/extend/dynlist.c"target="_blank"rel="noopener noreferrer">implementation (<code>dynlist.c</code>)</a></li></ul><p>For the sake of <em>Algorithms and Data Structures I</em> we consider <code>APPEND</code> operation, i.e. adding the element to the end of the list, to have time complexity <spanclass="math math-inline"><spanclass="katex"><spanclass="katex-mathml"><mathxmlns="http://www.w3.org/1998/Math/MathML"><semantics><mrow><mimathvariant="script">O</mi><mostretchy="false">(</mo><mn>1</mn><mostretchy="false">)</mo></mrow><annotationencoding="application/x-tex">\mathcal{O}(1)</annotation></semantics></math></span><spanclass="katex-html"aria-hidden="true"><spanclass="base"><spanclass="strut"style="height:1em;vertical-align:-0.25em"></span><spanclass="mord mathcal"style="margin-right:0.02778em">O</span><spanclass="mopen">(</span><spanclass="mord">1</span><spanclass="mclose">)</span></span></span></span></span> (<strong>amortized</strong>; which is out of the scope of IB002).</p><p>If we have a look at the <code>extend</code> implementation in this dynamic array example:</p><divclass="language-c codeBlockContainer_Ckt0 theme-code-block"style="--prism-color:#000000;--prism-background-color:#ffffff"><divclass="codeBlockContent_biex"><pretabindex="0"class="prism-code language-c codeBlock_bY9V thin-scrollbar"><codeclass="codeBlockLines_e6Vv codeBlockLinesWithNumbering_o6Pm"><spanclass="token-line codeLine_lJS_"style="color:#000000"><spanclass="codeLineNumber_Tfdd"></span><spanclass="codeLineContent_feaV"><spanclass="token keyword"style="color:rgb(0, 0, 255)">void</span><spanclass="token plain"></span><spanclass="token function"style="color:rgb(0, 0, 255)">dynamic_array_extend</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">(</span><spanclass="token keyword"style="color:rgb(0, 0, 255)">struct</span><spanclass="token plain"></span><spanclass="token class-name"style="color:rgb(38, 127, 153)">dynamic_array_t</span><spanclass="token plain"></span><spanclass="token operator"style="color:rgb(0, 0, 0)">*</span><spanclass="token plain">arr</span><spanclass="token punctuation"style="color:rgb(4, 81, 165)">,</span><spanclass="token plain"></span><spanclass="token keyword"style="color:rgb(0, 0, 255)">struct</span><spanclass="token plain"></span><spanclass="token class-name"style="color:rgb(38, 127, 153)">dynamic_array_t</span><spanclass="token plain"></span><spanclas