{"id":108473,"date":"2021-10-25T11:37:20","date_gmt":"2021-10-25T15:37:20","guid":{"rendered":"https:\/\/ibkrcampus.com\/?p=108473"},"modified":"2022-11-21T09:48:42","modified_gmt":"2022-11-21T14:48:42","slug":"dijkstra-algorithm-part-ii","status":"publish","type":"post","link":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/","title":{"rendered":"Dijkstra Algorithm \u2013 Part II"},"content":{"rendered":"\n<p><em>See <a href=\"\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-i\/\">Part I<\/a> for an overview of Dijkstra algorithm<\/em>.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"pseudo-code-of-dijkstra-algorithm\">Pseudo code of Dijkstra algorithm<\/h2>\n\n\n\n<p>The pseudo code of Dijkstra algorithm is:<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function Dijkstra(L&#91;1..n, 1..n]): matrix &#91;2..n]\nmatrix D&#91;2..n]\n{initialization}\nC &lt;- {2, 3, \u2026, n} {S = N \\ C exists only implicitly}\nfor i \u2190 2 to n do D&#91;i] \u2190 L&#91;1, i]\n{greedy loop}\nrepeat n - 2 times\n\tv \u2190 some element of C that minimizes D&#91;v]\n\tC \u2190 C \\ {v} {and implicitly S \u2190  S U {v}}\n\tfor each w \u2208 C do\n\t\tD&#91;w] \u2190 min(D&#91;w], D&#91;v] + L&#91;v, w])\nReturn D<\/code><\/pre>\n\n\n\n<pre class=\"wp-block-code\"><code><a href=\"https:\/\/gist.github.com\/quantra-go-algo\/27718fa7db7e02cbb3dbc6b5dba2c537#file-pseudo-code-py\" target=\"_blank\" rel=\"noreferrer noopener\">Pseudo code.py&nbsp;<\/a>hosted with \u2764 by&nbsp;<a href=\"https:\/\/github.com\/\" target=\"_blank\" rel=\"noreferrer noopener\">GitHub<\/a><\/code><\/pre>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"dijkstra-algorithm-table\">Dijkstra algorithm table<\/h2>\n\n\n\n<p>Assume the following routed graph:<\/p>\n\n\n\n<figure class=\"wp-block-image img-twothird\"><img decoding=\"async\" width=\"688\" height=\"507\" data-src=\"\/campus\/wp-content\/uploads\/sites\/2\/2021\/10\/dijkstras-algorithm-table-quantinsti.png\" alt=\"\" class=\"wp-image-108489 lazyload\" data-srcset=\"https:\/\/ibkrcampus.com\/campus\/wp-content\/uploads\/sites\/2\/2021\/10\/dijkstras-algorithm-table-quantinsti.png 688w, https:\/\/ibkrcampus.com\/campus\/wp-content\/uploads\/sites\/2\/2021\/10\/dijkstras-algorithm-table-quantinsti-300x221.png 300w\" data-sizes=\"(max-width: 688px) 100vw, 688px\" src=\"data:image\/svg+xml;base64,PHN2ZyB3aWR0aD0iMSIgaGVpZ2h0PSIxIiB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciPjwvc3ZnPg==\" style=\"--smush-placeholder-width: 688px; aspect-ratio: 688\/507;\" \/><\/figure>\n\n\n\n<p class=\"has-text-align-center\"><em>Dijkstra algorithm table<\/em><\/p>\n\n\n\n<figure class=\"wp-block-table\"><table><tbody><tr><td><strong>Step<\/strong><\/td><td><strong>v<\/strong><\/td><td><strong>C<\/strong><\/td><td><strong>D<\/strong><\/td><\/tr><tr><td>Initialization<\/td><td>&#8211;<\/td><td>{2, 3, 4, 5}<\/td><td>[50, 30, 100, 10]<\/td><\/tr><tr><td>1<\/td><td>5<\/td><td>{2, 3, 4}<\/td><td>[50, 30, 20, 10]<\/td><\/tr><tr><td>2<\/td><td>4<\/td><td>{2, 3}<\/td><td>[40, 30, 20, 10]<\/td><\/tr><tr><td>3<\/td><td>3<\/td><td>{2}<\/td><td>[35, 30, 20, 10]<\/td><\/tr><\/tbody><\/table><\/figure>\n\n\n\n<p>Obviously the matrix D would not change if we did one more interaction to remove the last element of C {2} and for this reason the main loop only repeats n-2 times.<\/p>\n\n\n\n<h2 class=\"wp-block-heading\" id=\"dijkstra-algorithm-time-complexity\">Dijkstra algorithm time complexity<\/h2>\n\n\n\n<p>The initialisation requires a matrix L[1..n, 1..n] and therefore requires a time that is in the Order of n O(n)<\/p>\n\n\n\n<p>The repeat loop requires looping through all the elements of C, so the total time is in the order of&nbsp;n2.O(n2)n2.O(n2)<\/p>\n\n\n\n<p>The loop for each requires looping through all the elements of C, so the total time is on the order of&nbsp;n2.O(n2)n2.O(n2)<\/p>\n\n\n\n<p>Therefore, the simple implementation of the Dijkstra algorithm requires a runtime that is&nbsp;O(n2)O(n2)<\/p>\n\n\n\n<p>Depending on the implementation of the algorithm and as long as the number of edges is much smaller than&nbsp;n2n2, we can improve the complexity up to O((a + n) log n) if the graph is connected and is in O(a log n), but if the graph is dense we can only reach&nbsp;O(n2\/logn).O(n2\/logn).<\/p>\n\n\n\n<p>To improve Dijkstra&#8217;s simple algorithm, one can make an implementation of k-ary heaps as proposed by Johnson. Fredman and Tarjan further improve the complexity by using a Fibonacci heap.<\/p>\n\n\n\n<p>See references for more information.<\/p>\n\n\n\n<hr class=\"wp-block-separator\"\/>\n\n\n\n<p><strong>References<\/strong><\/p>\n\n\n\n<ul class=\"wp-block-list\"><li>Fundamentals of algorithmics by G. Brassard and P. Bratley<\/li><li><a href=\"https:\/\/www.cs.princeton.edu\/courses\/archive\/spr04\/cos226\/lectures\/shortest-path.4up.pdf\" target=\"_blank\" rel=\"noreferrer noopener\">Princeton University, Dijkstra&#8217;s algorithm and Bellman-Ford algorithm<\/a><\/li><li><a href=\"https:\/\/docs.scipy.org\/doc\/scipy\/reference\/generated\/scipy.sparse.csgraph.dijkstra.html\">scipy.sparse.csgraph.dijkstra library<\/a><\/li><li>Arbitrage Strategy using Negative Cycle Detection Algorithm<\/li><li><a href=\"https:\/\/www.ijisrt.com\/assets\/upload\/files\/IJISRT20MAY047.pdf\">Currency aribitrage detection<\/a><\/li><\/ul>\n\n\n\n<p><em>Stay tuned for the next installment in which Mario Pisa will discuss use the Dijkstra algorithm.<\/em><\/p>\n\n\n\n<p><em>Visit QuantInsti for additional insight on this topic:&nbsp;<a href=\"https:\/\/blog.quantinsti.com\/dijkstra-algorithm\/\">https:\/\/blog.quantinsti.com\/dijkstra-algorithm\/<\/a><\/em><\/p>\n","protected":false},"excerpt":{"rendered":"<p> Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.<\/p>\n","protected":false},"author":387,"featured_media":50791,"comment_status":"closed","ping_status":"open","sticky":true,"template":"","format":"standard","meta":{"_acf_changed":false,"footnotes":""},"categories":[339,343,349,338,350,341,351,344],"tags":[851,7257,10530,10526,865,10529,10527,10528,10555],"contributors-categories":[13654],"class_list":{"0":"post-108473","1":"post","2":"type-post","3":"status-publish","4":"format-standard","5":"has-post-thumbnail","7":"category-data-science","8":"category-programing-languages","9":"category-python-development","10":"category-ibkr-quant-news","11":"category-quant-asia-pacific","12":"category-quant-development","13":"category-quant-europe","14":"category-quant-regions","15":"tag-algo-trading","16":"tag-algorithmic-trading","17":"tag-bellman-algorithm","18":"tag-dijkstra-algorithm","19":"tag-github","20":"tag-johnson-algorithm","21":"tag-kruskal-algorithm","22":"tag-prim-algorithm","23":"tag-pseudo-code-py","24":"contributors-categories-quantinsti"},"pp_statuses_selecting_workflow":false,"pp_workflow_action":"current","pp_status_selection":"publish","acf":[],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v26.9 (Yoast SEO v27.3) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Dijkstra Algorithm \u2013 Part II | IBKR Quant<\/title>\n<meta name=\"description\" content=\"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.\" \/>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/www.interactivebrokers.com\/campus\/wp-json\/wp\/v2\/posts\/108473\/\" \/>\n<meta property=\"og:locale\" content=\"en_US\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Dijkstra Algorithm \u2013 Part II | IBKR Quant Blog\" \/>\n<meta property=\"og:description\" content=\"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/\" \/>\n<meta property=\"og:site_name\" content=\"IBKR Campus US\" \/>\n<meta property=\"article:published_time\" content=\"2021-10-25T15:37:20+00:00\" \/>\n<meta property=\"article:modified_time\" content=\"2022-11-21T14:48:42+00:00\" \/>\n<meta property=\"og:image\" content=\"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg\" \/>\n\t<meta property=\"og:image:width\" content=\"900\" \/>\n\t<meta property=\"og:image:height\" content=\"550\" \/>\n\t<meta property=\"og:image:type\" content=\"image\/jpeg\" \/>\n<meta name=\"author\" content=\"Mario Pisa\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Written by\" \/>\n\t<meta name=\"twitter:data1\" content=\"Mario Pisa\" \/>\n\t<meta name=\"twitter:label2\" content=\"Est. reading time\" \/>\n\t<meta name=\"twitter:data2\" content=\"2 minutes\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\n\t    \"@context\": \"https:\\\/\\\/schema.org\",\n\t    \"@graph\": [\n\t        {\n\t            \"@type\": \"NewsArticle\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/#article\",\n\t            \"isPartOf\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/\"\n\t            },\n\t            \"author\": {\n\t                \"name\": \"Mario Pisa\",\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/person\\\/f2bfe36ae4f6f088b98f90558d37ed12\"\n\t            },\n\t            \"headline\": \"Dijkstra Algorithm \u2013 Part II\",\n\t            \"datePublished\": \"2021-10-25T15:37:20+00:00\",\n\t            \"dateModified\": \"2022-11-21T14:48:42+00:00\",\n\t            \"mainEntityOfPage\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/\"\n\t            },\n\t            \"wordCount\": 333,\n\t            \"publisher\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/#primaryimage\"\n\t            },\n\t            \"thumbnailUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/machine-learning-sphere.jpg\",\n\t            \"keywords\": [\n\t                \"Algo Trading\",\n\t                \"Algorithmic Trading\",\n\t                \"Bellman algorithm\",\n\t                \"Dijkstra algorithm\",\n\t                \"GitHub\",\n\t                \"Johnson algorithm\",\n\t                \"Kruskal algorithm\",\n\t                \"Prim algorithm\",\n\t                \"Pseudo code.py\"\n\t            ],\n\t            \"articleSection\": [\n\t                \"Data Science\",\n\t                \"Programming Languages\",\n\t                \"Python Development\",\n\t                \"Quant\",\n\t                \"Quant Asia Pacific\",\n\t                \"Quant Development\",\n\t                \"Quant Europe\",\n\t                \"Quant Regions\"\n\t            ],\n\t            \"inLanguage\": \"en-US\"\n\t        },\n\t        {\n\t            \"@type\": \"WebPage\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/\",\n\t            \"name\": \"Dijkstra Algorithm \u2013 Part II | IBKR Quant Blog\",\n\t            \"isPartOf\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#website\"\n\t            },\n\t            \"primaryImageOfPage\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/#primaryimage\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/#primaryimage\"\n\t            },\n\t            \"thumbnailUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/machine-learning-sphere.jpg\",\n\t            \"datePublished\": \"2021-10-25T15:37:20+00:00\",\n\t            \"dateModified\": \"2022-11-21T14:48:42+00:00\",\n\t            \"description\": \"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.\",\n\t            \"inLanguage\": \"en-US\",\n\t            \"potentialAction\": [\n\t                {\n\t                    \"@type\": \"ReadAction\",\n\t                    \"target\": [\n\t                        \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/\"\n\t                    ]\n\t                }\n\t            ]\n\t        },\n\t        {\n\t            \"@type\": \"ImageObject\",\n\t            \"inLanguage\": \"en-US\",\n\t            \"@id\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/ibkr-quant-news\\\/dijkstra-algorithm-part-ii\\\/#primaryimage\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/machine-learning-sphere.jpg\",\n\t            \"contentUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2020\\\/07\\\/machine-learning-sphere.jpg\",\n\t            \"width\": 900,\n\t            \"height\": 550,\n\t            \"caption\": \"Machine Learning\"\n\t        },\n\t        {\n\t            \"@type\": \"WebSite\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#website\",\n\t            \"url\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/\",\n\t            \"name\": \"IBKR Campus US\",\n\t            \"description\": \"Financial Education from Interactive Brokers\",\n\t            \"publisher\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\"\n\t            },\n\t            \"potentialAction\": [\n\t                {\n\t                    \"@type\": \"SearchAction\",\n\t                    \"target\": {\n\t                        \"@type\": \"EntryPoint\",\n\t                        \"urlTemplate\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/?s={search_term_string}\"\n\t                    },\n\t                    \"query-input\": {\n\t                        \"@type\": \"PropertyValueSpecification\",\n\t                        \"valueRequired\": true,\n\t                        \"valueName\": \"search_term_string\"\n\t                    }\n\t                }\n\t            ],\n\t            \"inLanguage\": \"en-US\"\n\t        },\n\t        {\n\t            \"@type\": \"Organization\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#organization\",\n\t            \"name\": \"Interactive Brokers\",\n\t            \"alternateName\": \"IBKR\",\n\t            \"url\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/\",\n\t            \"logo\": {\n\t                \"@type\": \"ImageObject\",\n\t                \"inLanguage\": \"en-US\",\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/logo\\\/image\\\/\",\n\t                \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2024\\\/05\\\/ibkr-campus-logo.jpg\",\n\t                \"contentUrl\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/wp-content\\\/uploads\\\/sites\\\/2\\\/2024\\\/05\\\/ibkr-campus-logo.jpg\",\n\t                \"width\": 669,\n\t                \"height\": 669,\n\t                \"caption\": \"Interactive Brokers\"\n\t            },\n\t            \"image\": {\n\t                \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/logo\\\/image\\\/\"\n\t            },\n\t            \"publishingPrinciples\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/about-ibkr-campus\\\/\",\n\t            \"ethicsPolicy\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/cyber-security-notice\\\/\"\n\t        },\n\t        {\n\t            \"@type\": \"Person\",\n\t            \"@id\": \"https:\\\/\\\/ibkrcampus.com\\\/campus\\\/#\\\/schema\\\/person\\\/f2bfe36ae4f6f088b98f90558d37ed12\",\n\t            \"name\": \"Mario Pisa\",\n\t            \"url\": \"https:\\\/\\\/www.interactivebrokers.com\\\/campus\\\/author\\\/mariopisa\\\/\"\n\t        }\n\t    ]\n\t}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Dijkstra Algorithm \u2013 Part II | IBKR Quant","description":"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/www.interactivebrokers.com\/campus\/wp-json\/wp\/v2\/posts\/108473\/","og_locale":"en_US","og_type":"article","og_title":"Dijkstra Algorithm \u2013 Part II | IBKR Quant Blog","og_description":"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.","og_url":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/","og_site_name":"IBKR Campus US","article_published_time":"2021-10-25T15:37:20+00:00","article_modified_time":"2022-11-21T14:48:42+00:00","og_image":[{"width":900,"height":550,"url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","type":"image\/jpeg"}],"author":"Mario Pisa","twitter_card":"summary_large_image","twitter_misc":{"Written by":"Mario Pisa","Est. reading time":"2 minutes"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"NewsArticle","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/#article","isPartOf":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/"},"author":{"name":"Mario Pisa","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/person\/f2bfe36ae4f6f088b98f90558d37ed12"},"headline":"Dijkstra Algorithm \u2013 Part II","datePublished":"2021-10-25T15:37:20+00:00","dateModified":"2022-11-21T14:48:42+00:00","mainEntityOfPage":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/"},"wordCount":333,"publisher":{"@id":"https:\/\/ibkrcampus.com\/campus\/#organization"},"image":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/#primaryimage"},"thumbnailUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","keywords":["Algo Trading","Algorithmic Trading","Bellman algorithm","Dijkstra algorithm","GitHub","Johnson algorithm","Kruskal algorithm","Prim algorithm","Pseudo code.py"],"articleSection":["Data Science","Programming Languages","Python Development","Quant","Quant Asia Pacific","Quant Development","Quant Europe","Quant Regions"],"inLanguage":"en-US"},{"@type":"WebPage","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/","url":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/","name":"Dijkstra Algorithm \u2013 Part II | IBKR Quant Blog","isPartOf":{"@id":"https:\/\/ibkrcampus.com\/campus\/#website"},"primaryImageOfPage":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/#primaryimage"},"image":{"@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/#primaryimage"},"thumbnailUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","datePublished":"2021-10-25T15:37:20+00:00","dateModified":"2022-11-21T14:48:42+00:00","description":"Mario Pisa reviews how the Dijkstra algorithm works in pseudo-code before looking at the Python implementation.","inLanguage":"en-US","potentialAction":[{"@type":"ReadAction","target":["https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/"]}]},{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/www.interactivebrokers.com\/campus\/ibkr-quant-news\/dijkstra-algorithm-part-ii\/#primaryimage","url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","contentUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","width":900,"height":550,"caption":"Machine Learning"},{"@type":"WebSite","@id":"https:\/\/ibkrcampus.com\/campus\/#website","url":"https:\/\/ibkrcampus.com\/campus\/","name":"IBKR Campus US","description":"Financial Education from Interactive Brokers","publisher":{"@id":"https:\/\/ibkrcampus.com\/campus\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/ibkrcampus.com\/campus\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"en-US"},{"@type":"Organization","@id":"https:\/\/ibkrcampus.com\/campus\/#organization","name":"Interactive Brokers","alternateName":"IBKR","url":"https:\/\/ibkrcampus.com\/campus\/","logo":{"@type":"ImageObject","inLanguage":"en-US","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/logo\/image\/","url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2024\/05\/ibkr-campus-logo.jpg","contentUrl":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2024\/05\/ibkr-campus-logo.jpg","width":669,"height":669,"caption":"Interactive Brokers"},"image":{"@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/logo\/image\/"},"publishingPrinciples":"https:\/\/www.interactivebrokers.com\/campus\/about-ibkr-campus\/","ethicsPolicy":"https:\/\/www.interactivebrokers.com\/campus\/cyber-security-notice\/"},{"@type":"Person","@id":"https:\/\/ibkrcampus.com\/campus\/#\/schema\/person\/f2bfe36ae4f6f088b98f90558d37ed12","name":"Mario Pisa","url":"https:\/\/www.interactivebrokers.com\/campus\/author\/mariopisa\/"}]}},"jetpack_featured_media_url":"https:\/\/www.interactivebrokers.com\/campus\/wp-content\/uploads\/sites\/2\/2020\/07\/machine-learning-sphere.jpg","_links":{"self":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts\/108473","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/users\/387"}],"replies":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/comments?post=108473"}],"version-history":[{"count":0,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/posts\/108473\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/media\/50791"}],"wp:attachment":[{"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/media?parent=108473"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/categories?post=108473"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/tags?post=108473"},{"taxonomy":"contributors-categories","embeddable":true,"href":"https:\/\/ibkrcampus.com\/campus\/wp-json\/wp\/v2\/contributors-categories?post=108473"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}