{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "('amanaplanacanalpanama', 'amanaplanacanalpanama')"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "def is_palindrome_ignore_case_and_spaces(s: str) -> bool:\n",
    "    filtered = \"\".join(\n",
    "        c.lower() for c in s if c.isalnum()\n",
    "    )  # Keep only alphanumeric characters\n",
    "    return filtered, filtered[::-1]\n",
    "\n",
    "\n",
    "res = is_palindrome_ignore_case_and_spaces(\"A man, a plan, a canal: Panama\")\n",
    "res\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "assert res == True, \"Expected True but got {}\".format(res)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "def is_woodall(num):\n",
    "    if num % 2 != 0:\n",
    "        for n in range(2, num + 1):\n",
    "            for k in range(1, num + 1):\n",
    "                if n * (2**k) - 1 == num:\n",
    "                    return True\n",
    "    return False\n",
    "\n",
    "\n",
    "assert is_woodall(383) == True\n",
    "assert is_woodall(254) == False\n",
    "assert is_woodall(200) == False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def is_woodall(x):\n",
    "    if not isinstance(x, int):\n",
    "        return False\n",
    "    if x <= 0 or x % 2 == 0:\n",
    "        return False\n",
    "    if x == 1:\n",
    "        return True\n",
    "    x += 1\n",
    "    i = 0\n",
    "    while x % 2 == 0:\n",
    "        x /= 2\n",
    "        i += 1\n",
    "        if i == x:\n",
    "            return True\n",
    "    return False\n",
    "\n",
    "\n",
    "assert is_woodall(383) == True\n",
    "assert is_woodall(254) == False\n",
    "assert is_woodall(200) == False"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[14], line 238\u001b[0m\n\u001b[1;32m    131\u001b[0m results \u001b[38;5;241m=\u001b[39m [\n\u001b[1;32m    132\u001b[0m     \u001b[38;5;28;01mTrue\u001b[39;00m,\n\u001b[1;32m    133\u001b[0m     \u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    235\u001b[0m     \u001b[38;5;28;01mFalse\u001b[39;00m,\n\u001b[1;32m    236\u001b[0m ]\n\u001b[1;32m    237\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m i, (inp, exp) \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28menumerate\u001b[39m(\u001b[38;5;28mzip\u001b[39m(inputs, results)):\n\u001b[0;32m--> 238\u001b[0m     assertion(\u001b[43mis_woodall\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43minp\u001b[49m\u001b[43m)\u001b[49m, exp, \u001b[38;5;241m0\u001b[39m)\n",
      "Cell \u001b[0;32mIn[13], line 5\u001b[0m, in \u001b[0;36mis_woodall\u001b[0;34m(num)\u001b[0m\n\u001b[1;32m      3\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m n \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m2\u001b[39m, num \u001b[38;5;241m+\u001b[39m \u001b[38;5;241m1\u001b[39m):\n\u001b[1;32m      4\u001b[0m         \u001b[38;5;28;01mfor\u001b[39;00m k \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m1\u001b[39m, num \u001b[38;5;241m+\u001b[39m \u001b[38;5;241m1\u001b[39m):\n\u001b[0;32m----> 5\u001b[0m             \u001b[38;5;28;01mif\u001b[39;00m n \u001b[38;5;241m*\u001b[39m (\u001b[38;5;241;43m2\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mk\u001b[49m) \u001b[38;5;241m-\u001b[39m \u001b[38;5;241m1\u001b[39m \u001b[38;5;241m==\u001b[39m num:\n\u001b[1;32m      6\u001b[0m                 \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[1;32m      7\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;01mFalse\u001b[39;00m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from math import inf\n",
    "\n",
    "\n",
    "def is_floats(x) -> bool:\n",
    "    # check if it is float; List[float]; Tuple[float]\n",
    "    if isinstance(x, float):\n",
    "        return True\n",
    "    if isinstance(x, (list, tuple)):\n",
    "        return all(isinstance(i, float) for i in x)\n",
    "    if isinstance(x, np.ndarray):\n",
    "        return x.dtype == np.float64 or x.dtype == np.float32\n",
    "    return False\n",
    "\n",
    "\n",
    "def assertion(out, exp, atol):\n",
    "    if atol == 0 and is_floats(exp):\n",
    "        atol = 1e-6\n",
    "    if out != exp and atol != 0:\n",
    "        assert np.allclose(out, exp, rtol=1e-07, atol=atol)\n",
    "    else:\n",
    "        assert out == exp, f\"out: {out}, exp: {exp}\"\n",
    "\n",
    "\n",
    "inputs = [\n",
    "    [383],\n",
    "    [254],\n",
    "    [200],\n",
    "    [123456789],\n",
    "    [123456788],\n",
    "    [123456790],\n",
    "    [-71],\n",
    "    [-43.858003490436445],\n",
    "    [-29.61114685387961],\n",
    "    [123456791],\n",
    "    [True],\n",
    "    [-26.959954047393943],\n",
    "    [-36.19806730921029],\n",
    "    [False],\n",
    "    [123456792],\n",
    "    [123456793],\n",
    "    [-29.871125367901588],\n",
    "    [-29.522652685174876],\n",
    "    [-28.83173048562741],\n",
    "    [-36.46340914477242],\n",
    "    [-21.3952610510801],\n",
    "    [-54.31098212859848],\n",
    "    [-29.97825041127243],\n",
    "    [-69.13149487461008],\n",
    "    [-69.25331473635698],\n",
    "    [-30.672425597981977],\n",
    "    [-70],\n",
    "    [-31.492472971818966],\n",
    "    [-23.37512371019188],\n",
    "    [-26.87584184061303],\n",
    "    [-68.8018442158572],\n",
    "    [-72],\n",
    "    [-68.9582596167829],\n",
    "    [-38.639304621786174],\n",
    "    [-36.762574512172826],\n",
    "    [-29.71114112102485],\n",
    "    [-29.147181618179903],\n",
    "    [-45.96312293984687],\n",
    "    [-62.29011681998471],\n",
    "    [-102.18510964864885],\n",
    "    [-37.926042220673814],\n",
    "    [-21.669838537346024],\n",
    "    [-58.62219921432578],\n",
    "    [-49.3200214561046],\n",
    "    [-20.415110882873073],\n",
    "    [-70.16424320159742],\n",
    "    [-40.25945493003661],\n",
    "    [-70.28083008878951],\n",
    "    [-29.42426596564329],\n",
    "    [-36.42835541123631],\n",
    "    [-68.24706572951847],\n",
    "    [-69.41855382525948],\n",
    "    [-14.166058474029754],\n",
    "    [-62.72457764448362],\n",
    "    [-67.51407654646718],\n",
    "    [-43.87699809663642],\n",
    "    [-20.51986489168823],\n",
    "    [-15.085356836638901],\n",
    "    [-67.0567942382996],\n",
    "    [-19.580182972529585],\n",
    "    [-39.15390942077779],\n",
    "    [-35.784031914737916],\n",
    "    [-60.94797432645206],\n",
    "    [-30.593131467080347],\n",
    "    [-28.30344245006401],\n",
    "    [-29.774227963592523],\n",
    "    [88.42189273276318],\n",
    "    [123456794],\n",
    "    [-31.744787544004495],\n",
    "    [-68.40811941759871],\n",
    "    [-56.99871844685891],\n",
    "    [92.98004923674453],\n",
    "    [-29.38824771469962],\n",
    "    [-28.112821077251972],\n",
    "    [-59.66653455441657],\n",
    "    [-28.408958976827417],\n",
    "    [-34.246016042728264],\n",
    "    [-37.459933039490544],\n",
    "    [-69.08278583390873],\n",
    "    [-31.39943780262713],\n",
    "    [-27.08300242071865],\n",
    "    [-32.23443641065063],\n",
    "    [-16.35377974137643],\n",
    "    [-34.49166282951802],\n",
    "    [-80.04075575777426],\n",
    "    [-15.990708397802807],\n",
    "    [-37.17075988866512],\n",
    "    [-12.266024087946377],\n",
    "    [-42.995821326318705],\n",
    "    [-36.571652101601906],\n",
    "    [-36.40347054615233],\n",
    "    [-70.43269469508628],\n",
    "    [-28.726570985744708],\n",
    "    [-14.941982364755784],\n",
    "    [-26.521563448513206],\n",
    "    [-52.0451679843239],\n",
    "    [-41.16822642698813],\n",
    "    [-27.427877745731756],\n",
    "    [93.65722410276985],\n",
    "    [-61.5774096007493],\n",
    "    [-32.14674769877757],\n",
    "    [-21.464380924877055],\n",
    "    [-67.55449156821463],\n",
    "    [91.99125730826226],\n",
    "]\n",
    "results = [\n",
    "    True,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    True,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "    False,\n",
    "]\n",
    "for i, (inp, exp) in enumerate(zip(inputs, results)):\n",
    "    assertion(is_woodall(*inp), exp, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [],
   "source": [
    "def remove_Occ(s, ch):\n",
    "    s = s.replace(ch, \"\", 1)\n",
    "    s = s[::-1].replace(ch, \"\", 1)[::-1]\n",
    "    return s\n",
    "\n",
    "\n",
    "assert remove_Occ(\"hello\", \"l\") == \"heo\"\n",
    "assert remove_Occ(\"abcda\", \"a\") == \"bcd\"\n",
    "assert remove_Occ(\"PHP\", \"P\") == \"H\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def remove_Occ(test_str, test_char):\n",
    "    res = test_str.replace(test_char, \"\", 1).replace(test_char, \"\")\n",
    "    return res\n",
    "\n",
    "\n",
    "assert remove_Occ(\"hello\", \"l\") == \"heo\"\n",
    "assert remove_Occ(\"abcda\", \"a\") == \"bcd\"\n",
    "assert remove_Occ(\"PHP\", \"P\") == \"H\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "assert remove_Occ(\"hello\",\"l\") == \"heo\"\n",
      "assert remove_Occ(\"abcda\",\"a\") == \"bcd\"\n",
      "assert remove_Occ(\"PHP\",\"P\") == \"H\"\n"
     ]
    }
   ],
   "source": [
    "for i in [\n",
    "    'assert remove_Occ(\"hello\",\"l\") == \"heo\"',\n",
    "    'assert remove_Occ(\"abcda\",\"a\") == \"bcd\"',\n",
    "    'assert remove_Occ(\"PHP\",\"P\") == \"H\"',\n",
    "]:\n",
    "    print(i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from math import inf\n",
    "\n",
    "\n",
    "def is_floats(x) -> bool:\n",
    "    # check if it is float; List[float]; Tuple[float]\n",
    "    if isinstance(x, float):\n",
    "        return True\n",
    "    if isinstance(x, (list, tuple)):\n",
    "        return all(isinstance(i, float) for i in x)\n",
    "    if isinstance(x, np.ndarray):\n",
    "        return x.dtype == np.float64 or x.dtype == np.float32\n",
    "    return False\n",
    "\n",
    "\n",
    "def assertion(out, exp, atol):\n",
    "    if atol == 0 and is_floats(exp):\n",
    "        atol = 1e-6\n",
    "    if out != exp and atol != 0:\n",
    "        assert np.allclose(out, exp, rtol=1e-07, atol=atol)\n",
    "    else:\n",
    "        assert out == exp, f\"out: {out}, exp: {exp}\"\n",
    "\n",
    "\n",
    "inputs = [\n",
    "    [\"hello\", \"l\"],\n",
    "    [\"abcda\", \"a\"],\n",
    "    [\"PHP\", \"P\"],\n",
    "    [\"a\", \"a\"],\n",
    "    [\"aaa\", \"a\"],\n",
    "    [\"hello world\", \"x\"],\n",
    "    [\"worlda\", \"a\"],\n",
    "    [\"x\", \"x\"],\n",
    "    [\"hello world\", \"a\"],\n",
    "    [\"world\", \"x\"],\n",
    "    [\"xx\", \"x\"],\n",
    "    [\"xworlaaada\", \"x\"],\n",
    "    [\"axworlaaada\", \"x\"],\n",
    "    [\"waaaorlda\", \"a\"],\n",
    "    [\"xhello world\", \"a\"],\n",
    "    [\"xxx\", \"x\"],\n",
    "    [\"worlda\", \"x\"],\n",
    "    [\"world\", \"a\"],\n",
    "    [\"hwllo world\", \"a\"],\n",
    "    [\"axx\", \"a\"],\n",
    "    [\"hwllo world\", \"x\"],\n",
    "    [\"hwllo\", \"a\"],\n",
    "    [\"hwl\", \"a\"],\n",
    "    [\"ahwllo world\", \"a\"],\n",
    "    [\"xxx\", \"a\"],\n",
    "    [\"hwll\", \"a\"],\n",
    "    [\"hhwl\", \"a\"],\n",
    "    [\"ahwllo\", \"x\"],\n",
    "    [\"whwlloorld\", \"a\"],\n",
    "    [\"wda\", \"x\"],\n",
    "    [\"hwl\", \"x\"],\n",
    "    [\"xrworlaaada\", \"x\"],\n",
    "    [\"aahwllo\", \"a\"],\n",
    "    [\"a\", \"x\"],\n",
    "    [\"xxwaaaorlda\", \"x\"],\n",
    "    [\"wda\", \"a\"],\n",
    "    [\"hxworlaaadawllo\", \"a\"],\n",
    "    [\"aaaa\", \"a\"],\n",
    "    [\"xrworworldalaaadax\", \"x\"],\n",
    "    [\"aaawda\", \"x\"],\n",
    "    [\"hello worldx\", \"x\"],\n",
    "    [\"xrworworldalaaadax\", \"a\"],\n",
    "    [\"xrworlaaadaworldx\", \"x\"],\n",
    "    [\"aahwllo\", \"x\"],\n",
    "    [\"xworlaaadaaaaa\", \"a\"],\n",
    "    [\"xxxx\", \"a\"],\n",
    "    [\"xhello worlda\", \"a\"],\n",
    "    [\"xrworworaldalaaadax\", \"a\"],\n",
    "    [\"xaaaa\", \"x\"],\n",
    "    [\"xxwaahello worldxaorlda\", \"x\"],\n",
    "    [\"axworlaaada\", \"a\"],\n",
    "    [\"worldxaorlda\", \"x\"],\n",
    "    [\"hellloa\", \"a\"],\n",
    "    [\"xaaa\", \"x\"],\n",
    "    [\"aa\", \"a\"],\n",
    "    [\"xhello\", \"a\"],\n",
    "    [\"xrworlaaaada\", \"x\"],\n",
    "    [\"axxxaawda\", \"x\"],\n",
    "    [\"hello worldxxhello worlda\", \"a\"],\n",
    "    [\"xhello\", \"x\"],\n",
    "    [\"hxworlaaadawlolo\", \"a\"],\n",
    "    [\"aa\", \"x\"],\n",
    "    [\"lo\", \"x\"],\n",
    "    [\"xaaaa\", \"a\"],\n",
    "    [\"waaaorllda\", \"a\"],\n",
    "    [\"ahwllao\", \"x\"],\n",
    "    [\"aaa\", \"x\"],\n",
    "    [\"xxhello\", \"x\"],\n",
    "    [\"wdaa\", \"a\"],\n",
    "    [\"xrworworaldalaaadaxa\", \"a\"],\n",
    "    [\"waaaorlxxwaaaorlda\", \"a\"],\n",
    "    [\"aahwllao\", \"x\"],\n",
    "    [\"hello worldx\", \"a\"],\n",
    "    [\"lo\", \"a\"],\n",
    "    [\"hellloa\", \"x\"],\n",
    "    [\"helwdalloa\", \"x\"],\n",
    "    [\"worldxxhellox\", \"x\"],\n",
    "    [\"hello\", \"x\"],\n",
    "    [\"l\", \"x\"],\n",
    "    [\"waaaorlldalo\", \"x\"],\n",
    "    [\"xrwax\", \"x\"],\n",
    "    [\"waaaorllda\", \"x\"],\n",
    "    [\"whwlloorld\", \"x\"],\n",
    "    [\"aahhwla\", \"x\"],\n",
    "    [\"waaaorlda\", \"x\"],\n",
    "    [\"llo\", \"l\"],\n",
    "    [\"axaahwllaoworlaaada\", \"a\"],\n",
    "    [\"hwllor world\", \"a\"],\n",
    "    [\"xworlaaadaaaaa\", \"x\"],\n",
    "    [\"waaaorlldal\", \"a\"],\n",
    "    [\"aahawllao\", \"x\"],\n",
    "    [\"lllo\", \"l\"],\n",
    "    [\"worlaaaadxaorlda\", \"x\"],\n",
    "    [\"hello worldxxhhelloworlda\", \"a\"],\n",
    "    [\"hwlll\", \"a\"],\n",
    "    [\"xrworwoxxxraldalaaadaxa\", \"a\"],\n",
    "    [\"ll\", \"x\"],\n",
    "    [\"aaahwllaoo\", \"a\"],\n",
    "    [\"worldx\", \"a\"],\n",
    "    [\"xrworworaldalaaadaxa\", \"x\"],\n",
    "    [\"hxworlaaadawlolo\", \"x\"],\n",
    "    [\"whello world\", \"x\"],\n",
    "    [\"ahwllo\", \"a\"],\n",
    "    [\"ahxworlaaadawlolo\", \"a\"],\n",
    "    [\"whello\", \"x\"],\n",
    "    [\"ax\", \"a\"],\n",
    "]\n",
    "results = [\n",
    "    \"heo\",\n",
    "    \"bcd\",\n",
    "    \"H\",\n",
    "    \"\",\n",
    "    \"a\",\n",
    "    \"hello world\",\n",
    "    \"world\",\n",
    "    \"\",\n",
    "    \"hello world\",\n",
    "    \"world\",\n",
    "    \"\",\n",
    "    \"worlaaada\",\n",
    "    \"aworlaaada\",\n",
    "    \"waaorld\",\n",
    "    \"xhello world\",\n",
    "    \"x\",\n",
    "    \"worlda\",\n",
    "    \"world\",\n",
    "    \"hwllo world\",\n",
    "    \"xx\",\n",
    "    \"hwllo world\",\n",
    "    \"hwllo\",\n",
    "    \"hwl\",\n",
    "    \"hwllo world\",\n",
    "    \"xxx\",\n",
    "    \"hwll\",\n",
    "    \"hhwl\",\n",
    "    \"ahwllo\",\n",
    "    \"whwlloorld\",\n",
    "    \"wda\",\n",
    "    \"hwl\",\n",
    "    \"rworlaaada\",\n",
    "    \"hwllo\",\n",
    "    \"a\",\n",
    "    \"waaaorlda\",\n",
    "    \"wd\",\n",
    "    \"hxworlaadwllo\",\n",
    "    \"aa\",\n",
    "    \"rworworldalaaada\",\n",
    "    \"aaawda\",\n",
    "    \"hello world\",\n",
    "    \"xrworworldlaaadx\",\n",
    "    \"rworlaaadaworld\",\n",
    "    \"aahwllo\",\n",
    "    \"xworlaadaaaa\",\n",
    "    \"xxxx\",\n",
    "    \"xhello world\",\n",
    "    \"xrworworldalaaadx\",\n",
    "    \"aaaa\",\n",
    "    \"xwaahello worldaorlda\",\n",
    "    \"xworlaaad\",\n",
    "    \"worldaorlda\",\n",
    "    \"helllo\",\n",
    "    \"aaa\",\n",
    "    \"\",\n",
    "    \"xhello\",\n",
    "    \"rworlaaaada\",\n",
    "    \"axaawda\",\n",
    "    \"hello worldxxhello world\",\n",
    "    \"hello\",\n",
    "    \"hxworlaadwlolo\",\n",
    "    \"aa\",\n",
    "    \"lo\",\n",
    "    \"xaa\",\n",
    "    \"waaorlld\",\n",
    "    \"ahwllao\",\n",
    "    \"aaa\",\n",
    "    \"hello\",\n",
    "    \"wd\",\n",
    "    \"xrworworldalaaadax\",\n",
    "    \"waaorlxxwaaaorld\",\n",
    "    \"aahwllao\",\n",
    "    \"hello worldx\",\n",
    "    \"lo\",\n",
    "    \"hellloa\",\n",
    "    \"helwdalloa\",\n",
    "    \"worldxhello\",\n",
    "    \"hello\",\n",
    "    \"l\",\n",
    "    \"waaaorlldalo\",\n",
    "    \"rwa\",\n",
    "    \"waaaorllda\",\n",
    "    \"whwlloorld\",\n",
    "    \"aahhwla\",\n",
    "    \"waaaorlda\",\n",
    "    \"o\",\n",
    "    \"xaahwllaoworlaaad\",\n",
    "    \"hwllor world\",\n",
    "    \"worlaaadaaaaa\",\n",
    "    \"waaorlldl\",\n",
    "    \"aahawllao\",\n",
    "    \"lo\",\n",
    "    \"worlaaaadaorlda\",\n",
    "    \"hello worldxxhhelloworld\",\n",
    "    \"hwlll\",\n",
    "    \"xrworwoxxxrldalaaadax\",\n",
    "    \"ll\",\n",
    "    \"aahwlloo\",\n",
    "    \"worldx\",\n",
    "    \"rworworaldalaaadaa\",\n",
    "    \"hworlaaadawlolo\",\n",
    "    \"whello world\",\n",
    "    \"hwllo\",\n",
    "    \"hxworlaaadwlolo\",\n",
    "    \"whello\",\n",
    "    \"x\",\n",
    "]\n",
    "for i, (inp, exp) in enumerate(zip(inputs, results)):\n",
    "    assertion(remove_Occ(*inp), exp, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pdlnew",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
