{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import pandas as pd\n",
    "\n",
    "results_json = os.environ.get(\"EVALPLUS_RESULTS_JSON\", \"/path/to/eval_results.json\")\n",
    "df = pd.read_json(results_json)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "df = df.dropna(subset=['eval'])\n",
    "df['solution'] = df['eval'].apply(lambda x: x[0]['solution'])\n",
    "df['base_status'] = df['eval'].apply(lambda x: x[0]['base_status'])\n",
    "df['plus_status'] = df['eval'].apply(lambda x: x[0]['plus_status'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "def is_palindrome(string: str) -> bool:\n",
      "    \"\"\" Test if given string is a palindrome \"\"\"\n",
      "    return string == string[::-1]\n",
      "def make_palindrome(string: str) -> str:\n",
      "    \"\"\" Find the shortest palindrome that begins with a supplied string.\n",
      "    Algorithm idea is simple:\n",
      "    - Find the longest postfix of supplied string that is a palindrome.\n",
      "    - Append to the end of the string reverse of a string prefix that comes before the palindromic suffix.\n",
      "    >>> make_palindrome('')\n",
      "    ''\n",
      "    >>> make_palindrome('cat')\n",
      "    'catac'\n",
      "    >>> make_palindrome('cata')\n",
      "    'catac'\n",
      "    \"\"\"\n",
      "    n = len(string)\n",
      "    if n == 0:\n",
      "        return string\n",
      "\n",
      "    # Find the longest palindromic suffix\n",
      "    for i in range(n - 1, -1, -1):\n",
      "        if is_palindrome(string[i:]):\n",
      "            break\n",
      "\n",
      "    # Append the reverse of the prefix before the palindromic suffix\n",
      "    return string + string[:i][::-1]\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def prime_fib(n: int):\n",
      "    \"\"\"\n",
      "    prime_fib returns n-th number that is a Fibonacci number and it's also prime.\n",
      "    >>> prime_fib(1)\n",
      "    2\n",
      "    >>> prime_fib(2)\n",
      "    3\n",
      "    >>> prime_fib(3)\n",
      "    5\n",
      "    >>> prime_fib(4)\n",
      "    13\n",
      "    >>> prime_fib(5)\n",
      "    89\n",
      "    \"\"\"\n",
      "    def is_prime(num: int) -> bool:\n",
      "        \"\"\"Check if a number is prime.\"\"\"\n",
      "        if num <= 1:\n",
      "            return False\n",
      "        if num <= 3:\n",
      "            return True\n",
      "        if num % 2 == 0 or num % 3 == 0:\n",
      "            return False\n",
      "        i = 5\n",
      "        while i * i <= num:\n",
      "            if num % i == 0 or num % (i + 2) == 0:\n",
      "                return False\n",
      "            i += 6\n",
      "        return True\n",
      "\n",
      "    def fibonacci(n: int) -> int:\n",
      "        \"\"\"Generate the n-th Fibonacci number.\"\"\"\n",
      "        a, b = 0, 1\n",
      "        for _ in range(n):\n",
      "            a, b = b, a + b\n",
      "        return a\n",
      "\n",
      "    count = 0\n",
      "    fib_index = 0\n",
      "    while count < n:\n",
      "        fib_number = fibonacci(fib_index)\n",
      "        if is_prime(fib_number):\n",
      "            count += 1\n",
      "            if fib_number == 2:  # 2 is the only even prime number\n",
      "                return fib_number\n",
      "        fib_index += 1\n",
      "\n",
      "    return None\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "import math\n",
      "def poly(xs: list, x: float):\n",
      "    \"\"\"\n",
      "    Evaluates polynomial with coefficients xs at point x.\n",
      "    return xs[0] + xs[1] * x + xs[1] * x^2 + .... xs[n] * x^n\n",
      "    \"\"\"\n",
      "    return sum([coeff * math.pow(x, i) for i, coeff in enumerate(xs)])\n",
      "def find_zero(xs: list):\n",
      "    \"\"\" xs are coefficients of a polynomial.\n",
      "    find_zero find x such that poly(x) = 0.\n",
      "    find_zero returns only only zero point, even if there are many.\n",
      "    Moreover, find_zero only takes list xs having even number of coefficients\n",
      "    and largest non zero coefficient as it guarantees\n",
      "    a solution.\n",
      "    >>> round(find_zero([1, 2]), 2) # f(x) = 1 + 2x\n",
      "    -0.5\n",
      "    >>> round(find_zero([-6, 11, -6, 1]), 2) # (x - 1) * (x - 2) * (x - 3) = -6 + 11x - 6x^2 + x^3\n",
      "    1.0\n",
      "    \"\"\"\n",
      "    # Find the largest non-zero coefficient\n",
      "    largest_coeff = max(abs(xs), key=abs)\n",
      "    largest_coeff_index = xs.index(largest_coeff)\n",
      "    \n",
      "    # Calculate the degree of the polynomial\n",
      "    degree = len(xs) - 1\n",
      "    \n",
      "    # Use Newton-Raphson method to find a zero\n",
      "    x = 0.0\n",
      "    tolerance = 1e-7\n",
      "    max_iterations = 1000\n",
      "    iteration = 0\n",
      "    \n",
      "    while iteration < max_iterations:\n",
      "        # Evaluate the polynomial and its derivative at x\n",
      "        f_x = poly(xs, x)\n",
      "        f_prime_x = sum([coeff * i * math.pow(x, i - 1) for i, coeff in enumerate(xs) if i > 0])\n",
      "        \n",
      "        # Calculate the next approximation using Newton-Raphson formula\n",
      "        x_new = x - f_x / f_prime_x\n",
      "        \n",
      "        # Check for convergence\n",
      "        if abs(x_new - x) < tolerance:\n",
      "            return x_new\n",
      "        \n",
      "        x = x_new\n",
      "        iteration += 1\n",
      "    \n",
      "    raise ValueError(\"Failed to converge after maximum iterations\")\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "from typing import List\n",
      "def remove_duplicates(numbers: List[int]) -> List[int]:\n",
      "    \"\"\" From a list of integers, remove all elements that occur more than once.\n",
      "    Keep order of elements left the same as in the input.\n",
      "    >>> remove_duplicates([1, 2, 3, 2, 4])\n",
      "    [1, 3, 4]\n",
      "    \"\"\"\n",
      "    seen = set()\n",
      "    result = []\n",
      "    for number in numbers:\n",
      "        if number not in seen:\n",
      "            seen.add(number)\n",
      "            result.append(number)\n",
      "    return result\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "from typing import List\n",
      "def sort_numbers(numbers: str) -> str:\n",
      "    \"\"\" Input is a space-delimited string of numberals from 'zero' to 'nine'.\n",
      "    Valid choices are 'zero', 'one', 'two', 'three', 'four', 'five', 'six', 'seven', 'eight' and 'nine'.\n",
      "    Return the string with numbers sorted from smallest to largest\n",
      "    >>> sort_numbers('three one five')\n",
      "    'one three five'\n",
      "    \"\"\"\n",
      "    # Define a mapping from numberals to their corresponding integer values\n",
      "    numeral_to_int = {\n",
      "        'zero': 0,\n",
      "        'one': 1,\n",
      "        'two': 2,\n",
      "        'three': 3,\n",
      "        'four': 4,\n",
      "        'five': 5,\n",
      "        'six': 6,\n",
      "        'seven': 7,\n",
      "        'eight': 8,\n",
      "        'nine': 9\n",
      "    }\n",
      "    \n",
      "    # Split the input string into a list of numberals\n",
      "    numeral_list = numbers.split()\n",
      "    \n",
      "    # Convert each numeral to its integer value\n",
      "    integer_list = [numeral_to_int[numeral] for numeral in numeral_list]\n",
      "    \n",
      "    # Sort the list of integers\n",
      "    integer_list.sort()\n",
      "    \n",
      "    # Convert the sorted integers back to numberals\n",
      "    sorted_numeral_list = [numeral_to_int.keys()[i] for i in integer_list]\n",
      "    \n",
      "    # Join the sorted numberals back into a string\n",
      "    return ' '.join(sorted_numeral_list)\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def sort_third(l: list):\n",
      "    \"\"\"This function takes a list l and returns a list l' such that\n",
      "    l' is identical to l in the indices that are not divisible by three, while its values at the indices that are divisible by three are equal\n",
      "    to the values of the corresponding indices of l, but sorted.\n",
      "    >>> sort_third([1, 2, 3])\n",
      "    [1, 2, 3]\n",
      "    >>> sort_third([5, 6, 3, 4, 8, 9, 2])\n",
      "    [2, 6, 3, 4, 8, 9, 5]\n",
      "    \"\"\"\n",
      "    # Create a copy of the list to avoid modifying the original list\n",
      "    l_prime = l[:]\n",
      "    \n",
      "    # Iterate over the list and sort elements at indices divisible by three\n",
      "    for i in range(0, len(l), 3):\n",
      "        # Extract the sublist of elements at indices divisible by three\n",
      "        sublist = [l_prime[j] for j in range(i, len(l_prime), 3)]\n",
      "        # Sort the sublist\n",
      "        sublist.sort()\n",
      "        # Place the sorted sublist back into the list\n",
      "        for j, value in enumerate(sublist):\n",
      "            l_prime[i + j] = value\n",
      "    \n",
      "    return l_prime\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def circular_shift(x, shift):\n",
      "    \"\"\"Circular shift the digits of the integer x, shift the digits right by shift\n",
      "    and return the result as a string.\n",
      "    If shift > number of digits, return digits reversed.\n",
      "    >>> circular_shift(12, 1)\n",
      "    \"21\"\n",
      "    >>> circular_shift(12, 2)\n",
      "    \"12\"\n",
      "    \"\"\"\n",
      "    # Convert the integer to a string to manipulate its digits\n",
      "    x_str = str(x)\n",
      "    n = len(x_str)\n",
      "    \n",
      "    # If shift is greater than the number of digits, reverse the digits\n",
      "    if shift >= n:\n",
      "        return x_str[::-1]\n",
      "    \n",
      "    # Perform the circular shift\n",
      "    shifted_str = x_str[-shift:] + x_str[:-shift]\n",
      "    \n",
      "    return shifted_str\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def is_simple_power(x, n):\n",
      "    \"\"\"Your task is to write a function that returns true if a number x is a simple\n",
      "    power of n and false in other cases.\n",
      "    x is a simple power of n if n**int=x\n",
      "    For example:\n",
      "    is_simple_power(1, 4) => true\n",
      "    is_simple_power(2, 2) => true\n",
      "    is_simple_power(8, 2) => true\n",
      "    is_simple_power(3, 2) => false\n",
      "    is_simple_power(3, 1) => false\n",
      "    is_simple_power(5, 3) => false\n",
      "    \"\"\"\n",
      "    if n == 1:\n",
      "        return False  # Any number is a power of 1, but we consider x == 1 as a valid power of 1.\n",
      "    \n",
      "    if x == 1:\n",
      "        return True  # 1 is a power of any number n > 1.\n",
      "    \n",
      "    if x < n:\n",
      "        return False  # x cannot be a power of n if x < n.\n",
      "    \n",
      "    power = 1\n",
      "    while power < x:\n",
      "        power *= n\n",
      "    \n",
      "    return power == x\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def fruit_distribution(s, n):\n",
      "    \"\"\"\n",
      "    In this task, you will be given a string that represents a number of apples and oranges \n",
      "    that are distributed in a basket of fruit this basket contains \n",
      "    apples, oranges, and mango fruits. Given the string that represents the total number of \n",
      "    the oranges and apples and an integer that represent the total number of the fruits \n",
      "    in the basket return the number of the mango fruits in the basket.\n",
      "    for examble:\n",
      "    fruit_distribution(\"5 apples and 6 oranges\", 19) ->19 - 5 - 6 = 8\n",
      "    fruit_distribution(\"0 apples and 1 oranges\",3) -> 3 - 0 - 1 = 2\n",
      "    fruit_distribution(\"2 apples and 3 oranges\", 100) -> 100 - 2 - 3 = 95\n",
      "    fruit_distribution(\"100 apples and 1 oranges\",120) -> 120 - 100 - 1 = 19\n",
      "    \"\"\"\n",
      "    # Extract the number of apples and oranges from the string\n",
      "    apples = int(s.split()[0])\n",
      "    oranges = int(s.split()[2])\n",
      "    \n",
      "    # Calculate the number of mango fruits\n",
      "    mangoes = n - apples - oranges\n",
      "    \n",
      "    return mangoes\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def check_dict_case(dict):\n",
      "    \"\"\"\n",
      "    Given a dictionary, return True if all keys are strings in lower \n",
      "    case or all keys are strings in upper case, else return False.\n",
      "    The function should return False is the given dictionary is empty.\n",
      "    Examples:\n",
      "    check_dict_case({\"a\":\"apple\", \"b\":\"banana\"}) should return True.\n",
      "    check_dict_case({\"a\":\"apple\", \"A\":\"banana\", \"B\":\"banana\"}) should return False.\n",
      "    check_dict_case({\"a\":\"apple\", 8:\"banana\", \"a\":\"apple\"}) should return False.\n",
      "    check_dict_case({\"Name\":\"John\", \"Age\":\"36\", \"City\":\"Houston\"}) should return False.\n",
      "    check_dict_case({\"STATE\":\"NC\", \"ZIP\":\"12345\" }) should return True.\n",
      "    \"\"\"\n",
      "    if not dict:\n",
      "        return False\n",
      "    \n",
      "    first_key = next(iter(dict))\n",
      "    is_lower = first_key.islower()\n",
      "    is_upper = first_key.isupper()\n",
      "    \n",
      "    for key in dict:\n",
      "        if not isinstance(key, str):\n",
      "            return False\n",
      "        if key.islower() != is_lower and key.isupper() != is_upper:\n",
      "            return False\n",
      "    \n",
      "    return True\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def starts_one_ends(n):\n",
      "    \"\"\"\n",
      "    Given a positive integer n, return the count of the numbers of n-digit\n",
      "    positive integers that start or end with 1.\n",
      "    \"\"\"\n",
      "    # Calculate the number of n-digit numbers that start with 1\n",
      "    # For n-digit numbers, the first digit is 1, and the rest can be any digit from 0 to 9\n",
      "    # So, there are 10^(n-1) such numbers\n",
      "    count_start_with_one = 10 ** (n - 1)\n",
      "    \n",
      "    # Calculate the number of n-digit numbers that end with 1\n",
      "    # For n-digit numbers, the last digit is 1, and the rest can be any digit from 0 to 9\n",
      "    # So, there are 10^(n-1) such numbers\n",
      "    count_end_with_one = 10 ** (n - 1)\n",
      "    \n",
      "    # Calculate the number of n-digit numbers that both start and end with 1\n",
      "    # For n-digit numbers, the first and last digits are 1, and the rest can be any digit from 0 to 9\n",
      "    # So, there are 10^(n-2) such numbers\n",
      "    count_both = 10 ** (n - 2)\n",
      "    \n",
      "    # The total count is the sum of numbers that start with 1, end with 1, minus those that do both\n",
      "    total_count = count_start_with_one + count_end_with_one - count_both\n",
      "    \n",
      "    return total_count\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def is_bored(S):\n",
      "    \"\"\"\n",
      "    You'll be given a string of words, and your task is to count the number\n",
      "    of boredoms. A boredom is a sentence that starts with the word \"I\".\n",
      "    Sentences are delimited by '.', '?' or '!'.\n",
      "   \n",
      "    For example:\n",
      "    >>> is_bored(\"Hello world\")\n",
      "    0\n",
      "    >>> is_bored(\"The sky is blue. The sun is shining. I love this weather\")\n",
      "    1\n",
      "    \"\"\"\n",
      "    import re\n",
      "    \n",
      "    # Split the string into sentences using '.', '?' or '!' as delimiters\n",
      "    sentences = re.split(r'[.!?]', S)\n",
      "    \n",
      "    # Initialize a counter for boredoms\n",
      "    boredom_count = 0\n",
      "    \n",
      "    # Iterate over each sentence\n",
      "    for sentence in sentences:\n",
      "        # Strip whitespace and check if the sentence starts with \"I\"\n",
      "        if sentence.strip().startswith('I'):\n",
      "            boredom_count += 1\n",
      "    \n",
      "    return boredom_count\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def next_smallest(lst):\n",
      "    \"\"\"\n",
      "    You are given a list of integers.\n",
      "    Write a function next_smallest() that returns the 2nd smallest element of the list.\n",
      "    Return None if there is no such element.\n",
      "    \n",
      "    next_smallest([1, 2, 3, 4, 5]) == 2\n",
      "    next_smallest([5, 1, 4, 3, 2]) == 2\n",
      "    next_smallest([]) == None\n",
      "    next_smallest([1, 1]) == None\n",
      "    \"\"\"\n",
      "    if len(lst) < 2:\n",
      "        return None\n",
      "    \n",
      "    # Sort the list to find the second smallest element\n",
      "    sorted_lst = sorted(lst)\n",
      "    \n",
      "    # Return the second smallest element\n",
      "    return sorted_lst[1]\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def encode(message):\n",
      "    \"\"\"\n",
      "    Write a function that takes a message, and encodes in such a \n",
      "    way that it swaps case of all letters, replaces all vowels in \n",
      "    the message with the letter that appears 2 places ahead of that \n",
      "    vowel in the english alphabet. \n",
      "    Assume only letters. \n",
      "    \n",
      "    Examples:\n",
      "    >>> encode('test')\n",
      "    'TGST'\n",
      "    >>> encode('This is a message')\n",
      "    'tHKS KS C MGSSCGG'\n",
      "    \"\"\"\n",
      "    # Swap the case\n",
      "    swapped_message = ''.join(\n",
      "        char.upper() if char.islower() else char.lower() for char in message\n",
      "    )\n",
      "    \n",
      "    # Replace vowels with the letter 2 places ahead\n",
      "    vowels = 'aeiouAEIOU'\n",
      "    shifted_vowels = 'gIOUaeiou'\n",
      "    encoded_message = ''.join(\n",
      "        shifted_vowels[vowels.index(char)] if char in vowels else char\n",
      "        for char in swapped_message\n",
      "    )\n",
      "    \n",
      "    return encoded_message\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def choose_num(x, y):\n",
      "    \"\"\"This function takes two positive numbers x and y and returns the\n",
      "    biggest even integer number that is in the range [x, y] inclusive. If \n",
      "    there's no such number, then the function should return -1.\n",
      "\n",
      "    For example:\n",
      "    choose_num(12, 15) = 14\n",
      "    choose_num(13, 12) = -1\n",
      "    \"\"\"\n",
      "    # Ensure x is less than or equal to y\n",
      "    if x > y:\n",
      "        x, y = y, x\n",
      "    \n",
      "    # Start from y and go downwards to find the largest even number\n",
      "    for num in range(y, x - 1, -1):\n",
      "        if num % 2 == 0:\n",
      "            return num\n",
      "    \n",
      "    # If no even number is found, return -1\n",
      "    return -1\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def anti_shuffle(s):\n",
      "    \"\"\"\n",
      "    Write a function that takes a string and returns an ordered version of it.\n",
      "    Ordered version of string, is a string where all words (separated by space)\n",
      "    are replaced by a new word where all the characters arranged in\n",
      "    ascending order based on ascii value.\n",
      "    Note: You should keep the order of words and blank spaces in the sentence.\n",
      "\n",
      "    For example:\n",
      "    anti_shuffle('Hi') returns 'Hi'\n",
      "    anti_shuffle('hello') returns 'ehllo'\n",
      "    anti_shuffle('Hello World!!!') returns 'Hello !!!Wdlor'\n",
      "    \"\"\"\n",
      "    # Split the input string into words and spaces\n",
      "    words = s.split(' ')\n",
      "    result = []\n",
      "    \n",
      "    for word in words:\n",
      "        # If the word is not empty, sort its characters\n",
      "        if word:\n",
      "            sorted_word = ''.join(sorted(word))\n",
      "            result.append(sorted_word)\n",
      "        else:\n",
      "            # If the word is empty, it's a space, so just append it\n",
      "            result.append(' ')\n",
      "    \n",
      "    # Join the sorted words and spaces back into a single string\n",
      "    return ' '.join(result)\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def count_nums(arr):\n",
      "    \"\"\"\n",
      "    Write a function count_nums which takes an array of integers and returns\n",
      "    the number of elements which has a sum of digits > 0.\n",
      "    If a number is negative, then its first signed digit will be negative:\n",
      "    e.g. -123 has signed digits -1, 2, and 3.\n",
      "    >>> count_nums([]) == 0\n",
      "    >>> count_nums([-1, 11, -11]) == 1\n",
      "    >>> count_nums([1, 1, 2]) == 3\n",
      "    \"\"\"\n",
      "    def sum_of_signed_digits(num):\n",
      "        # Convert the number to a string to iterate over each digit\n",
      "        num_str = str(abs(num))\n",
      "        # Determine the sign of the number\n",
      "        sign = -1 if num < 0 else 1\n",
      "        # Calculate the sum of signed digits\n",
      "        total_sum = sum(sign * int(digit) for digit in num_str)\n",
      "        return total_sum\n",
      "\n",
      "    count = 0\n",
      "    for num in arr:\n",
      "        if sum_of_signed_digits(num) > 0:\n",
      "            count += 1\n",
      "\n",
      "    return count\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def sort_array(arr):\n",
      "    \"\"\"\n",
      "    In this Kata, you have to sort an array of non-negative integers according to\n",
      "    number of ones in their binary representation in ascending order.\n",
      "    For similar number of ones, sort based on decimal value.\n",
      "\n",
      "    It must be implemented like this:\n",
      "    >>> sort_array([1, 5, 2, 3, 4]) == [1, 2, 3, 4, 5]\n",
      "    >>> sort_array([-2, -3, -4, -5, -6]) == [-6, -5, -4, -3, -2]\n",
      "    >>> sort_array([1, 0, 2, 3, 4]) == [0, 1, 2, 3, 4]\n",
      "    \"\"\"\n",
      "    # Filter out negative numbers since they are not non-negative\n",
      "    non_negatives = [x for x in arr if x >= 0]\n",
      "    \n",
      "    # Sort numbers based on the number of ones in their binary representation\n",
      "    # and by their decimal value as a tiebreaker\n",
      "    sorted_non_negatives = sorted(non_negatives, key=lambda x: (bin(x).count('1'), x))\n",
      "    \n",
      "    # Combine sorted non-negative numbers with negative numbers\n",
      "    sorted_negatives = [x for x in arr if x < 0]\n",
      "    sorted_negatives.sort()  # Sort negative numbers in ascending order\n",
      "    \n",
      "    return sorted_negatives + sorted_non_negatives\n",
      "pass\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def add_elements(arr, k):\n",
      "    \"\"\"\n",
      "    Given a non-empty array of integers arr and an integer k, return\n",
      "    the sum of the elements with at most two digits from the first k elements of arr.\n",
      "\n",
      "    Example:\n",
      "\n",
      "        Input: arr = [111,21,3,4000,5,6,7,8,9], k = 4\n",
      "        Output: 24 # sum of 21 + 3\n",
      "\n",
      "    Constraints:\n",
      "        1. 1 <= len(arr) <= 100\n",
      "        2. 1 <= k <= len(arr)\n",
      "    \"\"\"\n",
      "    # Initialize the sum\n",
      "    total_sum = 0\n",
      "    \n",
      "    # Iterate over the first k elements of the array\n",
      "    for num in arr[:k]:\n",
      "        # Check if the number has at most two digits\n",
      "        if -100 <= num <= 99 or 0 <= num <= 999:\n",
      "            total_sum += num\n",
      "    \n",
      "    return total_sum\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "import math\n",
      "def max_fill(grid, capacity):\n",
      "    \"\"\"\n",
      "    You are given a rectangular grid of wells. Each row represents a single well,\n",
      "    and each 1 in a row represents a single unit of water.\n",
      "    Each well has a corresponding bucket that can be used to extract water from it, \n",
      "    and all buckets have the same capacity.\n",
      "    Your task is to use the buckets to empty the wells.\n",
      "    Output the number of times you need to lower the buckets.\n",
      "\n",
      "    Example 1:\n",
      "        Input: \n",
      "            grid : [[0,0,1,0], [0,1,0,0], [1,1,1,1]]\n",
      "            bucket_capacity : 1\n",
      "        Output: 6\n",
      "\n",
      "    Example 2:\n",
      "        Input: \n",
      "            grid : [[0,0,1,1], [0,0,0,0], [1,1,1,1], [0,1,1,1]]\n",
      "            bucket_capacity : 2\n",
      "        Output: 5\n",
      "    \n",
      "    Example 3:\n",
      "        Input: \n",
      "            grid : [[0,0,0], [0,0,0]]\n",
      "            bucket_capacity : 5\n",
      "        Output: 0\n",
      "\n",
      "    Constraints:\n",
      "        * all wells have the same length\n",
      "        * 1 <= grid.length <= 10^2\n",
      "        * 1 <= grid[:,1].length <= 10^2\n",
      "        * grid[i][j] -> 0 | 1\n",
      "        * 1 <= capacity <= 10\n",
      "    \"\"\"\n",
      "    total_water = sum(sum(row) for row in grid)\n",
      "    return math.ceil(total_water / capacity)\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "import re\n",
      "from datetime import datetime\n",
      "def valid_date(date):\n",
      "    \"\"\"Validates a given date string and returns True if the date is valid otherwise False.\"\"\"\n",
      "    \n",
      "    # Check if the date string is empty\n",
      "    if not date:\n",
      "        return False\n",
      "    \n",
      "    # Regular expression to match the mm-dd-yyyy format\n",
      "    pattern = re.compile(r'^\\d{2}-\\d{2}-\\d{4}$')\n",
      "    \n",
      "    # Check if the date string matches the pattern\n",
      "    if not pattern.match(date):\n",
      "        return False\n",
      "    \n",
      "    # Extract month, day, and year from the date string\n",
      "    month, day, year = date.split('-')\n",
      "    \n",
      "    # Convert month and day to integers\n",
      "    month = int(month)\n",
      "    day = int(day)\n",
      "    \n",
      "    # Check if the month is between 1 and 12\n",
      "    if month < 1 or month > 12:\n",
      "        return False\n",
      "    \n",
      "    # Check if the day is valid for the given month\n",
      "    if month in {1, 3, 5, 7, 8, 10, 12} and day < 1 or day > 31:\n",
      "        return False\n",
      "    elif month in {4, 6, 9, 11} and day < 1 or day > 30:\n",
      "        return False\n",
      "    elif month == 2:\n",
      "        # Check if the year is a leap year\n",
      "        if year % 4 == 0 and (year % 100 != 0 or year % 400 == 0):\n",
      "            if day < 1 or day > 29:\n",
      "                return False\n",
      "        else:\n",
      "            if day < 1 or day > 28:\n",
      "                return False\n",
      "    \n",
      "    # Check if the date is actually valid\n",
      "    try:\n",
      "        datetime(year, month, day)\n",
      "        return True\n",
      "    except ValueError:\n",
      "        return False\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def split_words(txt):\n",
      "    # Check if the text contains whitespace\n",
      "    if ' ' in txt:\n",
      "        # Split by whitespace\n",
      "        return txt.split()\n",
      "    # Check if the text contains commas\n",
      "    elif ',' in txt:\n",
      "        # Split by commas\n",
      "        return txt.split(',')\n",
      "    # If neither whitespace nor commas are present, count the lowercase letters with odd order\n",
      "    else:\n",
      "        count = 0\n",
      "        for char in txt:\n",
      "            if 'a' <= char <= 'z' and ord(char) - ord('a') % 2 == 1:\n",
      "                count += 1\n",
      "        return count\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def is_sorted(lst):\n",
      "    # Check if the list is sorted in ascending order\n",
      "    is_sorted = all(lst[i] <= lst[i + 1] for i in range(len(lst) - 1))\n",
      "    \n",
      "    # Check if there are more than one duplicate of the same number\n",
      "    has_no_duplicates = all(lst.count(x) <= 1 for x in set(lst))\n",
      "    \n",
      "    return is_sorted and has_no_duplicates\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def maximum(arr, k):\n",
      "    \"\"\"\n",
      "    Given an array arr of integers and a positive integer k, return a sorted list \n",
      "    of length k with the maximum k numbers in arr.\n",
      "\n",
      "    Example 1:\n",
      "\n",
      "        Input: arr = [-3, -4, 5], k = 3\n",
      "        Output: [-4, -3, 5]\n",
      "\n",
      "    Example 2:\n",
      "\n",
      "        Input: arr = [4, -4, 4], k = 2\n",
      "        Output: [4, 4]\n",
      "\n",
      "    Example 3:\n",
      "\n",
      "        Input: arr = [-3, 2, 1, 2, -1, -2, 1], k = 1\n",
      "        Output: [2]\n",
      "\n",
      "    Note:\n",
      "        1. The length of the array will be in the range of [1, 1000].\n",
      "        2. The elements in the array will be in the range of [-1000, 1000].\n",
      "        3. 0 <= k <= len(arr)\n",
      "    \"\"\"\n",
      "    # Sort the array in descending order\n",
      "    sorted_arr = sorted(arr, reverse=True)\n",
      "    \n",
      "    # Return the first k elements from the sorted array\n",
      "    return sorted_arr[:k]\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def exchange(lst1, lst2):\n",
      "    \"\"\"In this problem, you will implement a function that takes two lists of numbers,\n",
      "    and determines whether it is possible to perform an exchange of elements\n",
      "    between them to make lst1 a list of only even numbers.\n",
      "    There is no limit on the number of exchanged elements between lst1 and lst2.\n",
      "    If it is possible to exchange elements between the lst1 and lst2 to make\n",
      "    all the elements of lst1 to be even, return \"YES\".\n",
      "    Otherwise, return \"NO\".\n",
      "    For example:\n",
      "    exchange([1, 2, 3, 4], [1, 2, 3, 4]) => \"YES\"\n",
      "    exchange([1, 2, 3, 4], [1, 5, 3, 4]) => \"NO\"\n",
      "    It is assumed that the input lists will be non-empty.\n",
      "    \"\"\"\n",
      "    # Count the number of odd numbers in lst1\n",
      "    odd_count_lst1 = sum(1 for x in lst1 if x % 2 != 0)\n",
      "    \n",
      "    # Count the number of even numbers in lst2\n",
      "    even_count_lst2 = sum(1 for x in lst2 if x % 2 == 0)\n",
      "    \n",
      "    # If there are no odd numbers in lst1, it's already even\n",
      "    if odd_count_lst1 == 0:\n",
      "        return \"YES\"\n",
      "    \n",
      "    # If there are no even numbers in lst2, it's impossible to make lst1 even\n",
      "    if even_count_lst2 == 0:\n",
      "        return \"NO\"\n",
      "    \n",
      "    # If there are odd numbers in lst1 and even numbers in lst2, it's possible to exchange\n",
      "    return \"YES\"\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def is_prime(n):\n",
      "    \"\"\"Helper function to determine if a number is prime.\"\"\"\n",
      "    if n <= 1:\n",
      "        return False\n",
      "    if n <= 3:\n",
      "        return True\n",
      "    if n % 2 == 0 or n % 3 == 0:\n",
      "        return False\n",
      "    i = 5\n",
      "    while i * i <= n:\n",
      "        if n % i == 0 or n % (i + 2) == 0:\n",
      "            return False\n",
      "        i += 6\n",
      "    return True\n",
      "def intersection(interval1, interval2):\n",
      "    \"\"\"Determine if the length of the intersection of two intervals is a prime number.\"\"\"\n",
      "    start1, end1 = interval1\n",
      "    start2, end2 = interval2\n",
      "    \n",
      "    # Calculate the intersection of the two intervals\n",
      "    intersection_start = max(start1, start2)\n",
      "    intersection_end = min(end1, end2)\n",
      "    \n",
      "    # Check if the intervals intersect\n",
      "    if intersection_start > intersection_end:\n",
      "        return \"NO\"\n",
      "    \n",
      "    # Calculate the length of the intersection\n",
      "    intersection_length = intersection_end - intersection_start + 1\n",
      "    \n",
      "    # Check if the length is a prime number\n",
      "    if is_prime(intersection_length):\n",
      "        return \"YES\"\n",
      "    else:\n",
      "        return \"NO\"\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def minPath(grid, k):\n",
      "    \"\"\"\n",
      "    Given a grid with N rows and N columns (N >= 2) and a positive integer k, \n",
      "    each cell of the grid contains a value. Every integer in the range [1, N * N]\n",
      "    inclusive appears exactly once on the cells of the grid.\n",
      "\n",
      "    You have to find the minimum path of length k in the grid. You can start\n",
      "    from any cell, and in each step you can move to any of the neighbor cells,\n",
      "    in other words, you can go to cells which share an edge with you current\n",
      "    cell.\n",
      "    Please note that a path of length k means visiting exactly k cells (not\n",
      "    necessarily distinct).\n",
      "    You CANNOT go off the grid.\n",
      "    A path A (of length k) is considered less than a path B (of length k) if\n",
      "    after making the ordered lists of the values on the cells that A and B go\n",
      "    through (let's call them lst_A and lst_B), lst_A is lexicographically less\n",
      "    than lst_B, in other words, there exist an integer index i (1 <= i <= k)\n",
      "    such that lst_A[i] < lst_B[i] and for any j (1 <= j < i) we have\n",
      "    lst_A[j] = lst_B[j].\n",
      "    It is guaranteed that the answer is unique.\n",
      "    Return an ordered list of the values on the cells that the minimum path go through.\n",
      "\n",
      "    Examples:\n",
      "\n",
      "        Input: grid = [ [1,2,3], [4,5,6], [7,8,9]], k = 3\n",
      "        Output: [1, 2, 1]\n",
      "\n",
      "        Input: grid = [ [5,9,3], [4,1,6], [7,8,2]], k = 1\n",
      "        Output: [1]\n",
      "    \"\"\"\n",
      "    from collections import deque\n",
      "\n",
      "    N = len(grid)\n",
      "    directions = [(0, 1), (1, 0), (0, -1), (-1, 0)]  # Right, Down, Left, Up\n",
      "\n",
      "    def bfs(start):\n",
      "        queue = deque([(start, [grid[start[0]][start[1]]])])  # (current_position, path)\n",
      "        visited = set()\n",
      "        visited.add(start)\n",
      "\n",
      "        while queue:\n",
      "            (x, y), path = queue.popleft()\n",
      "            if len(path) == k:\n",
      "                return path\n",
      "\n",
      "            for dx, dy in directions:\n",
      "                nx, ny = x + dx, y + dy\n",
      "                if 0 <= nx < N and 0 <= ny < N and (nx, ny) not in visited:\n",
      "                    visited.add((nx, ny))\n",
      "                    queue.append(((nx, ny), path + [grid[nx][ny]]))\n",
      "\n",
      "    min_path = None\n",
      "    for i in range(N):\n",
      "        for j in range(N):\n",
      "            path = bfs((i, j))\n",
      "            if path:\n",
      "                if min_path is None or path < min_path:\n",
      "                    min_path = path\n",
      "\n",
      "    return min_path\n",
      "grid = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]\n",
      "k = 3\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def generate_integers(a, b):\n",
      "    \"\"\"\n",
      "    Given two positive integers a and b, return the even digits between a\n",
      "    and b, in ascending order.\n",
      "\n",
      "    For example:\n",
      "    generate_integers(2, 8) => [2, 4, 6, 8]\n",
      "    generate_integers(8, 2) => [2, 4, 6, 8]\n",
      "    generate_integers(10, 14) => []\n",
      "    \"\"\"\n",
      "    # Ensure a is less than or equal to b\n",
      "    if a > b:\n",
      "        a, b = b, a\n",
      "\n",
      "    # Generate the list of even numbers between a and b\n",
      "    even_numbers = [i for i in range(a, b + 1) if i % 2 == 0]\n",
      "\n",
      "    return even_numbers\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def cycpattern_check(a, b):\n",
      "    \"\"\"\n",
      "    You are given 2 words. You need to return True if the second word or any of its rotations is a substring in the first word\n",
      "    cycpattern_check(\"abcd\",\"abd\") => False\n",
      "    cycpattern_check(\"hello\",\"ell\") => True\n",
      "    cycpattern_check(\"whassup\",\"psus\") => False\n",
      "    cycpattern_check(\"abab\",\"baa\") => True\n",
      "    cycpattern_check(\"efef\",\"eeff\") => False\n",
      "    cycpattern_check(\"himenss\",\"simen\") => True\n",
      "    \"\"\"\n",
      "    # Create a doubled version of the first word to handle rotations\n",
      "    doubled_a = a + a\n",
      "    \n",
      "    # Check if the second word is a substring of the doubled version of the first word\n",
      "    return b in doubled_a\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def fix_spaces(text):\n",
      "    \"\"\"\n",
      "    Given a string text, replace all spaces in it with underscores, \n",
      "    and if a string has more than 2 consecutive spaces, \n",
      "    then replace all consecutive spaces with - \n",
      "    \n",
      "    fix_spaces(\"Example\") == \"Example\"\n",
      "    fix_spaces(\"Example 1\") == \"Example_1\"\n",
      "    fix_spaces(\" Example 2\") == \"_Example_2\"\n",
      "    fix_spaces(\" Example   3\") == \"_Example-3\"\n",
      "    \"\"\"\n",
      "    # Replace all spaces with underscores\n",
      "    text = text.replace(' ', '_')\n",
      "    \n",
      "    # Replace more than 2 consecutive underscores with a single dash\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def order_by_points(nums):\n",
      "    \"\"\"\n",
      "    Write a function which sorts the given list of integers\n",
      "    in ascending order according to the sum of their digits.\n",
      "    Note: if there are several items with similar sum of their digits,\n",
      "    order them based on their index in original list.\n",
      "\n",
      "    For example:\n",
      "    >>> order_by_points([1, 11, -1, -11, -12]) == [-1, -11, 1, -12, 11]\n",
      "    >>> order_by_points([]) == []\n",
      "    \"\"\"\n",
      "    def sum_of_digits(n):\n",
      "        # Calculate the sum of digits of a number\n",
      "        n = abs(n)\n",
      "        return sum(int(digit) for digit in str(n))\n",
      "    \n",
      "    # Create a list of tuples (number, sum_of_digits, original_index)\n",
      "    indexed_nums = [(num, sum_of_digits(num), index) for index, num in enumerate(nums)]\n",
      "    \n",
      "    # Sort the list based on the sum of digits, and by original index if sums are equal\n",
      "    indexed_nums.sort(key=lambda x: (x[1], x[2]))\n",
      "    \n",
      "    # Extract the sorted numbers\n",
      "    sorted_nums = [num for num, _, _ in indexed_nums]\n",
      "    \n",
      "    return sorted_nums\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def is_nested(string):\n",
      "    '''\n",
      "    Create a function that takes a string as input which contains only square brackets.\n",
      "    The function should return True if and only if there is a valid subsequence of brackets \n",
      "    where at least one bracket in the subsequence is nested.\n",
      "\n",
      "    is_nested('[[]]') ➞ True\n",
      "    is_nested('[]]]]]]][[[[[]') ➞ False\n",
      "    is_nested('[][]') ➞ False\n",
      "    is_nested('[]') ➞ False\n",
      "    is_nested('[[][]]') ➞ True\n",
      "    is_nested('[[]][[') ➞ True\n",
      "    '''\n",
      "    stack = []\n",
      "    nested = False\n",
      "\n",
      "    for char in string:\n",
      "        if char == '[':\n",
      "            stack.append(char)\n",
      "        elif char == ']':\n",
      "            if stack and stack[-1] == '[':\n",
      "                stack.pop()\n",
      "                if stack:\n",
      "                    nested = True  # Found a nested bracket\n",
      "    return nested\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def check_if_last_char_is_a_letter(txt):\n",
      "    '''\n",
      "    Create a function that returns True if the last character\n",
      "    of a given string is an alphabetical character and is not\n",
      "    a part of a word, and False otherwise.\n",
      "    Note: \"word\" is a group of characters separated by space.\n",
      "\n",
      "    Examples:\n",
      "    check_if_last_char_is_a_letter(\"apple pie\") ➞ False\n",
      "    check_if_last_char_is_a_letter(\"apple pi e\") ➞ True\n",
      "    check_if_last_char_is_a_letter(\"apple pi e \") ➞ False\n",
      "    check_if_last_char_is_a_letter(\"\") ➞ False \n",
      "    '''\n",
      "    # Check if the string is empty\n",
      "    if not txt:\n",
      "        return False\n",
      "    \n",
      "    # Get the last character of the string\n",
      "    last_char = txt[-1]\n",
      "    \n",
      "    # Check if the last character is an alphabetical character\n",
      "    if not last_char.isalpha():\n",
      "        return False\n",
      "    \n",
      "    # Check if the last character is not part of a word\n",
      "    # A word is a sequence of characters separated by spaces\n",
      "    words = txt.split()\n",
      "    if not words:\n",
      "        return False\n",
      "    \n",
      "    # Check if the last character is the last character of the last word\n",
      "    last_word = words[-1]\n",
      "    if last_char == last_word[-1]:\n",
      "        return False\n",
      "    \n",
      "    return True\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def eat(number, need, remaining):\n",
      "    \"\"\"\n",
      "    You're a hungry rabbit, and you already have eaten a certain number of carrots,\n",
      "    but now you need to eat more carrots to complete the day's meals.\n",
      "    you should return an array of [ total number of eaten carrots after your meals,\n",
      "                                    the number of carrots left after your meals ]\n",
      "    if there are not enough remaining carrots, you will eat all remaining carrots, but will still be hungry.\n",
      "    \n",
      "    Example:\n",
      "    * eat(5, 6, 10) -> [11, 4]\n",
      "    * eat(4, 8, 9) -> [12, 1]\n",
      "    * eat(1, 10, 10) -> [11, 0]\n",
      "    * eat(2, 11, 5) -> [7, 0]\n",
      "    \n",
      "    Variables:\n",
      "    @number : integer\n",
      "        the number of carrots that you have eaten.\n",
      "    @need : integer\n",
      "        the number of carrots that you need to eat.\n",
      "    @remaining : integer\n",
      "        the number of remaining carrots thet exist in stock\n",
      "    \n",
      "    Constrain:\n",
      "    * 0 <= number <= 1000\n",
      "    * 0 <= need <= 1000\n",
      "    * 0 <= remaining <= 1000\n",
      "\n",
      "    Have fun :)\n",
      "    \"\"\"\n",
      "    # Calculate the total number of carrots needed to eat\n",
      "    total_needed = number + need\n",
      "    \n",
      "    # If the remaining carrots are less than the total needed, eat all remaining carrots\n",
      "    if remaining < total_needed:\n",
      "        total_eaten = remaining\n",
      "        remaining_carrots = 0\n",
      "    else:\n",
      "        total_eaten = total_needed\n",
      "        remaining_carrots = remaining - total_needed\n",
      "    \n",
      "    return [total_eaten, remaining_carrots]\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def do_algebra(operator, operand):\n",
      "    \"\"\"\n",
      "    Given two lists operator, and operand. The first list has basic algebra operations, and \n",
      "    the second list is a list of integers. Use the two given lists to build the algebric \n",
      "    expression and return the evaluation of this expression.\n",
      "\n",
      "    The basic algebra operations:\n",
      "    Addition ( + ) \n",
      "    Subtraction ( - ) \n",
      "    Multiplication ( * ) \n",
      "    Floor division ( // ) \n",
      "    Exponentiation ( ** ) \n",
      "\n",
      "    Example:\n",
      "    operator['+', '*', '-']\n",
      "    array = [2, 3, 4, 5]\n",
      "    result = 2 + 3 * 4 - 5\n",
      "    => result = 9\n",
      "\n",
      "    Note:\n",
      "        The length of operator list is equal to the length of operand list minus one.\n",
      "        Operand is a list of of non-negative integers.\n",
      "        Operator list has at least one operator, and operand list has at least two operands.\n",
      "\n",
      "    \"\"\"\n",
      "    # Initialize the result with the first operand\n",
      "    result = operand[0]\n",
      "    \n",
      "    # Iterate over the operators and operands\n",
      "    for i, op in enumerate(operator):\n",
      "        # Apply the operator to the current result and the next operand\n",
      "        if op == '+':\n",
      "            result += operand[i + 1]\n",
      "        elif op == '-':\n",
      "            result -= operand[i + 1]\n",
      "        elif op == '*':\n",
      "            result *= operand[i + 1]\n",
      "        elif op == '//':\n",
      "            result //= operand[i + 1]\n",
      "        elif op == '**':\n",
      "            result **= operand[i + 1]\n",
      "        else:\n",
      "            raise ValueError(f\"Invalid operator: {op}\")\n",
      "    \n",
      "    return result\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n",
      "def tri(n):\n",
      "    \"\"\"Everyone knows Fibonacci sequence, it was studied deeply by mathematicians in \n",
      "    the last couple centuries. However, what people don't know is Tribonacci sequence.\n",
      "    Tribonacci sequence is defined by the recurrence:\n",
      "    tri(1) = 3\n",
      "    tri(n) = 1 + n / 2, if n is even.\n",
      "    tri(n) =  tri(n - 1) + tri(n - 2) + tri(n + 1), if n is odd.\n",
      "    For example:\n",
      "    tri(2) = 1 + (2 / 2) = 2\n",
      "    tri(4) = 3\n",
      "    tri(3) = tri(2) + tri(1) + tri(4)\n",
      "           = 2 + 3 + 3 = 8 \n",
      "    You are given a non-negative integer number n, you have to a return a list of the \n",
      "    first n + 1 numbers of the Tribonacci sequence.\n",
      "    Examples:\n",
      "    tri(3) = [1, 3, 2, 8]\n",
      "    \"\"\"\n",
      "    if n == 0:\n",
      "        return [1]\n",
      "    elif n == 1:\n",
      "        return [1, 3]\n",
      "    \n",
      "    # Initialize the first two numbers of the sequence\n",
      "    sequence = [1, 3]\n",
      "    \n",
      "    # Generate the sequence up to the nth number\n",
      "    for i in range(2, n + 1):\n",
      "        if i % 2 == 0:\n",
      "            # tri(n) = 1 + n / 2\n",
      "            sequence.append(1 + i / 2)\n",
      "        else:\n",
      "            # tri(n) = tri(n - 1) + tri(n - 2) + tri(n + 1)\n",
      "            sequence.append(sequence[i - 1] + sequence[i - 2] + sequence[i + 1])\n",
      "    \n",
      "    return sequence\n",
      "fail\n",
      "fail\n",
      "----------------------------------------------------------------------------------------------------\n"
     ]
    }
   ],
   "source": [
    "failed_df = df[df['base_status'] == 'fail']\n",
    "failed_df.solution\n",
    "\n",
    "for i in range(len(failed_df)):\n",
    "    print(failed_df.iloc[i].solution)\n",
    "    print(failed_df.iloc[i].plus_status)\n",
    "    print(failed_df.iloc[i].base_status)\n",
    "    print('-'*100)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "sandbox",
   "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.11.11"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
