<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom">
  <channel>
    <title>ignoramus on jonah vairon</title>
    <link>https://58e1b19d.site-bk0.pages.dev/tags/ignoramus/</link>
    <description>Recent content in ignoramus on jonah vairon</description>
    <generator>Hugo</generator>
    <language>en-uk</language>
    <copyright>© 2025 Jonah Vairon</copyright>
    <lastBuildDate>Thu, 07 Mar 2024 00:00:00 +0100</lastBuildDate>
    <atom:link href="https://58e1b19d.site-bk0.pages.dev/tags/ignoramus/index.xml" rel="self" type="application/rss+xml" />
    <item>
      <title>three ways to check for anagrams</title>
      <link>https://58e1b19d.site-bk0.pages.dev/writing/three-ways-to-check-for-anagrams/</link>
      <pubDate>Thu, 07 Mar 2024 00:00:00 +0100</pubDate>
      <guid>https://58e1b19d.site-bk0.pages.dev/writing/three-ways-to-check-for-anagrams/</guid>
      <description>&lt;h2 id=&#34;problem&#34;&gt;problem&lt;/h2&gt;&#xA;&lt;p&gt;Given 2 strings, check that they are anagrams.&lt;/p&gt;&#xA;&lt;h2 id=&#34;solutions&#34;&gt;solutions&lt;/h2&gt;&#xA;&lt;h3 id=&#34;worst&#34;&gt;worst&lt;/h3&gt;&#xA;&lt;p&gt;Perhaps the most intuitive approach: look at each character in the first&#xA;string and check it&amp;rsquo;s in the second string by iterating through its&#xA;characters. If a character in the first string isn&amp;rsquo;t present in the first,&#xA;return &lt;code&gt;False&lt;/code&gt;. Otherwise, remove the matched character from the second string so&#xA;it isn&amp;rsquo;t matched again going forward.&lt;/p&gt;&#xA;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#c8d3f5;background-color:#222436;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-python&#34; data-lang=&#34;python&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#c099ff&#34;&gt;def&lt;/span&gt; &lt;span style=&#34;color:#82aaff&#34;&gt;are_anagrams&lt;/span&gt;(s1: &lt;span style=&#34;color:#c3e88d&#34;&gt;str&lt;/span&gt;, s2: &lt;span style=&#34;color:#c3e88d&#34;&gt;str&lt;/span&gt;) &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;-&amp;gt;&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;bool&lt;/span&gt;:&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    &lt;span style=&#34;color:#444a73;font-style:italic&#34;&gt;# no point proceeding if the strings aren&amp;#39;t even of the same length&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    &lt;span style=&#34;color:#c099ff&#34;&gt;if&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;len&lt;/span&gt;(s1) &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;!=&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;len&lt;/span&gt;(s2):&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;        &lt;span style=&#34;color:#c099ff&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#ffc777&#34;&gt;False&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    &lt;span style=&#34;color:#c099ff&#34;&gt;for&lt;/span&gt; ch1 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;in&lt;/span&gt; s1:&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;        in_s2 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ffc777&#34;&gt;False&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;        &lt;span style=&#34;color:#c099ff&#34;&gt;for&lt;/span&gt; i, ch2 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;in&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;enumerate&lt;/span&gt;(s2):&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;            &lt;span style=&#34;color:#c099ff&#34;&gt;if&lt;/span&gt; ch1 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;==&lt;/span&gt; ch2:&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;                in_s2 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#ffc777&#34;&gt;True&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;                &lt;span style=&#34;color:#c099ff&#34;&gt;break&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;        &lt;span style=&#34;color:#c099ff&#34;&gt;if&lt;/span&gt; in_s2:&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;            &lt;span style=&#34;color:#444a73;font-style:italic&#34;&gt;# remove matched char from s2&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;            s2 &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; s2[:i] &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;+&lt;/span&gt; s2[i&lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;+&lt;/span&gt;&lt;span style=&#34;color:#ffc777&#34;&gt;1&lt;/span&gt;:]&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;        &lt;span style=&#34;color:#c099ff&#34;&gt;else&lt;/span&gt;:&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;            &lt;span style=&#34;color:#c099ff&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#ffc777&#34;&gt;False&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;    &lt;span style=&#34;color:#c099ff&#34;&gt;return&lt;/span&gt; &lt;span style=&#34;color:#ffc777&#34;&gt;True&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;x &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;&amp;#39;fried&amp;#39;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;y &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;&amp;#39;fired&amp;#39;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;z &lt;span style=&#34;color:#c3e88d;font-weight:bold&#34;&gt;=&lt;/span&gt; &lt;span style=&#34;color:#c3e88d&#34;&gt;&amp;#39;fixed&amp;#39;&lt;/span&gt;&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#c3e88d&#34;&gt;print&lt;/span&gt;(are_anagrams(x,y))&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;&lt;span style=&#34;color:#c3e88d&#34;&gt;print&lt;/span&gt;(are_anagrams(x,z))&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;div class=&#34;highlight&#34;&gt;&lt;pre tabindex=&#34;0&#34; style=&#34;color:#c8d3f5;background-color:#222436;-moz-tab-size:4;-o-tab-size:4;tab-size:4;&#34;&gt;&lt;code class=&#34;language-text&#34; data-lang=&#34;text&#34;&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;True&#xA;&lt;/span&gt;&lt;/span&gt;&lt;span style=&#34;display:flex;&#34;&gt;&lt;span&gt;False&#xA;&lt;/span&gt;&lt;/span&gt;&lt;/code&gt;&lt;/pre&gt;&lt;/div&gt;&lt;p&gt;While straightforward, it&amp;rsquo;s the worst approach because its \(O(n^{2})\).&lt;/p&gt;</description>
    </item>
  </channel>
</rss>
