<?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: Nishanth</title>
    <description>The latest articles on DEV Community by Nishanth (@nishanth023).</description>
    <link>https://dev.to/nishanth023</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%2F589048%2Fa1771f81-c6c7-4531-944d-b946ccce565e.png</url>
      <title>DEV Community: Nishanth</title>
      <link>https://dev.to/nishanth023</link>
    </image>
    <atom:link rel="self" type="application/rss+xml" href="https://dev.to/feed/nishanth023"/>
    <language>en</language>
    <item>
      <title>Roadmap for beginners  to  Competitive programming</title>
      <dc:creator>Nishanth</dc:creator>
      <pubDate>Wed, 17 Mar 2021 13:57:33 +0000</pubDate>
      <link>https://dev.to/nishanth023/roadmap-for-beginners-to-competitive-programming-jed</link>
      <guid>https://dev.to/nishanth023/roadmap-for-beginners-to-competitive-programming-jed</guid>
      <description>&lt;h1&gt;
  
  
  What is Competitive Programming?
&lt;/h1&gt;

&lt;p&gt;It's basically a mind-sport where you are given a problem and you have come up with optimized solutions for given constraints with your coding skills. This helps in building our logical thinking and analytical thinking skills and most importantly your data structure and algorithms knowledge.&lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fhki0zg4pdzztwgy6nftx.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fhki0zg4pdzztwgy6nftx.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Learn a language
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;1:&lt;/strong&gt; The most preferred language used in competitive programming is C++, Java. I prefer C++ always because it is flexible, very fast. C++ has many  Data structures and Algorithms built-in library which makes it easier while coding.&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;2:&lt;/strong&gt; Java This language is also used widely in programming but one drawback is it is not suitable for beginner programmers because it is longer code to write and not beginner-friendly.&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fgg8i67mru9984ltzr4gx.jpg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fgg8i67mru9984ltzr4gx.jpg" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Practice basic problems from these sites.
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;Hackerrank&lt;/strong&gt;&lt;/p&gt;

&lt;p&gt;I think this will be one of the best beginner-friendly websites for practicing basic problems. here there a wide range of problems from beginner to advanced. Even we can practice in different languages C, C++, Java, Python, etc...&lt;/p&gt;

&lt;p&gt;&lt;strong&gt;HackerEarth&lt;/strong&gt;&lt;br&gt;
HackerEarth is an Indian company focusing on coding problems and hiring challenges. Even this platform provides good beginner-friendly questions. Here there will monthly contest held where you can participate. this website has tutorials for all practice topics. It hosts competitions conducted by various MNC's and Colleges &lt;/p&gt;

&lt;p&gt;I think these two websites are more enough for practicing basic questions. &lt;/p&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fp0l16txfiwwxmym5ihns.gif" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2Fp0l16txfiwwxmym5ihns.gif" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Learn Data structure and Algorithms
&lt;/h3&gt;

&lt;p&gt;Once you are done with the basics of coding and practicing it then it's time to learn &lt;strong&gt;Data Structure And Algorithms&lt;/strong&gt;.&lt;br&gt;
&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F4al9ndrvyq8vq2f9bdxb.jpeg" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F4al9ndrvyq8vq2f9bdxb.jpeg" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;This is the most important thing that should be learned and practiced. Having good knowledge of Ds&amp;amp;Algo will make up a more optimal solution for the problem we are trying to solve. &lt;/p&gt;

&lt;h3&gt;
  
  
  Important Data Structures and Algorithm Topics:
&lt;/h3&gt;

&lt;div class="highlight js-code-highlight"&gt;
&lt;pre class="highlight plaintext"&gt;&lt;code&gt;* Array
* Stack
* Queue
* Linked list
* Tree's
* Graph's
* Hash table's 
* Trie's
* Dynamic Programming 
* Divide and Conquer 
* Backtracking
&lt;/code&gt;&lt;/pre&gt;

&lt;/div&gt;

&lt;p&gt;&lt;a href="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9ir8bjf3grjggk9x932n.png" class="article-body-image-wrapper"&gt;&lt;img src="https://media.dev.to/dynamic/image/width=800%2Cheight=%2Cfit=scale-down%2Cgravity=auto%2Cformat=auto/https%3A%2F%2Fdev-to-uploads.s3.amazonaws.com%2Fuploads%2Farticles%2F9ir8bjf3grjggk9x932n.png" alt="Alt Text"&gt;&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Pratice..Practice...Pratice....
&lt;/h3&gt;

&lt;p&gt;Next is completely based on your practice to be master in competitive programming."&lt;strong&gt;The more you practice the more you get stronger&lt;/strong&gt;" &lt;/p&gt;

&lt;p&gt;There are different websites you can practice competitive programming &lt;/p&gt;

&lt;p&gt;&lt;strong&gt;1:&lt;/strong&gt;&lt;a href="https://www.codechef.com/" rel="noopener noreferrer"&gt;Codechef&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;2:&lt;/strong&gt;&lt;a href="https://codeforces.com/" rel="noopener noreferrer"&gt;Codeforces&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;3:&lt;/strong&gt;&lt;a href="https://www.topcoder.com/" rel="noopener noreferrer"&gt;Topcoder&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;4:&lt;/strong&gt;&lt;a href="https://www.spoj.com/" rel="noopener noreferrer"&gt;Sphere Online Judge&lt;/a&gt;&lt;/p&gt;

&lt;h3&gt;
  
  
  Resources.
&lt;/h3&gt;

&lt;p&gt;&lt;strong&gt;1:&lt;/strong&gt; &lt;a href="https://www.amazon.com/Introduction-Algorithms-3rd-MIT-Press/dp/0262033844" rel="noopener noreferrer"&gt;Introduction To Algorithms&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;2:&lt;/strong&gt; &lt;a href="https://ocw.mit.edu/courses/electrical-engineering-and-computer-science/6-006-introduction-to-algorithms-spring-2008/" rel="noopener noreferrer"&gt;MIT OpenCourseWare&lt;/a&gt;&lt;br&gt;
&lt;strong&gt;3:&lt;/strong&gt; &lt;a href="http://cp-algorithms.com/" rel="noopener noreferrer"&gt;Cp-Algorithms&lt;/a&gt;&lt;/p&gt;

&lt;p&gt;Even you can go through &lt;a href="https://www.geeksforgeeks.org/" rel="noopener noreferrer"&gt;GeeksforGeeks&lt;/a&gt; for additional reference.&lt;/p&gt;

&lt;p&gt;Everything cannot be done overnight. You have to be focused on your learning and practicing problems. Just put up your goals, time table and follow through with it. Atlast I would say three words &lt;strong&gt;Take it easy&lt;/strong&gt;&lt;/p&gt;

</description>
      <category>computerscience</category>
      <category>programming</category>
      <category>coding</category>
      <category>algorithms</category>
    </item>
  </channel>
</rss>
