{
  "statistics": {
    "total_samples": 250,
    "filtered_count": 216,
    "filtered_percentage": 86.4,
    "teacher_ppl_stats": {
      "infinite_count": 0,
      "min": 1.1980470483943544,
      "max": 3.654869545343165,
      "mean": 1.792967595901861,
      "median": 1.7092129851510847
    },
    "base_ppl_stats": {
      "infinite_count": 0,
      "min": 1.201367221295223,
      "max": 3.1186534458292066,
      "mean": 1.7230299730479075,
      "median": 1.6831363575462217
    },
    "ppl_diff_stats": {
      "infinite_count": 0,
      "min": -1.4756155803975761,
      "max": 1.967920234199121,
      "mean": 0.06993762285395336,
      "median": 0.02330858110249001
    }
  },
  "category_breakdown": {
    "Much Better (Teacher << Base)": [
      {
        "index": 194,
        "prompt": "Write a function to return a flattened version of a nested list (one level deep).",
        "teacher_output": "def flatten(nested_list):",
        "base_output": "def flatten_once(lst):\n    return [item for sub in lst for item in (sub if isinstance(sub, list) else [sub])]",
        "teacher_ppl": 1.3181690465280007,
        "base_ppl": 2.470273343932323,
        "ppl_diff": -1.152104297404322,
        "would_be_filtered": false
      },
      {
        "index": 234,
        "prompt": "Write a function to find the intersection of multiple sets.",
        "teacher_output": "def find_intersection(set1, set2, set3):",
        "base_output": "def set_intersection(*sets):\n    return set.intersection(*sets) if sets else set()",
        "teacher_ppl": 1.4022284598295331,
        "base_ppl": 2.5042882125366304,
        "ppl_diff": -1.1020597527070972,
        "would_be_filtered": false
      },
      {
        "index": 245,
        "prompt": "Write a function to get the largest key in a dictionary.",
        "teacher_output": "def get_max_key(d):\n    return max(d.keys())",
        "base_output": "def max_dict_key(d):\n    return max(d) if d else None",
        "teacher_ppl": 1.6430378654316304,
        "base_ppl": 3.1186534458292066,
        "ppl_diff": -1.4756155803975761,
        "would_be_filtered": true
      }
    ],
    "Better (Teacher < Base)": [
      {
        "index": 0,
        "prompt": "Write a function to check if a number is an Armstrong number.",
        "teacher_output": "def is_armstrong(num):\n    sum = 0\n    for i in str(num):\n        sum += int(i)**3\n    if sum == num:\n        return True\n    else:\n        return False",
        "base_output": "def is_armstrong(num):\n    order = len(str(num))\n    return num == sum(int(d)**order for d in str(num))",
        "teacher_ppl": 1.3308908576805352,
        "base_ppl": 1.8841447426746543,
        "ppl_diff": -0.5532538849941191,
        "would_be_filtered": false
      },
      {
        "index": 10,
        "prompt": "Write a function to interleave two lists of equal length.",
        "teacher_output": "def interleave(l1, l2):\n    return (l1 + l2)",
        "base_output": "def interleave_lists(a, b):\n    return [val for pair in zip(a, b) for val in pair]",
        "teacher_ppl": 1.598289512768291,
        "base_ppl": 2.11253047670369,
        "ppl_diff": -0.5142409639353989,
        "would_be_filtered": true
      },
      {
        "index": 18,
        "prompt": "Write a function to rotate a list to the left by one position.",
        "teacher_output": "def rotate_left(l):\n    return l[1:] + [l[0]]",
        "base_output": "def rotate_left(lst):\n    if not lst:\n        return lst\n    return lst[1:] + lst[:1]",
        "teacher_ppl": 1.6482730389463955,
        "base_ppl": 1.9921916055391353,
        "ppl_diff": -0.3439185665927398,
        "would_be_filtered": true
      },
      {
        "index": 22,
        "prompt": "Write a function to check if a list is sorted in ascending order.",
        "teacher_output": "def isSorted(myList):\n    return True if (myList[0] < myList[1]) and (myList[0] < myList[2]) and (myList[0] < myList[3]) and (myList[0] < myList[4]) and (myList[0] < myList[5]) and (myList[0] < myList[6]) and (myList[0] < myList[7]) and (myList[0] < myList[8]) and (myList[0] < myList[9]) and (myList[0] < myList[10]) and (myList[0] < myList[11]) and (myList[0]",
        "base_output": "def is_sorted(lst):\n    return lst == sorted(lst)",
        "teacher_ppl": 1.1980470483943544,
        "base_ppl": 1.7212616400967822,
        "ppl_diff": -0.5232145917024278,
        "would_be_filtered": false
      },
      {
        "index": 31,
        "prompt": "Write a function to compute the average of a list of numbers.",
        "teacher_output": "def average(numbers):\nreturn sum(numbers)/len(numbers)",
        "base_output": "def average(lst):\n    return sum(lst) / len(lst) if lst else 0",
        "teacher_ppl": 1.5816044869710257,
        "base_ppl": 2.0496580593694356,
        "ppl_diff": -0.46805357239840983,
        "would_be_filtered": true
      },
      {
        "index": 38,
        "prompt": "Write a function to count how many times each character appears in a string.",
        "teacher_output": "def count_char(string):\n    char_count = {}\n    for c in string:\n        if c not in char_count:\n            char_count[c] = 1\n        else:\n            char_count[c] += 1\n    return char_count",
        "base_output": "def char_frequency(s):\n    freq = {}\n    for char in s:\n        freq[char] = freq.get(char, 0) + 1\n    return freq",
        "teacher_ppl": 1.2456964007546978,
        "base_ppl": 1.5922774635312966,
        "ppl_diff": -0.34658106277659884,
        "would_be_filtered": false
      },
      {
        "index": 39,
        "prompt": "Write a function to rotate a square matrix 90 degrees clockwise.",
        "teacher_output": "def rotate(matrix):",
        "base_output": "def rotate_matrix(mat):\n    return [list(reversed(col)) for col in zip(*mat)]",
        "teacher_ppl": 1.6960368837744244,
        "base_ppl": 2.178074930827521,
        "ppl_diff": -0.4820380470530965,
        "would_be_filtered": true
      },
      {
        "index": 54,
        "prompt": "Write a function to return the transpose of a jagged (non-square) matrix.",
        "teacher_output": "def transpose(a):\nreturn([[a[i][j] for j in range(len(a))] for i in range(len(a[0]))])",
        "base_output": "def transpose_jagged(matrix):\n    return list(map(list, zip(*matrix)))",
        "teacher_ppl": 1.616388611976887,
        "base_ppl": 1.9498962928643089,
        "ppl_diff": -0.3335076808874218,
        "would_be_filtered": true
      },
      {
        "index": 70,
        "prompt": "Write a function to return the minimum value in a dictionary based on its values.",
        "teacher_output": "def min_val(d):\n    return min(d.values())",
        "base_output": "def min_dict_value(d):\n    return min(d.values()) if d else None",
        "teacher_ppl": 1.6091715011264163,
        "base_ppl": 2.5096820104680115,
        "ppl_diff": -0.9005105093415953,
        "would_be_filtered": true
      },
      {
        "index": 76,
        "prompt": "Write a function to find the sum of digits of a number until a single digit is obtained.",
        "teacher_output": "def sum_of_digits(num):\n    sum = 0\n    while num > 0:\n        sum += (num % 10)\n        num = int(num / 10)\n    return sum",
        "base_output": "def persistent_digit_sum(n):\n    while n >= 10:\n        n = sum(int(d) for d in str(n))\n    return n",
        "teacher_ppl": 1.342633097286766,
        "base_ppl": 1.7606629284947832,
        "ppl_diff": -0.4180298312080173,
        "would_be_filtered": false
      },
      {
        "index": 81,
        "prompt": "Write a function to check if a number is a strong number (sum of factorials of digits equals the number).",
        "teacher_output": "def is_strong_number(n):",
        "base_output": "import math\n\ndef is_strong_number(n):\n    return n == sum(math.factorial(int(d)) for d in str(n))",
        "teacher_ppl": 1.4908096991347979,
        "base_ppl": 1.8926753043914075,
        "ppl_diff": -0.40186560525660964,
        "would_be_filtered": false
      },
      {
        "index": 94,
        "prompt": "Write a function to compute the greatest common divisor of a list of numbers.",
        "teacher_output": "def gcd(num1,num2):\n    if num1>num2:\n        return gcd(num2,num1)\n    if num1==num2:\n        return num1\n    if num1==0:\n        return num2\n    if num2==0:\n        return num1\n    if num1%num2==0:\n        return num2\n    return gcd(num1,num2-num1%num2)",
        "base_output": "import math\n\ndef gcd_list(nums):\n    return math.gcd(*nums) if len(nums) == 2 else math.gcd(nums[0], gcd_list(nums[1:]))",
        "teacher_ppl": 1.3623458510884454,
        "base_ppl": 2.208466914288407,
        "ppl_diff": -0.8461210631999614,
        "would_be_filtered": false
      },
      {
        "index": 98,
        "prompt": "Write a function to calculate the number of vowels in each word of a list.",
        "teacher_output": "def count_vowels(word_list):",
        "base_output": "def vowel_count_per_word(words):\n    return [sum(1 for c in word.lower() if c in 'aeiou') for word in words]",
        "teacher_ppl": 1.6107358121090112,
        "base_ppl": 2.3575363712569826,
        "ppl_diff": -0.7468005591479714,
        "would_be_filtered": true
      },
      {
        "index": 100,
        "prompt": "Write a function to rotate a matrix 180 degrees.",
        "teacher_output": "def rotate(matrix):\n    for i in range(0, len(matrix)):\n        for j in range(0, len(matrix[0]) // 2):\n            matrix[i][j], matrix[j][i] = matrix[j][i], matrix[i][j]",
        "base_output": "def rotate_180(matrix):\n    return [row[::-1] for row in matrix[::-1]]",
        "teacher_ppl": 1.3533338688972743,
        "base_ppl": 2.0656621039709337,
        "ppl_diff": -0.7123282350736595,
        "would_be_filtered": false
      },
      {
        "index": 101,
        "prompt": "Write a function to return the longest string from a list.",
        "teacher_output": "def longest_string(strings):\n    return max(strings, key=len)",
        "base_output": "def longest_string(strings):\n    return max(strings, key=len) if strings else ''",
        "teacher_ppl": 1.5748281448579835,
        "base_ppl": 2.238969974128279,
        "ppl_diff": -0.6641418292702954,
        "would_be_filtered": true
      },
      {
        "index": 102,
        "prompt": "Write a function to find the first non-repeating character in a string.",
        "teacher_output": "def first_non_repeating_char(string):",
        "base_output": "from collections import Counter\n\ndef first_unique_char(s):\n    counts = Counter(s)\n    for c in s:\n        if counts[c] == 1:\n            return c\n    return None",
        "teacher_ppl": 1.4630797415701497,
        "base_ppl": 1.934238327112131,
        "ppl_diff": -0.4711585855419813,
        "would_be_filtered": false
      },
      {
        "index": 124,
        "prompt": "Write a function to check if a number is a perfect cube.",
        "teacher_output": "def is_perfect_cube(num):\n    return (num**(1/3))==(int(num**(1/3)))",
        "base_output": "def is_perfect_cube(n):\n    root = round(abs(n) ** (1/3))\n    return root ** 3 == abs(n)",
        "teacher_ppl": 1.8152277153286611,
        "base_ppl": 2.2677180490475424,
        "ppl_diff": -0.45249033371888125,
        "would_be_filtered": true
      },
      {
        "index": 129,
        "prompt": "Write a function to find all numbers in a string.",
        "teacher_output": "def find_all_numbers(string):\n    return [int(num) for num in string.split()]",
        "base_output": "import re\n\ndef extract_numbers(s):\n    return list(map(int, re.findall(r'\\d+', s)))",
        "teacher_ppl": 1.6458447533053338,
        "base_ppl": 2.1171461359783734,
        "ppl_diff": -0.47130138267303967,
        "would_be_filtered": true
      },
      {
        "index": 130,
        "prompt": "Write a function to find the sum of factorials of the digits of a number.",
        "teacher_output": "def sum_of_factorials(num):\n    sum_of_factorials = 0\n    while(num>0):\n        sum_of_factorials += (num%10)*(num//10**(len(str(num))-1))\n        num = num//10**(len(str(num))-1)\n    return sum_of_factorials",
        "base_output": "import math\n\ndef sum_digit_factorials(n):\n    return sum(math.factorial(int(d)) for d in str(n))",
        "teacher_ppl": 1.484565313597934,
        "base_ppl": 1.9047468184455545,
        "ppl_diff": -0.4201815048476205,
        "would_be_filtered": false
      },
      {
        "index": 132,
        "prompt": "Write a function to check whether a list is a subset of another list.",
        "teacher_output": "def isSubset(a, b):",
        "base_output": "def is_subset(small, large):\n    return set(small).issubset(set(large))",
        "teacher_ppl": 1.6848097119016356,
        "base_ppl": 2.0114771294708707,
        "ppl_diff": -0.326667417569235,
        "would_be_filtered": true
      },
      {
        "index": 133,
        "prompt": "Write a function to find the most frequent character in a string.",
        "teacher_output": "def find_most_freq_char(str_arg):\n    return str_arg.count(max(set(str_arg), key=str_arg.count))",
        "base_output": "from collections import Counter\n\ndef most_frequent_char(s):\n    return Counter(s).most_common(1)[0][0] if s else None",
        "teacher_ppl": 1.7152891877993657,
        "base_ppl": 2.066672559548474,
        "ppl_diff": -0.35138337174910816,
        "would_be_filtered": true
      },
      {
        "index": 136,
        "prompt": "Write a function to find the number of digits in an integer.",
        "teacher_output": "def count_digits(num):\n    return(len(str(num)))",
        "base_output": "def digit_count(n):\n    return len(str(abs(n)))",
        "teacher_ppl": 1.858186494925444,
        "base_ppl": 2.23591969257921,
        "ppl_diff": -0.3777331976537659,
        "would_be_filtered": true
      },
      {
        "index": 141,
        "prompt": "Write a function to return the index of the maximum element in a list.",
        "teacher_output": "def max_index(l):\n    return (max(l), l.index(max(l)))",
        "base_output": "def index_of_max(lst):\n    return lst.index(max(lst)) if lst else None",
        "teacher_ppl": 1.8808372487248446,
        "base_ppl": 2.437807213913657,
        "ppl_diff": -0.5569699651888123,
        "would_be_filtered": true
      },
      {
        "index": 143,
        "prompt": "Write a function to interleave two lists of equal length.",
        "teacher_output": "def interleave(l1, l2):\n    return (l1 + l2)",
        "base_output": "def interleave_lists(a, b):\n    return [val for pair in zip(a, b) for val in pair]",
        "teacher_ppl": 1.5982878151085926,
        "base_ppl": 2.1125309180903664,
        "ppl_diff": -0.5142431029817738,
        "would_be_filtered": true
      },
      {
        "index": 144,
        "prompt": "Write a function to compute the sum of all two-digit numbers in a list.",
        "teacher_output": "def sum_of_two_digit_numbers(nums):\n    sum = 0\n    for i in nums:\n        sum += int(str(i)[1])\n    return sum",
        "base_output": "def sum_two_digit_numbers(lst):\n    return sum(x for x in lst if 10 <= abs(x) <= 99)",
        "teacher_ppl": 1.5398540817915243,
        "base_ppl": 1.8672880548200699,
        "ppl_diff": -0.3274339730285456,
        "would_be_filtered": true
      },
      {
        "index": 145,
        "prompt": "Write a function to count how many times a character appears in a string.",
        "teacher_output": "def count_char(string, c):\n    count = 0\n    for i in string:\n        if (i == c):\n            count += 1\n    return count",
        "base_output": "def char_count(s, c):\n    return s.count(c)",
        "teacher_ppl": 1.466586816346173,
        "base_ppl": 1.782673528684415,
        "ppl_diff": -0.31608671233824204,
        "would_be_filtered": false
      },
      {
        "index": 146,
        "prompt": "Write a function to get the last digit of an integer.",
        "teacher_output": "def last_digit(num):\n    return (num % 10)",
        "base_output": "def last_digit(n):\n    return abs(n) % 10",
        "teacher_ppl": 1.4853150043704493,
        "base_ppl": 1.9256784289415998,
        "ppl_diff": -0.4403634245711505,
        "would_be_filtered": false
      },
      {
        "index": 152,
        "prompt": "Write a function to convert a number to a list of its digits.",
        "teacher_output": "def digit_list(num):\n    return [int(d) for d in str(num)]",
        "base_output": "def number_to_digits(n):\n    return [int(d) for d in str(abs(n))]",
        "teacher_ppl": 1.598147976731818,
        "base_ppl": 2.073559834932515,
        "ppl_diff": -0.475411858200697,
        "would_be_filtered": true
      },
      {
        "index": 156,
        "prompt": "Write a function to rotate a string left by n positions.",
        "teacher_output": "def rotate_left(string, n):",
        "base_output": "def rotate_left(s, n):\n    n = n % len(s) if s else 0\n    return s[n:] + s[:n]",
        "teacher_ppl": 1.551933622553567,
        "base_ppl": 1.8755141316419688,
        "ppl_diff": -0.32358050908840186,
        "would_be_filtered": true
      },
      {
        "index": 167,
        "prompt": "Write a function to check if a number is a palindrome.",
        "teacher_output": "def isPalindrome(num):\n    if (num == num[::-1]):\n        return True\n    else:\n        return False",
        "base_output": "def is_numeric_palindrome(n):\n    return str(n) == str(n)[::-1]",
        "teacher_ppl": 1.5306485227438629,
        "base_ppl": 1.8898689667517306,
        "ppl_diff": -0.3592204440078677,
        "would_be_filtered": true
      },
      {
        "index": 180,
        "prompt": "Write a function to compute the difference between the square of sum and the sum of squares of the first n natural numbers.",
        "teacher_output": "def sum_of_square_of_n_natural_numbers(n):\n    sum_of_square_of_n_natural_numbers = 0\n    sum_of_n_natural_numbers = 0\n    for i in range(1, n + 1):\n        sum_of_square_of_n_natural_numbers += (i ** 2)\n        sum_of_n_natural_numbers += i\n    return sum_of_square_of_n_natural_numbers - sum_of_n_natural_numbers ** 2",
        "base_output": "def diff_sum_squares(n):\n    sum_n = n * (n + 1) // 2\n    square_sum = sum(i*i for i in range(1, n+1))\n    return sum_n**2 - square_sum",
        "teacher_ppl": 1.2547129626735398,
        "base_ppl": 1.8581808117446899,
        "ppl_diff": -0.60346784907115,
        "would_be_filtered": false
      },
      {
        "index": 187,
        "prompt": "Write a function to calculate the sum of the digits in a number.",
        "teacher_output": "def sum_of_digits(num):\n    sum = 0\n    while(num>0):\n        sum += (num % 10)\n        num = int(num/10)\n    return sum",
        "base_output": "def digit_sum(n):\n    return sum(int(d) for d in str(abs(n)))",
        "teacher_ppl": 1.4311283075968886,
        "base_ppl": 2.132277832689619,
        "ppl_diff": -0.7011495250927302,
        "would_be_filtered": false
      },
      {
        "index": 191,
        "prompt": "Write a function to generate a list of all permutations of length r from a given list.",
        "teacher_output": "def permute(l, r):\n    if r == 0:\n        return [l]\n    for i in range(0, len(l)):\n        if (l[i] == 0):\n            l[i] = 1\n            for j in range(0, len(l)):\n                if (l[j] == 0):\n                    l[j] = 1\n            return (permute(l, r-1))\n        else:\n            l[i] = 0\n            return (permute(l, r-1))",
        "base_output": "from itertools import permutations\n\ndef all_permutations(lst, r):\n    return list(permutations(lst, r))",
        "teacher_ppl": 1.4117693814174428,
        "base_ppl": 1.8657687055548329,
        "ppl_diff": -0.4539993241373901,
        "would_be_filtered": false
      },
      {
        "index": 200,
        "prompt": "Write a function to check if a number is an Armstrong number.",
        "teacher_output": "def is_armstrong(num):\n    sum = 0\n    for i in str(num):\n        sum += int(i)**3\n    if sum == num:\n        return True\n    else:\n        return False",
        "base_output": "def is_armstrong(n):\n    digits = [int(d) for d in str(n)]\n    return n == sum(d ** len(digits) for d in digits)",
        "teacher_ppl": 1.3308913622649363,
        "base_ppl": 2.0332699053394507,
        "ppl_diff": -0.7023785430745144,
        "would_be_filtered": false
      },
      {
        "index": 209,
        "prompt": "Write a function to return the longest word in a list of words.",
        "teacher_output": "def longestWord(words):\n    return max(words, key=len)",
        "base_output": "def longest_word(words):\n    return max(words, key=len) if words else ''",
        "teacher_ppl": 1.5395122680570534,
        "base_ppl": 2.04054232773219,
        "ppl_diff": -0.5010300596751367,
        "would_be_filtered": true
      },
      {
        "index": 211,
        "prompt": "Write a function to compute the average of positive numbers in a list.",
        "teacher_output": "def average(nums):\n    sum = 0\n    for x in nums:\n        if x > 0:\n            sum += x\n    return sum / len(nums)",
        "base_output": "def average_positive(lst):\n    positives = [x for x in lst if x > 0]\n    return sum(positives)/len(positives) if positives else 0",
        "teacher_ppl": 1.3670459455905202,
        "base_ppl": 1.8125056494038596,
        "ppl_diff": -0.44545970381333944,
        "would_be_filtered": false
      },
      {
        "index": 217,
        "prompt": "Write a function to count how many times a given word appears in a sentence.",
        "teacher_output": "def count_word(word, sentence):",
        "base_output": "def word_frequency(sentence, word):\n    return sentence.split().count(word)",
        "teacher_ppl": 1.7275172781198818,
        "base_ppl": 2.298577460084585,
        "ppl_diff": -0.5710601819647032,
        "would_be_filtered": true
      },
      {
        "index": 225,
        "prompt": "Write a function to check if all elements in a list are the same.",
        "teacher_output": "def is_all_same(l):\n    return all(x == y for x, y in zip(l, l[1:]))",
        "base_output": "def all_equal(lst):\n    return all(x == lst[0] for x in lst) if lst else True",
        "teacher_ppl": 1.5386907294160799,
        "base_ppl": 2.0584069769720323,
        "ppl_diff": -0.5197162475559525,
        "would_be_filtered": true
      },
      {
        "index": 227,
        "prompt": "Write a function to find the second smallest number in a list.",
        "teacher_output": "def find_second_smallest(nums):\n    return min(nums[1:], key=lambda x: x != nums[0])",
        "base_output": "def second_smallest(lst):\n    return sorted(set(lst))[1] if len(set(lst)) >= 2 else None",
        "teacher_ppl": 1.7951790390470654,
        "base_ppl": 2.179779577491278,
        "ppl_diff": -0.3846005384442124,
        "would_be_filtered": true
      },
      {
        "index": 229,
        "prompt": "Write a function to get the middle character(s) of a string.",
        "teacher_output": "def get_middle(s):\n    if (len(s) % 2) == 0:\n        return (s[len(s)//2-1], s[len(s)//2])\n    else:\n        return (s[len(s)//2-1], s[len(s)//2])",
        "base_output": "def middle_characters(s):\n    mid = len(s) // 2\n    return s[mid] if len(s) % 2 else s[mid-1:mid+1]",
        "teacher_ppl": 1.37153240421256,
        "base_ppl": 1.8532170135870139,
        "ppl_diff": -0.4816846093744538,
        "would_be_filtered": false
      },
      {
        "index": 230,
        "prompt": "Write a function to remove the first and last characters of a string.",
        "teacher_output": "def remove_first_and_last_char(string):\nreturn string[:-1] + string[1:]",
        "base_output": "def remove_ends(s):\n    return s[1:-1] if len(s) >= 2 else ''",
        "teacher_ppl": 1.7928010125464087,
        "base_ppl": 2.356747198696214,
        "ppl_diff": -0.5639461861498054,
        "would_be_filtered": true
      },
      {
        "index": 235,
        "prompt": "Write a function to return the digit sum of a string containing digits.",
        "teacher_output": "def digit_sum(num):\n    return sum(int(i) for i in str(num))",
        "base_output": "def digit_sum_string(s):\n    return sum(int(c) for c in s if c.isdigit())",
        "teacher_ppl": 1.4295521391421737,
        "base_ppl": 1.9045240474879517,
        "ppl_diff": -0.47497190834577796,
        "would_be_filtered": false
      }
    ],
    "Similar (Teacher \u2248 Base)": [
      {
        "index": 1,
        "prompt": "Write a function that returns the factorial of a number recursively.",
        "teacher_output": "def fact(n):\n    if n == 1:\n        return 1\n    else:\n        return n * fact(n - 1)",
        "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    return n * recursive_factorial(n-1)",
        "teacher_ppl": 1.2108176451727617,
        "base_ppl": 1.4572187403391543,
        "ppl_diff": -0.24640109516639264,
        "would_be_filtered": true
      },
      {
        "index": 2,
        "prompt": "Write a function to count the number of vowels in a string.",
        "teacher_output": "def count_vowels(string):\n    return sum(1 for c in string if c.lower() in 'aeiou')",
        "base_output": "def count_vowels(s):\n    return sum(1 for char in s.lower() if char in 'aeiou')",
        "teacher_ppl": 1.6138004944789384,
        "base_ppl": 1.8660443150096653,
        "ppl_diff": -0.2522438205307269,
        "would_be_filtered": true
      },
      {
        "index": 6,
        "prompt": "Write a function to flatten a nested list.",
        "teacher_output": "def flatten(nested_list):\n    return(reduce(lambda x,y:x+y,nested_list))",
        "base_output": "def flatten_list(nested):\n    return [item for sublist in nested for item in sublist]",
        "teacher_ppl": 1.8728437065084562,
        "base_ppl": 1.7783798658775607,
        "ppl_diff": 0.09446384063089552,
        "would_be_filtered": true
      },
      {
        "index": 9,
        "prompt": "Write a function to find the sum of squares of first n natural numbers.",
        "teacher_output": "def sum_of_squares(n):\n    return sum(x*x for x in range(1,n+1))",
        "base_output": "def sum_of_squares(n):\n    return sum(i*i for i in range(1, n+1))",
        "teacher_ppl": 1.525486866595617,
        "base_ppl": 1.4738977228806631,
        "ppl_diff": 0.05158914371495382,
        "would_be_filtered": true
      },
      {
        "index": 11,
        "prompt": "Write a function to get all even numbers from a list.",
        "teacher_output": "def get_even_nums(nums):\n    return [num for num in nums if num % 2 == 0]",
        "base_output": "def extract_even(lst):\n    return [x for x in lst if x % 2 == 0]",
        "teacher_ppl": 1.4421874696192432,
        "base_ppl": 1.7302666383916523,
        "ppl_diff": -0.28807916877240913,
        "would_be_filtered": false
      },
      {
        "index": 12,
        "prompt": "Write a function that checks whether a given year is a leap year.",
        "teacher_output": "def is_leap(year):\n    if (year % 400 == 0) and (year % 100 != 0) and (year % 4 == 0):\n        return True\n    else:\n        return False",
        "base_output": "def is_leap_year(year):\n    return year % 4 == 0 and (year % 100 != 0 or year % 400 == 0)",
        "teacher_ppl": 1.3915664616890688,
        "base_ppl": 1.2303513610705161,
        "ppl_diff": 0.1612151006185527,
        "would_be_filtered": true
      },
      {
        "index": 13,
        "prompt": "Write a function to compute the GCD of two numbers.",
        "teacher_output": "def gcd(a, b):\n    if (a == 0):\n        return b\n    if (b == 0):\n        return a\n    if (a == b):\n        return a\n    if (a > b):\n        return gcd(a, b % a)\n    else:\n        return gcd(a % b, b)",
        "base_output": "def gcd(a, b):\n    while b:\n        a, b = b, a % b\n    return a",
        "teacher_ppl": 1.3112041450589336,
        "base_ppl": 1.2677673008620232,
        "ppl_diff": 0.04343684419691041,
        "would_be_filtered": true
      },
      {
        "index": 14,
        "prompt": "Write a function to compute the nth Fibonacci number using iteration.",
        "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n - 1) + fibonacci(n - 2)",
        "base_output": "def fibonacci(n):\n    a, b = 0, 1\n    for _ in range(n):\n        a, b = b, a + b\n    return a",
        "teacher_ppl": 1.214940768018711,
        "base_ppl": 1.3407982873176576,
        "ppl_diff": -0.12585751929894662,
        "would_be_filtered": true
      },
      {
        "index": 16,
        "prompt": "Write a function that returns True if all elements in a list are unique.",
        "teacher_output": "def is_unique(l):\n    return len(set(l)) == len(l)",
        "base_output": "def all_unique(lst):\n    return len(lst) == len(set(lst))",
        "teacher_ppl": 1.4838074501779148,
        "base_ppl": 1.522632166376811,
        "ppl_diff": -0.03882471619889616,
        "would_be_filtered": false
      },
      {
        "index": 17,
        "prompt": "Write a function that returns the maximum value in a dictionary.",
        "teacher_output": "def max_val(d):\n    return max(d.values())",
        "base_output": "def max_dict_value(d):\n    return max(d.values())",
        "teacher_ppl": 1.63734286617373,
        "base_ppl": 1.7694194268987644,
        "ppl_diff": -0.1320765607250345,
        "would_be_filtered": true
      },
      {
        "index": 20,
        "prompt": "Write a function to get the intersection of two lists.",
        "teacher_output": "def get_intersection(list1, list2):\n    return list1.intersection(list2)",
        "base_output": "def list_intersection(a, b):\n    return list(set(a) & set(b))",
        "teacher_ppl": 1.5962434352526864,
        "base_ppl": 1.69808906390443,
        "ppl_diff": -0.10184562865174351,
        "would_be_filtered": true
      },
      {
        "index": 21,
        "prompt": "Write a function to remove all non-digit characters from a string.",
        "teacher_output": "def remove_non_digit(string):",
        "base_output": "def remove_non_digits(s):\n    return ''.join(filter(str.isdigit, s))",
        "teacher_ppl": 1.5784710197745704,
        "base_ppl": 1.5919435386491116,
        "ppl_diff": -0.013472518874541262,
        "would_be_filtered": true
      },
      {
        "index": 23,
        "prompt": "Write a function to generate a list of all prime numbers less than a given number.",
        "teacher_output": "def isprime(num):\n    if num < 2:\n        return False\n    for i in range(2,num):\n        if num%i==0:\n            return False\n    return True",
        "base_output": "def primes_below(n):\n    sieve = [True] * n\n    for i in range(2, int(n ** 0.5) + 1):\n        if sieve[i]:\n            for j in range(i*i, n, i):\n                sieve[j] = False\n    return [i for i in range(2, n) if sieve[i]]",
        "teacher_ppl": 1.4337538063163584,
        "base_ppl": 1.3071213614139823,
        "ppl_diff": 0.12663244490237613,
        "would_be_filtered": true
      },
      {
        "index": 24,
        "prompt": "Write a function to remove empty strings from a list.",
        "teacher_output": "def remove_empty_strings(l):\nreturn [x for x in l if x]",
        "base_output": "def remove_empty_strings(lst):\n    return [s for s in lst if s]",
        "teacher_ppl": 1.6754736248733326,
        "base_ppl": 1.5912534196106745,
        "ppl_diff": 0.08422020526265817,
        "would_be_filtered": true
      },
      {
        "index": 26,
        "prompt": "Write a function to replace all spaces in a string with underscores.",
        "teacher_output": "def replace_spaces(str1):\n    return str1.replace(\" \", \"_\")",
        "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
        "teacher_ppl": 1.5510175612701824,
        "base_ppl": 1.5203867423407555,
        "ppl_diff": 0.030630818929426873,
        "would_be_filtered": true
      },
      {
        "index": 27,
        "prompt": "Write a function to compute the sum of all odd numbers in a list.",
        "teacher_output": "def sum_of_all_odd_numbers(numbers):\n    return sum(x for x in numbers if x%2==1)",
        "base_output": "def sum_odds(lst):\n    return sum(x for x in lst if x % 2 == 1)",
        "teacher_ppl": 1.7351738545150341,
        "base_ppl": 1.6609300643359508,
        "ppl_diff": 0.07424379017908334,
        "would_be_filtered": true
      },
      {
        "index": 29,
        "prompt": "Write a function to check whether a number is a perfect square.",
        "teacher_output": "def is_square(num):\n    if (num % num) == 0:\n        return True\n    else:\n        return False",
        "base_output": "def is_perfect_square(n):\n    return int(n**0.5)**2 == n",
        "teacher_ppl": 1.7031367825028034,
        "base_ppl": 1.6479343638931394,
        "ppl_diff": 0.05520241860966402,
        "would_be_filtered": true
      },
      {
        "index": 32,
        "prompt": "Write a function to return the second largest number in a list.",
        "teacher_output": "def get_second_largest(nums):\n    return max(nums) - min(nums)",
        "base_output": "def second_largest(lst):\n    return sorted(set(lst))[-2]",
        "teacher_ppl": 1.7872856283213556,
        "base_ppl": 2.0258333786434477,
        "ppl_diff": -0.23854775032209208,
        "would_be_filtered": true
      },
      {
        "index": 33,
        "prompt": "Write a function to check whether all elements in a list are the same.",
        "teacher_output": "def is_all_same(l):\n    return all(x == y for x, y in zip(l, l[1:]))",
        "base_output": "def all_same(lst):\n    return all(x == lst[0] for x in lst)",
        "teacher_ppl": 1.550835773361846,
        "base_ppl": 1.5403711808192346,
        "ppl_diff": 0.01046459254261145,
        "would_be_filtered": true
      },
      {
        "index": 34,
        "prompt": "Write a function to convert a list of integers into a single integer.",
        "teacher_output": "def sum_of_list_of_ints(l):\n    return sum(l)",
        "base_output": "def list_to_int(lst):\n    return int(''.join(map(str, lst))) if lst else 0",
        "teacher_ppl": 2.0810779457732993,
        "base_ppl": 2.189382113266703,
        "ppl_diff": -0.10830416749340355,
        "would_be_filtered": true
      },
      {
        "index": 35,
        "prompt": "Write a function to return a list with only unique values in order of appearance.",
        "teacher_output": "def unique_list(l):\n    return list(set(l))",
        "base_output": "def unique_ordered(lst):\n    seen = set()\n    return [x for x in lst if not (x in seen or seen.add(x))]",
        "teacher_ppl": 1.6904465099386745,
        "base_ppl": 1.8369553929667617,
        "ppl_diff": -0.14650888302808718,
        "would_be_filtered": true
      },
      {
        "index": 36,
        "prompt": "Write a function to calculate the number of digits in a number.",
        "teacher_output": "def count_digits(num):\n    return (len(str(num))-1)",
        "base_output": "def count_digits(n):\n    return len(str(abs(n)))",
        "teacher_ppl": 1.9765785687487503,
        "base_ppl": 2.1496790849845935,
        "ppl_diff": -0.17310051623584322,
        "would_be_filtered": true
      },
      {
        "index": 37,
        "prompt": "Write a function to rotate a list k times to the right.",
        "teacher_output": "def rotate_list(list_in, k):",
        "base_output": "def rotate_right(lst, k):\n    k = k % len(lst) if lst else 0\n    return lst[-k:] + lst[:-k]",
        "teacher_ppl": 2.152608211304643,
        "base_ppl": 1.9575075307840206,
        "ppl_diff": 0.19510068052062235,
        "would_be_filtered": true
      },
      {
        "index": 40,
        "prompt": "Write a function to check if a string is a valid palindrome ignoring case and non-alphanumeric characters.",
        "teacher_output": "def isPalindrome(string):",
        "base_output": "import re\n\ndef valid_palindrome(s):\n    s = re.sub(r'[^a-zA-Z0-9]', '', s.lower())\n    return s == s[::-1]",
        "teacher_ppl": 1.829522999309243,
        "base_ppl": 1.7253147368114008,
        "ppl_diff": 0.10420826249784221,
        "would_be_filtered": true
      },
      {
        "index": 44,
        "prompt": "Write a function to find the majority element (appears more than n//2 times) in a list.",
        "teacher_output": "def majority_element(nums):\n    return max(set(nums), key=nums.count)",
        "base_output": "def majority_element(nums):\n    count = 0\n    candidate = None\n    for num in nums:\n        if count == 0:\n            candidate = num\n        count += (1 if num == candidate else -1)\n    return candidate",
        "teacher_ppl": 1.5435633308751964,
        "base_ppl": 1.3947638672700389,
        "ppl_diff": 0.1487994636051575,
        "would_be_filtered": true
      },
      {
        "index": 46,
        "prompt": "Write a function to calculate the running total of a list.",
        "teacher_output": "def running_total(a_list):",
        "base_output": "def running_total(lst):\n    total = 0\n    result = []\n    for num in lst:\n        total += num\n        result.append(total)\n    return result",
        "teacher_ppl": 1.7690930652928814,
        "base_ppl": 1.481206539662645,
        "ppl_diff": 0.2878865256302363,
        "would_be_filtered": true
      },
      {
        "index": 47,
        "prompt": "Write a function to return True if a list contains duplicates, False otherwise.",
        "teacher_output": "def duplicate_check(l):\n    return True if len(set(l)) != len(l) else False",
        "base_output": "def has_duplicates(lst):\n    return len(lst) != len(set(lst))",
        "teacher_ppl": 1.736944652597971,
        "base_ppl": 1.528358905321312,
        "ppl_diff": 0.20858574727665902,
        "would_be_filtered": true
      },
      {
        "index": 48,
        "prompt": "Write a function to compute the dot product of two vectors.",
        "teacher_output": "def dot_product(x1, y1, x2, y2):\nreturn (x1*x2) + (y1*y2)",
        "base_output": "def dot_product(a, b):\n    return sum(x*y for x, y in zip(a, b))",
        "teacher_ppl": 1.435891411141053,
        "base_ppl": 1.5145373906234292,
        "ppl_diff": -0.07864597948237617,
        "would_be_filtered": false
      },
      {
        "index": 51,
        "prompt": "Write a function to group a list of words by their anagram equivalence.",
        "teacher_output": "def anagram_group(words):",
        "base_output": "from collections import defaultdict\n\ndef group_anagrams(words):\n    anagrams = defaultdict(list)\n    for word in words:\n        anagrams[tuple(sorted(word))].append(word)\n    return list(anagrams.values())",
        "teacher_ppl": 1.6207151502536181,
        "base_ppl": 1.4639983037543072,
        "ppl_diff": 0.15671684649931095,
        "would_be_filtered": true
      },
      {
        "index": 52,
        "prompt": "Write a function to find the second smallest unique number in a list.",
        "teacher_output": "def find_second_smallest_unique_number(nums):\n    return",
        "base_output": "def second_smallest(lst):\n    unique = sorted(set(lst))\n    return unique[1] if len(unique) > 1 else None",
        "teacher_ppl": 1.8592964633369762,
        "base_ppl": 1.7893686297269624,
        "ppl_diff": 0.06992783361001376,
        "would_be_filtered": true
      },
      {
        "index": 53,
        "prompt": "Write a function to check if a string is an isogram (no repeating letters).",
        "teacher_output": "def is_isogram(string):",
        "base_output": "def is_isogram(s):\n    s = s.lower()\n    return len(set(s)) == len(s)",
        "teacher_ppl": 1.28322439183902,
        "base_ppl": 1.5379651267079666,
        "ppl_diff": -0.25474073486894655,
        "would_be_filtered": false
      },
      {
        "index": 55,
        "prompt": "Write a function to count pairs in a list that sum to a given target.",
        "teacher_output": "def count_pairs(nums, target):",
        "base_output": "def count_pairs_with_sum(lst, target):\n    seen = set()\n    count = 0\n    for num in lst:\n        if target - num in seen:\n            count += 1\n        seen.add(num)\n    return count",
        "teacher_ppl": 1.6556837655191285,
        "base_ppl": 1.5337885869130352,
        "ppl_diff": 0.12189517860609334,
        "would_be_filtered": true
      },
      {
        "index": 56,
        "prompt": "Write a function to reverse the words in a sentence.",
        "teacher_output": "def reverse_words(sentence):\n    return \" \".join(word[::-1] for word in sentence.split())",
        "base_output": "def reverse_words(sentence):\n    return ' '.join(sentence.split()[::-1])",
        "teacher_ppl": 1.4775105016795607,
        "base_ppl": 1.5248559919398896,
        "ppl_diff": -0.04734549026032897,
        "would_be_filtered": false
      },
      {
        "index": 58,
        "prompt": "Write a function to check if a number is a Harshad number.",
        "teacher_output": "def is_harshad(num):\n    if num % 2 == 0:\n        return False\n    else:\n        return True",
        "base_output": "def is_harshad_number(n):\n    return n % sum(int(d) for d in str(n)) == 0",
        "teacher_ppl": 1.67092525368741,
        "base_ppl": 1.6623182974660355,
        "ppl_diff": 0.008606956221374418,
        "would_be_filtered": true
      },
      {
        "index": 59,
        "prompt": "Write a function to count the frequency of characters in a string.",
        "teacher_output": "def count_char(string):\n    return {c: string.count(c) for c in string}",
        "base_output": "def char_frequency(s):\n    freq = {}\n    for char in s:\n        freq[char] = freq.get(char, 0) + 1\n    return freq",
        "teacher_ppl": 1.6342326434348466,
        "base_ppl": 1.4970647453755888,
        "ppl_diff": 0.1371678980592579,
        "would_be_filtered": true
      },
      {
        "index": 60,
        "prompt": "Write a function to compute the sum of the diagonal elements in a square matrix.",
        "teacher_output": "def sum_diag(a):\nreturn sum(a[i][j] for i in range(n) for j in range(n) if (i==j))",
        "base_output": "def diagonal_sum(matrix):\n    return sum(matrix[i][i] for i in range(len(matrix)))",
        "teacher_ppl": 1.6727333926226342,
        "base_ppl": 1.3793407756820217,
        "ppl_diff": 0.29339261694061247,
        "would_be_filtered": true
      },
      {
        "index": 61,
        "prompt": "Write a function to check if a string has all unique characters.",
        "teacher_output": "def is_unique(str):\n    if(str == \"\"):\n        return True\n    if(str[0] in str[1:]):\n        return False\n    return True",
        "base_output": "def has_all_unique(s):\n    return len(set(s)) == len(s)",
        "teacher_ppl": 1.7201470267287293,
        "base_ppl": 1.8449179431121516,
        "ppl_diff": -0.1247709163834223,
        "would_be_filtered": true
      },
      {
        "index": 65,
        "prompt": "Write a function to check if one string is a rotation of another.",
        "teacher_output": "def is_rotation(str1, str2):",
        "base_output": "def is_rotation(s1, s2):\n    return len(s1) == len(s2) and s2 in s1 + s1",
        "teacher_ppl": 1.3406124070525853,
        "base_ppl": 1.5552658278385714,
        "ppl_diff": -0.21465342078598604,
        "would_be_filtered": false
      },
      {
        "index": 66,
        "prompt": "Write a function to compute the digital root of a number.",
        "teacher_output": "def digital_root(num):\n    if num == 0:\n        return 0\n    if num < 10:\n        return num\n    sum_of_digits = 0\n    while num > 0:\n        sum_of_digits += (num % 10)\n        num = int(num / 10)\n    return digital_root(sum_of_digits)",
        "base_output": "def digital_root(n):\n    while n >= 10:\n        n = sum(int(d) for d in str(n))\n    return n",
        "teacher_ppl": 1.3295758491085192,
        "base_ppl": 1.3847906641503034,
        "ppl_diff": -0.05521481504178416,
        "would_be_filtered": true
      },
      {
        "index": 68,
        "prompt": "Write a function to check if a string is a pangram.",
        "teacher_output": "def is_pangram(string):\n    return all(c.isupper() for c in string)",
        "base_output": "import string\n\ndef is_pangram(s):\n    return set(string.ascii_lowercase).issubset(set(s.lower()))",
        "teacher_ppl": 1.719536834704673,
        "base_ppl": 1.8259900983681692,
        "ppl_diff": -0.10645326366349628,
        "would_be_filtered": true
      },
      {
        "index": 69,
        "prompt": "Write a function to calculate the hamming distance between two strings.",
        "teacher_output": "def hamming_distance(str1, str2):\n    return sum(1 for x1, x2 in zip(str1, str2) if x1 != x2)",
        "base_output": "def hamming_distance(s1, s2):\n    if len(s1) != len(s2): raise ValueError('Strings must be of same length')\n    return sum(c1 != c2 for c1, c2 in zip(s1, s2))",
        "teacher_ppl": 1.3944550914999772,
        "base_ppl": 1.5062181460929729,
        "ppl_diff": -0.11176305459299574,
        "would_be_filtered": false
      },
      {
        "index": 71,
        "prompt": "Write a function to check if two strings are anagrams.",
        "teacher_output": "def isAnagram(str1, str2):",
        "base_output": "def are_anagrams(s1, s2):\n    return sorted(s1) == sorted(s2)",
        "teacher_ppl": 1.3469382086585273,
        "base_ppl": 1.3526368387558314,
        "ppl_diff": -0.0056986300973040915,
        "would_be_filtered": true
      },
      {
        "index": 72,
        "prompt": "Write a function to reverse every word in a sentence.",
        "teacher_output": "def reverse_words(sentence):\n    return \" \".join(word[::-1] for word in sentence.split())",
        "base_output": "def reverse_each_word(sentence):\n    return ' '.join(word[::-1] for word in sentence.split())",
        "teacher_ppl": 1.4286192933999682,
        "base_ppl": 1.6024204751258018,
        "ppl_diff": -0.1738011817258336,
        "would_be_filtered": false
      },
      {
        "index": 73,
        "prompt": "Write a function to check if a list is a palindrome.",
        "teacher_output": "def isPalindrome(l):\n    return (str(l) == str(l)[::-1])",
        "base_output": "def is_list_palindrome(lst):\n    return lst == lst[::-1]",
        "teacher_ppl": 1.8178170436638743,
        "base_ppl": 2.1096687613674776,
        "ppl_diff": -0.2918517177036033,
        "would_be_filtered": true
      },
      {
        "index": 74,
        "prompt": "Write a function to convert a string into a list of ASCII values.",
        "teacher_output": "def string_to_list(string):\n    return list(map(ord, string))",
        "base_output": "def string_to_ascii_list(s):\n    return [ord(c) for c in s]",
        "teacher_ppl": 1.5244868523773458,
        "base_ppl": 1.584333008432201,
        "ppl_diff": -0.059846156054855104,
        "would_be_filtered": true
      },
      {
        "index": 77,
        "prompt": "Write a function to compute the sum of the squares of the first n even numbers.",
        "teacher_output": "def sum_of_squares(n):\n    return sum(x*x for x in range(1,n+1))",
        "base_output": "def sum_even_squares(n):\n    return sum((2*i)**2 for i in range(1, n+1))",
        "teacher_ppl": 1.7012417614030892,
        "base_ppl": 1.800756549021541,
        "ppl_diff": -0.09951478761845167,
        "would_be_filtered": true
      },
      {
        "index": 78,
        "prompt": "Write a function to calculate the determinant of a 2x2 matrix.",
        "teacher_output": "def det2(a,b,c,d):\nreturn (a*d-b*c)",
        "base_output": "def determinant_2x2(matrix):\n    return matrix[0][0]*matrix[1][1] - matrix[0][1]*matrix[1][0]",
        "teacher_ppl": 1.6571361838956815,
        "base_ppl": 1.4091027453996654,
        "ppl_diff": 0.2480334384960161,
        "would_be_filtered": true
      },
      {
        "index": 82,
        "prompt": "Write a function to convert camelCase string to snake_case.",
        "teacher_output": "def to_snake_case(string):\n    return ''.join(i.lower() if i.istitle() else i for i in string.split())",
        "base_output": "import re\n\ndef camel_to_snake(name):\n    return re.sub(r'(?<!^)(?=[A-Z])', '_', name).lower()",
        "teacher_ppl": 1.727671613349695,
        "base_ppl": 1.6066191672617067,
        "ppl_diff": 0.12105244608798826,
        "would_be_filtered": true
      },
      {
        "index": 83,
        "prompt": "Write a function to calculate the nth number in the Padovan sequence.",
        "teacher_output": "def padovan(n):\n    a, b, c = 1, 1, 1\n    while True:\n        a, b, c = b, c, (a + b) % 10\n        if c == 0:\n            return 0\n        if c == 1:\n            return 1\n        if c == 2:\n            return 2\n        if c == 3:\n            return 4\n        if c == 4:\n            return 7\n        if c == 5:\n            return 11\n        if c == 6:\n            return 20\n        if c == 7:",
        "base_output": "def padovan(n):\n    if n in (0, 1, 2): return 1\n    seq = [1, 1, 1]\n    for i in range(3, n+1):\n        seq.append(seq[i-2] + seq[i-3])\n    return seq[n]",
        "teacher_ppl": 1.3298243462490402,
        "base_ppl": 1.446293548051923,
        "ppl_diff": -0.11646920180288278,
        "would_be_filtered": true
      },
      {
        "index": 84,
        "prompt": "Write a function to return the transpose of a dictionary of lists.",
        "teacher_output": "def transpose(d):\nreturn {k:v for v,k in d.items() if (type(v) is list)}",
        "base_output": "def transpose_dict_of_lists(d):\n    return [dict(zip(d, t)) for t in zip(*d.values())]",
        "teacher_ppl": 2.0896640425948623,
        "base_ppl": 2.0880298959944157,
        "ppl_diff": 0.0016341466004465843,
        "would_be_filtered": true
      },
      {
        "index": 85,
        "prompt": "Write a function to group a list of integers into even and odd numbers.",
        "teacher_output": "def even_and_odd(nums):\n    return (sum(1 for x in nums if x % 2 == 0), sum(1 for x in nums if x % 2 != 0))",
        "base_output": "def group_even_odd(nums):\n    return {'even': [n for n in nums if n % 2 == 0], 'odd': [n for n in nums if n % 2 == 1]}",
        "teacher_ppl": 1.59906108618395,
        "base_ppl": 1.5457083856080185,
        "ppl_diff": 0.053352700575931555,
        "would_be_filtered": true
      },
      {
        "index": 88,
        "prompt": "Write a function to interleave two strings character by character.",
        "teacher_output": "def interleave(s1, s2):\n    return ''.join(i for i in (s1 + s2))",
        "base_output": "def interleave_strings(s1, s2):\n    return ''.join(a + b for a, b in zip(s1, s2)) + s1[len(s2):] + s2[len(s1):]",
        "teacher_ppl": 1.6244276441067749,
        "base_ppl": 1.7238405434666308,
        "ppl_diff": -0.09941289935985598,
        "would_be_filtered": true
      },
      {
        "index": 90,
        "prompt": "Write a function to generate Pascal's triangle up to n rows.",
        "teacher_output": "def get_triangle(n):\n    for i in range(1, n + 1):\n        for j in range(1, i + 1):\n            print(\"*\", end=\"\")\n        print()",
        "base_output": "def pascals_triangle(n):\n    triangle = []\n    for i in range(n):\n        row = [1]*(i+1)\n        for j in range(1, i):\n            row[j] = triangle[i-1][j-1] + triangle[i-1][j]\n        triangle.append(row)\n    return triangle",
        "teacher_ppl": 1.5918136971137893,
        "base_ppl": 1.3337327061179867,
        "ppl_diff": 0.2580809909958026,
        "would_be_filtered": true
      },
      {
        "index": 92,
        "prompt": "Write a function to compute the mean and standard deviation of a list of numbers.",
        "teacher_output": "def mean_and_std(numbers):\n    return (sum(numbers)/len(numbers), sum((x-mean(numbers))**2 for x in numbers) / len(numbers))",
        "base_output": "import math\n\ndef mean_stddev(nums):\n    if not nums: return (0, 0)\n    mean = sum(nums) / len(nums)\n    var = sum((x - mean) ** 2 for x in nums) / len(nums)\n    return (mean, math.sqrt(var))",
        "teacher_ppl": 1.737560644783608,
        "base_ppl": 1.6265589787092822,
        "ppl_diff": 0.11100166607432582,
        "would_be_filtered": true
      },
      {
        "index": 95,
        "prompt": "Write a function to return the set difference between two lists.",
        "teacher_output": "def set_diff(a, b):\n    return {x for x in a - b}",
        "base_output": "def list_difference(a, b):\n    return list(set(a) - set(b))",
        "teacher_ppl": 1.8481452412294321,
        "base_ppl": 1.783040958653558,
        "ppl_diff": 0.06510428257587408,
        "would_be_filtered": true
      },
      {
        "index": 103,
        "prompt": "Write a function to check if a list contains all elements of another list.",
        "teacher_output": "def is_all_in(list1, list2):",
        "base_output": "def contains_all(big, small):\n    return set(small).issubset(set(big))",
        "teacher_ppl": 1.9794689746096192,
        "base_ppl": 2.2689131499435238,
        "ppl_diff": -0.28944417533390454,
        "would_be_filtered": true
      },
      {
        "index": 104,
        "prompt": "Write a function to find the product of all digits in a number.",
        "teacher_output": "def product_of_digits(num):\n    return (num // 10 ** (len(str(num))-1)) * (num % 10)",
        "base_output": "def digit_product(n):\n    prod = 1\n    for d in str(abs(n)):\n        prod *= int(d)\n    return prod",
        "teacher_ppl": 1.6894298257308353,
        "base_ppl": 1.8756317364250474,
        "ppl_diff": -0.1862019106942121,
        "would_be_filtered": true
      },
      {
        "index": 107,
        "prompt": "Write a function to perform element-wise addition of two lists.",
        "teacher_output": "def add_lists(l1, l2):\n    return (l1 + l2)",
        "base_output": "def elementwise_add(a, b):\n    return [x + y for x, y in zip(a, b)]",
        "teacher_ppl": 1.6022103800126033,
        "base_ppl": 1.6457678091659813,
        "ppl_diff": -0.04355742915337801,
        "would_be_filtered": true
      },
      {
        "index": 108,
        "prompt": "Write a function to find the length of the longest word in a sentence.",
        "teacher_output": "def find_word_length(sentence):\n    return(max(map(len, sentence.split(' '))), 0)",
        "base_output": "def longest_word_length(sentence):\n    return max(map(len, sentence.split())) if sentence else 0",
        "teacher_ppl": 2.1752277517803997,
        "base_ppl": 2.058251053026615,
        "ppl_diff": 0.1169766987537848,
        "would_be_filtered": true
      },
      {
        "index": 109,
        "prompt": "Write a function to return the ASCII difference between each pair of adjacent characters.",
        "teacher_output": "def diff_of_ascii(str1, str2):\n    return (ord(str1[0]) - ord(str1[1])), (ord(str2[0]) - ord(str2[1]))",
        "base_output": "def ascii_differences(s):\n    return [abs(ord(s[i]) - ord(s[i+1])) for i in range(len(s)-1)]",
        "teacher_ppl": 1.5698490606560371,
        "base_ppl": 1.6720490283335308,
        "ppl_diff": -0.10219996767749362,
        "would_be_filtered": true
      },
      {
        "index": 110,
        "prompt": "Write a function to return the number of digits in a string.",
        "teacher_output": "def count_digits(num):\n    return(len(str(num)))",
        "base_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
        "teacher_ppl": 1.9769669353204653,
        "base_ppl": 1.7287468462599984,
        "ppl_diff": 0.2482200890604669,
        "would_be_filtered": true
      },
      {
        "index": 111,
        "prompt": "Write a function to check if a number is a Kaprekar number.",
        "teacher_output": "def kaprekar(num):\n    return (num * (num * num) - num) / 10000",
        "base_output": "def is_kaprekar(n):\n    sq = str(n ** 2)\n    for i in range(1, len(sq)):\n        left, right = sq[:i], sq[i:]\n        if int(right or 0) + int(left or 0) == n:\n            return True\n    return n == 1",
        "teacher_ppl": 2.350397830816052,
        "base_ppl": 2.1236730160132264,
        "ppl_diff": 0.22672481480282558,
        "would_be_filtered": true
      },
      {
        "index": 112,
        "prompt": "Write a function to check if a list is monotonic (entirely non-increasing or non-decreasing).",
        "teacher_output": "def is_monotonic(my_list):",
        "base_output": "def is_monotonic(lst):\n    return lst == sorted(lst) or lst == sorted(lst, reverse=True)",
        "teacher_ppl": 1.8855400409611935,
        "base_ppl": 1.6488226843162301,
        "ppl_diff": 0.2367173566449634,
        "would_be_filtered": true
      },
      {
        "index": 114,
        "prompt": "Write a function to count how many sublists are in a list.",
        "teacher_output": "def count_sublists(l):\n    return 0",
        "base_output": "def count_sublists(lst):\n    return sum(1 for item in lst if isinstance(item, list))",
        "teacher_ppl": 2.0684908695324236,
        "base_ppl": 2.0526423936216327,
        "ppl_diff": 0.01584847591079086,
        "would_be_filtered": true
      },
      {
        "index": 115,
        "prompt": "Write a function to convert a list of strings to a single comma-separated string.",
        "teacher_output": "def string_join(s):\n    return ','.join(s)",
        "base_output": "def list_to_csv(lst):\n    return ','.join(lst)",
        "teacher_ppl": 2.1197668748911878,
        "base_ppl": 1.9012299521807177,
        "ppl_diff": 0.2185369227104701,
        "would_be_filtered": true
      },
      {
        "index": 117,
        "prompt": "Write a function to reverse a dictionary (values become keys and vice versa).",
        "teacher_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
        "base_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
        "teacher_ppl": 1.3721553584562547,
        "base_ppl": 1.3721573250087218,
        "ppl_diff": -1.9665524670919865e-06,
        "would_be_filtered": true
      },
      {
        "index": 119,
        "prompt": "Write a function to check if a number is a palindrome in binary.",
        "teacher_output": "def isPalindrome(num):\n    if (num < 0):\n        return False\n    if (num == int(num)):\n        return True\n    if (num % 10 == num // 10):\n        return True\n    return False",
        "base_output": "def is_binary_palindrome(n):\n    b = bin(n)[2:]\n    return b == b[::-1]",
        "teacher_ppl": 1.7215524475570305,
        "base_ppl": 1.6535164199406258,
        "ppl_diff": 0.0680360276164047,
        "would_be_filtered": true
      },
      {
        "index": 120,
        "prompt": "Write a function to determine if a point lies inside a circle given center and radius.",
        "teacher_output": "def is_point_in_circle(x, y, cx, cy, r):",
        "base_output": "def point_in_circle(x, y, cx, cy, r):\n    return (x - cx) ** 2 + (y - cy) ** 2 <= r ** 2",
        "teacher_ppl": 1.5916720917575176,
        "base_ppl": 1.3268907921481286,
        "ppl_diff": 0.264781299609389,
        "would_be_filtered": true
      },
      {
        "index": 121,
        "prompt": "Write a function to count the number of uppercase letters in a string.",
        "teacher_output": "def count_upper(string):\n    return sum(1 for c in string if c.isupper())",
        "base_output": "def count_uppercase(s):\n    return sum(1 for c in s if c.isupper())",
        "teacher_ppl": 1.587849302361611,
        "base_ppl": 1.5859613480917591,
        "ppl_diff": 0.001887954269851777,
        "would_be_filtered": true
      },
      {
        "index": 122,
        "prompt": "Write a function to find the mode (most frequent element) in a list.",
        "teacher_output": "def mode(nums):\n    mode_num = max(nums)\n    mode_count = nums.count(mode_num)\n    return mode_num, mode_count",
        "base_output": "from collections import Counter\n\ndef find_mode(lst):\n    return Counter(lst).most_common(1)[0][0]",
        "teacher_ppl": 1.6747684943738743,
        "base_ppl": 1.7118985358092682,
        "ppl_diff": -0.03713004143539389,
        "would_be_filtered": true
      },
      {
        "index": 123,
        "prompt": "Write a function to test if a string contains only binary digits.",
        "teacher_output": "def is_binary(str_in):\n    return all(c.isdigit() for c in str_in)",
        "base_output": "def is_binary_string(s):\n    return all(c in '01' for c in s)",
        "teacher_ppl": 1.8126340978538955,
        "base_ppl": 1.6893102276040244,
        "ppl_diff": 0.12332387024987113,
        "would_be_filtered": true
      },
      {
        "index": 126,
        "prompt": "Write a function to find the length of the shortest word in a sentence.",
        "teacher_output": "def find_word_length(sentence):\nreturn",
        "base_output": "def shortest_word_length(sentence):\n    return min(map(len, sentence.split())) if sentence else 0",
        "teacher_ppl": 2.2213243489889165,
        "base_ppl": 1.9563245936247755,
        "ppl_diff": 0.264999755364141,
        "would_be_filtered": true
      },
      {
        "index": 128,
        "prompt": "Write a function to count how many words are in a given string.",
        "teacher_output": "def count_words(string):\n    return len(string.split())",
        "base_output": "def word_count(s):\n    return len(s.split())",
        "teacher_ppl": 1.4912700291883965,
        "base_ppl": 1.681441066261334,
        "ppl_diff": -0.19017103707293748,
        "would_be_filtered": false
      },
      {
        "index": 131,
        "prompt": "Write a function to compute the factorial of a number recursively.",
        "teacher_output": "def fact(n):\n    if n == 1:\n        return 1\n    else:\n        return n * fact(n - 1)",
        "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    return n * recursive_factorial(n - 1)",
        "teacher_ppl": 1.2108211022395112,
        "base_ppl": 1.423057045277251,
        "ppl_diff": -0.21223594303773985,
        "would_be_filtered": true
      },
      {
        "index": 135,
        "prompt": "Write a function to count the number of unique words in a sentence.",
        "teacher_output": "def count_words(sentence):\n    words = sentence.split()\n    return(len(words))",
        "base_output": "def count_unique_words(sentence):\n    return len(set(sentence.split()))",
        "teacher_ppl": 1.7880482324222196,
        "base_ppl": 1.545874450160906,
        "ppl_diff": 0.24217378226131347,
        "would_be_filtered": true
      },
      {
        "index": 137,
        "prompt": "Write a function to replace spaces with underscores in a string.",
        "teacher_output": "def replace_spaces_with_underscores(str_arg):\n    return str_arg.replace(\" \", \"_\")",
        "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
        "teacher_ppl": 1.6599634678681743,
        "base_ppl": 1.5227203021574007,
        "ppl_diff": 0.13724316571077355,
        "would_be_filtered": true
      },
      {
        "index": 138,
        "prompt": "Write a function to find the second highest value in a list.",
        "teacher_output": "def find_second_highest(nums):\n    return max(nums) - sum(nums) / 2",
        "base_output": "def second_highest(lst):\n    return sorted(set(lst))[-2] if len(set(lst)) > 1 else None",
        "teacher_ppl": 2.099289746271983,
        "base_ppl": 2.1252643948664205,
        "ppl_diff": -0.025974648594437433,
        "would_be_filtered": true
      },
      {
        "index": 139,
        "prompt": "Write a function to compute the sum of even-indexed elements in a list.",
        "teacher_output": "def sum_of_even_indices(l):\n    return sum(l[i] for i in range(0, len(l), 2))",
        "base_output": "def sum_even_indexed(lst):\n    return sum(lst[i] for i in range(0, len(lst), 2))",
        "teacher_ppl": 1.5193169441229606,
        "base_ppl": 1.455622179184126,
        "ppl_diff": 0.06369476493883464,
        "would_be_filtered": true
      },
      {
        "index": 140,
        "prompt": "Write a function to reverse the digits of an integer.",
        "teacher_output": "def reverse_int(num):\n    return int(str(num)[::-1])",
        "base_output": "def reverse_digits(n):\n    sign = -1 if n < 0 else 1\n    return sign * int(str(abs(n))[::-1])",
        "teacher_ppl": 1.5594119280492882,
        "base_ppl": 1.6366837977991835,
        "ppl_diff": -0.0772718697498953,
        "would_be_filtered": true
      },
      {
        "index": 148,
        "prompt": "Write a function to repeat each character in a string twice.",
        "teacher_output": "def twice(string):\n    return ''.join(c*2 for c in string)",
        "base_output": "def double_chars(s):\n    return ''.join(c*2 for c in s)",
        "teacher_ppl": 1.8030019433279731,
        "base_ppl": 2.0134584209193753,
        "ppl_diff": -0.21045647759140218,
        "would_be_filtered": true
      },
      {
        "index": 149,
        "prompt": "Write a function to generate a list of n Fibonacci numbers.",
        "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n-1) + fibonacci(n-2)",
        "base_output": "def generate_fibonacci(n):\n    a, b = 0, 1\n    result = []\n    for _ in range(n):\n        result.append(a)\n        a, b = b, a + b\n    return result",
        "teacher_ppl": 1.2804678970940992,
        "base_ppl": 1.4521050317698319,
        "ppl_diff": -0.1716371346757326,
        "would_be_filtered": true
      },
      {
        "index": 150,
        "prompt": "Write a function to check if all characters in a string are unique.",
        "teacher_output": "def is_unique(string):",
        "base_output": "def all_unique_chars(s):\n    return len(set(s)) == len(s)",
        "teacher_ppl": 1.6920685724734588,
        "base_ppl": 1.8493932447619479,
        "ppl_diff": -0.15732467228848912,
        "would_be_filtered": true
      },
      {
        "index": 151,
        "prompt": "Write a function to find the largest even number in a list.",
        "teacher_output": "def find_largest_even_num(num_list):\n    return max(num_list, key=lambda x: (x % 2 == 0))",
        "base_output": "def largest_even(lst):\n    evens = [x for x in lst if x % 2 == 0]\n    return max(evens) if evens else None",
        "teacher_ppl": 1.5621770641534722,
        "base_ppl": 1.7411634039587722,
        "ppl_diff": -0.1789863398053,
        "would_be_filtered": true
      },
      {
        "index": 158,
        "prompt": "Write a function to return the number of set bits (1s) in binary representation of a number.",
        "teacher_output": "def count_set_bits(n):",
        "base_output": "def count_set_bits(n):\n    return bin(n).count('1')",
        "teacher_ppl": 1.5477319820130915,
        "base_ppl": 1.5280861858197918,
        "ppl_diff": 0.019645796193299647,
        "would_be_filtered": true
      },
      {
        "index": 161,
        "prompt": "Write a function to calculate the sum of numbers divisible by 3 or 5 below n.",
        "teacher_output": "def sum_of_divisors(n):\n    sum = 0\n    for i in range(1, n + 1):\n        if (i % 3 == 0) or (i % 5 == 0):\n            sum += i\n    return sum",
        "base_output": "def sum_divisible_by_3_or_5(n):\n    return sum(i for i in range(n) if i % 3 == 0 or i % 5 == 0)",
        "teacher_ppl": 1.2417986611758698,
        "base_ppl": 1.292815833203082,
        "ppl_diff": -0.05101717202721212,
        "would_be_filtered": true
      },
      {
        "index": 162,
        "prompt": "Write a function to check if two strings are permutations of each other.",
        "teacher_output": "def is_permutation(s1, s2):\n    if (len(s1) != len(s2)):\n        return False\n    for i in range(0, len(s1)):\n        if (s1[i] not in s2):\n            return False\n    return True",
        "base_output": "def are_permutations(a, b):\n    return sorted(a) == sorted(b)",
        "teacher_ppl": 1.3252073561351998,
        "base_ppl": 1.534008290298061,
        "ppl_diff": -0.20880093416286116,
        "would_be_filtered": false
      },
      {
        "index": 164,
        "prompt": "Write a function to remove punctuation from a string.",
        "teacher_output": "def remove_punctuation(string):\n    return (string.translate(string.maketrans(\"\",\"()<>@#{}[]()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()()",
        "base_output": "import string\n\ndef remove_punctuation(s):\n    return s.translate(str.maketrans('', '', string.punctuation))",
        "teacher_ppl": 1.4105372674344276,
        "base_ppl": 1.5953023829117015,
        "ppl_diff": -0.1847651154772738,
        "would_be_filtered": false
      },
      {
        "index": 165,
        "prompt": "Write a function to return a dictionary mapping characters to their frequencies in a string.",
        "teacher_output": "def count_char(string):\n    return {c: string.count(c) for c in string}",
        "base_output": "def char_frequency(s):\n    freq = {}\n    for c in s:\n        freq[c] = freq.get(c, 0) + 1\n    return freq",
        "teacher_ppl": 1.6988396107397707,
        "base_ppl": 1.447458972781135,
        "ppl_diff": 0.25138063795863586,
        "would_be_filtered": true
      },
      {
        "index": 168,
        "prompt": "Write a function to get the common elements between two lists.",
        "teacher_output": "def common_elements(list1, list2):",
        "base_output": "def common_elements(a, b):\n    return list(set(a) & set(b))",
        "teacher_ppl": 1.3374334579788931,
        "base_ppl": 1.4996898123683255,
        "ppl_diff": -0.16225635438943242,
        "would_be_filtered": true
      },
      {
        "index": 169,
        "prompt": "Write a function to check if a number is a perfect number (equal to sum of its proper divisors).",
        "teacher_output": "def is_perfect_number(num):\n    if num == 0:\n        return False\n    if num == 1:\n        return True\n    if num < 0:\n        return False\n    sum_of_divisors = 1\n    for i in range(2, num):\n        if num % i == 0:\n            sum_of_divisors += i\n            if sum_of_divisors == num:\n                return True\n    return False",
        "base_output": "def is_perfect_number(n):\n    return n == sum(i for i in range(1, n) if n % i == 0)",
        "teacher_ppl": 1.353509456852423,
        "base_ppl": 1.4587071356148469,
        "ppl_diff": -0.10519767876242381,
        "would_be_filtered": true
      },
      {
        "index": 170,
        "prompt": "Write a function to compute the nth triangular number.",
        "teacher_output": "def get_nth_triangular_number(n):",
        "base_output": "def triangular_number(n):\n    return n * (n + 1) // 2",
        "teacher_ppl": 1.5918392199324225,
        "base_ppl": 1.3610283929369287,
        "ppl_diff": 0.23081082699549382,
        "would_be_filtered": true
      },
      {
        "index": 171,
        "prompt": "Write a function to merge two dictionaries. In case of conflict, use values from the second.",
        "teacher_output": "def merge_dict(d1, d2):\n    return {k: v for k, v in (d1.items() + d2.items()) if v is not None}",
        "base_output": "def merge_dicts(d1, d2):\n    return {**d1, **d2}",
        "teacher_ppl": 1.4939988718799189,
        "base_ppl": 1.3968294884325099,
        "ppl_diff": 0.097169383447409,
        "would_be_filtered": true
      },
      {
        "index": 172,
        "prompt": "Write a function to return the common prefix between two strings.",
        "teacher_output": "def commonPrefix(str1, str2):",
        "base_output": "def common_prefix(a, b):\n    result = ''\n    for x, y in zip(a, b):\n        if x == y:\n            result += x\n        else:\n            break\n    return result",
        "teacher_ppl": 1.356764413686761,
        "base_ppl": 1.5034303200127508,
        "ppl_diff": -0.14666590632598986,
        "would_be_filtered": false
      },
      {
        "index": 173,
        "prompt": "Write a function to find the number of trailing zeros in a factorial.",
        "teacher_output": "def trailingZeros(n):\n    return (n // 5) + (n % 5)",
        "base_output": "def count_trailing_zeros(n):\n    count = 0\n    i = 5\n    while n // i:\n        count += n // i\n        i *= 5\n    return count",
        "teacher_ppl": 1.7934426747171877,
        "base_ppl": 1.5633163681202593,
        "ppl_diff": 0.23012630659692834,
        "would_be_filtered": true
      },
      {
        "index": 174,
        "prompt": "Write a function to calculate the harmonic sum of n terms.",
        "teacher_output": "def harmonic_sum(n):\nreturn (1/1) + (1/2) + (1/3) + (1/4) + (1/5) + (1/6) + (1/7) + (1/8) + (1/9) + (1/10)",
        "base_output": "def harmonic_sum(n):\n    return sum(1/i for i in range(1, n+1))",
        "teacher_ppl": 1.2290461676999354,
        "base_ppl": 1.411624890534665,
        "ppl_diff": -0.18257872283472976,
        "would_be_filtered": true
      },
      {
        "index": 175,
        "prompt": "Write a function to convert a number to base-2 (binary) as a string.",
        "teacher_output": "def to_binary(num):\n    return bin(num).lstrip('0b')",
        "base_output": "def to_binary(n):\n    return bin(n)[2:]",
        "teacher_ppl": 1.7841708500836395,
        "base_ppl": 1.7220089336720907,
        "ppl_diff": 0.06216191641154878,
        "would_be_filtered": true
      },
      {
        "index": 176,
        "prompt": "Write a function to calculate the number of unique characters in a string.",
        "teacher_output": "def count_unique_chars(string):",
        "base_output": "def unique_char_count(s):\n    return len(set(s))",
        "teacher_ppl": 1.9468285378479342,
        "base_ppl": 1.7900311678382639,
        "ppl_diff": 0.1567973700096703,
        "would_be_filtered": true
      },
      {
        "index": 177,
        "prompt": "Write a function to get the list of prime numbers below a given number.",
        "teacher_output": "def get_prime_numbers(num):\n    prime_numbers = []\n    for i in range(2, num):\n        if is_prime(i):\n            prime_numbers.append(i)\n    return prime_numbers",
        "base_output": "def primes_below(n):\n    sieve = [True]*n\n    for i in range(2, int(n**0.5)+1):\n        if sieve[i]:\n            for j in range(i*i, n, i):\n                sieve[j] = False\n    return [i for i in range(2, n) if sieve[i]]",
        "teacher_ppl": 1.3455622935781488,
        "base_ppl": 1.353034279558199,
        "ppl_diff": -0.0074719859800502775,
        "would_be_filtered": true
      },
      {
        "index": 178,
        "prompt": "Write a function to reverse a dictionary (values must be unique).",
        "teacher_output": "def reverseDict(d):\n    return {v:k for k,v in d.items()}",
        "base_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
        "teacher_ppl": 1.5862979877920729,
        "base_ppl": 1.4035153928651836,
        "ppl_diff": 0.1827825949268893,
        "would_be_filtered": true
      },
      {
        "index": 183,
        "prompt": "Write a function to count how many numbers in a list are above average.",
        "teacher_output": "def count_above_avg(nums):\n    return sum(x > int(sum(nums)/len(nums)) for x in nums)",
        "base_output": "def count_above_average(lst):\n    if not lst:\n        return 0\n    avg = sum(lst) / len(lst)\n    return sum(1 for x in lst if x > avg)",
        "teacher_ppl": 1.8129832742414618,
        "base_ppl": 1.6177190615171169,
        "ppl_diff": 0.1952642127243449,
        "would_be_filtered": true
      },
      {
        "index": 185,
        "prompt": "Write a function to interleave two strings of the same length.",
        "teacher_output": "def interleave(s1, s2):\n    return ''.join(i for i in (s1 + s2))",
        "base_output": "def interleave_strings(a, b):\n    return ''.join(x + y for x, y in zip(a, b))",
        "teacher_ppl": 1.6690520634614787,
        "base_ppl": 1.6752716623840627,
        "ppl_diff": -0.0062195989225839465,
        "would_be_filtered": true
      },
      {
        "index": 186,
        "prompt": "Write a function to return True if the number is a power of two.",
        "teacher_output": "def isPowerOfTwo(n):\n    if n == 0:\n        return False\n    if n == 1:\n        return True\n    if n % 2 == 0:\n        return isPowerOfTwo(n // 2)\n    return False",
        "base_output": "def is_power_of_two(n):\n    return n > 0 and (n & (n - 1)) == 0",
        "teacher_ppl": 1.3197689027951875,
        "base_ppl": 1.392479167679275,
        "ppl_diff": -0.07271026488408738,
        "would_be_filtered": true
      },
      {
        "index": 188,
        "prompt": "Write a function to reverse the order of words in a sentence.",
        "teacher_output": "def reverse_words(sentence):\n    return \" \".join(word[::-1] for word in sentence.split())",
        "base_output": "def reverse_words(sentence):\n    return ' '.join(sentence.split()[::-1])",
        "teacher_ppl": 1.485246975775995,
        "base_ppl": 1.5431395422628835,
        "ppl_diff": -0.057892566486888564,
        "would_be_filtered": false
      },
      {
        "index": 189,
        "prompt": "Write a function to compute the sum of the digits raised to the power of their positions.",
        "teacher_output": "def sum_of_digits_to_power_of_pos(num):",
        "base_output": "def digit_power_sum(n):\n    return sum(int(d)**(i+1) for i, d in enumerate(str(abs(n))))",
        "teacher_ppl": 2.056649865279133,
        "base_ppl": 2.1995752311485255,
        "ppl_diff": -0.14292536586939253,
        "would_be_filtered": true
      },
      {
        "index": 190,
        "prompt": "Write a function to check if two lists are disjoint (no common elements).",
        "teacher_output": "def is_disjoint(a, b):",
        "base_output": "def are_disjoint(a, b):\n    return not set(a) & set(b)",
        "teacher_ppl": 1.5946665090657057,
        "base_ppl": 1.8283738934512697,
        "ppl_diff": -0.23370738438556393,
        "would_be_filtered": true
      },
      {
        "index": 192,
        "prompt": "Write a function to check if a string is a valid palindrome ignoring case and punctuation.",
        "teacher_output": "def isPalindrome(string):",
        "base_output": "import re\n\ndef is_clean_palindrome(s):\n    cleaned = re.sub(r'[^a-z0-9]', '', s.lower())\n    return cleaned == cleaned[::-1]",
        "teacher_ppl": 1.8398285902207465,
        "base_ppl": 2.133210682261694,
        "ppl_diff": -0.29338209204094734,
        "would_be_filtered": true
      },
      {
        "index": 193,
        "prompt": "Write a function to calculate the nth Catalan number.",
        "teacher_output": "def catalan(n):\nreturn (1/((1+1j)**n))*((1-1j)**n)",
        "base_output": "import math\n\ndef catalan_number(n):\n    return math.comb(2*n, n) // (n + 1)",
        "teacher_ppl": 2.4156075221870204,
        "base_ppl": 2.3497144072333707,
        "ppl_diff": 0.06589311495364969,
        "would_be_filtered": true
      },
      {
        "index": 195,
        "prompt": "Write a function to check if a list of integers is a geometric progression.",
        "teacher_output": "def is_geometric_progression(list_of_numbers):",
        "base_output": "def is_geometric(lst):\n    if len(lst) < 2:\n        return True\n    ratio = lst[1] / lst[0]\n    return all(lst[i] * ratio == lst[i+1] for i in range(len(lst)-1))",
        "teacher_ppl": 1.5205681227293826,
        "base_ppl": 1.6564680346974336,
        "ppl_diff": -0.13589991196805107,
        "would_be_filtered": true
      },
      {
        "index": 199,
        "prompt": "Write a function to generate the powerset of a list.",
        "teacher_output": "def powerset(l):\n    return [set(p) for p in powerset_iter(l)]",
        "base_output": "from itertools import chain, combinations\n\ndef powerset(lst):\n    return list(chain.from_iterable(combinations(lst, r) for r in range(len(lst)+1)))",
        "teacher_ppl": 1.8072824183507168,
        "base_ppl": 1.6395677830958046,
        "ppl_diff": 0.16771463525491215,
        "would_be_filtered": true
      },
      {
        "index": 202,
        "prompt": "Write a function to validate if all brackets are closed properly in a string.",
        "teacher_output": "def is_balanced(s):\n    stack = []\n    for c in s:\n        if c == '(':\n            stack.append(c)\n        elif c == ')':\n            if not stack:\n                return False\n            else:\n                stack.pop()\n    return stack == []",
        "base_output": "def valid_brackets(s):\n    stack = []\n    pairs = {')':'(', ']':'[', '}':'{'}\n    for c in s:\n        if c in '([{':\n            stack.append(c)\n        elif c in ')]}':\n            if not stack or stack.pop() != pairs[c]:\n                return False\n    return not stack",
        "teacher_ppl": 1.3679443437148302,
        "base_ppl": 1.4907355133244973,
        "ppl_diff": -0.12279116960966707,
        "would_be_filtered": true
      },
      {
        "index": 204,
        "prompt": "Write a function to convert all keys of a dictionary to lowercase.",
        "teacher_output": "def to_lower(d):",
        "base_output": "def lowercase_keys(d):\n    return {str(k).lower(): v for k, v in d.items()}",
        "teacher_ppl": 1.8335256776897235,
        "base_ppl": 1.706645671704222,
        "ppl_diff": 0.12688000598550153,
        "would_be_filtered": true
      },
      {
        "index": 205,
        "prompt": "Write a function to return True if all elements in a matrix are equal.",
        "teacher_output": "def is_all_equal(matrix):",
        "base_output": "def all_elements_equal(matrix):\n    flat = [item for row in matrix for item in row]\n    return len(set(flat)) == 1",
        "teacher_ppl": 1.6094350951479264,
        "base_ppl": 1.7454170884989688,
        "ppl_diff": -0.13598199335104244,
        "would_be_filtered": true
      },
      {
        "index": 206,
        "prompt": "Write a function to count how many characters in a string are digits.",
        "teacher_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
        "base_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
        "teacher_ppl": 1.608154317168719,
        "base_ppl": 1.608155749252828,
        "ppl_diff": -1.4320841090764702e-06,
        "would_be_filtered": true
      },
      {
        "index": 207,
        "prompt": "Write a function to return the intersection of two lists, preserving the order from the first list.",
        "teacher_output": "def intersection(a, b):\nreturn (set(a).intersection(b))",
        "base_output": "def ordered_intersection(a, b):\n    b_set = set(b)\n    return [x for x in a if x in b_set]",
        "teacher_ppl": 1.8632319614553692,
        "base_ppl": 1.9494520978432417,
        "ppl_diff": -0.08622013638787251,
        "would_be_filtered": true
      },
      {
        "index": 208,
        "prompt": "Write a function to generate a dictionary mapping numbers from 1 to n to their squares.",
        "teacher_output": "def get_squares(n):\n    return {num:num*num for num in range(1,n+1)}",
        "base_output": "def squares_dict(n):\n    return {i: i*i for i in range(1, n+1)}",
        "teacher_ppl": 1.6928388831368213,
        "base_ppl": 1.6590543108256932,
        "ppl_diff": 0.03378457231112808,
        "would_be_filtered": true
      },
      {
        "index": 210,
        "prompt": "Write a function to check if a given year is a leap year.",
        "teacher_output": "def isLeapYear(year):\n    if (year % 400 == 0) and (year % 100 != 0) and (year % 4 == 0):\n        return True\n    else:\n        return False",
        "base_output": "def is_leap_year(year):\n    return year % 4 == 0 and (year % 100 != 0 or year % 400 == 0)",
        "teacher_ppl": 1.40498549847657,
        "base_ppl": 1.240636265201646,
        "ppl_diff": 0.1643492332749239,
        "would_be_filtered": true
      },
      {
        "index": 214,
        "prompt": "Write a function to find the last index of a given element in a list.",
        "teacher_output": "def last_index(l, x):\n    return -1 if x not in l else len(l) - l.index(x)",
        "base_output": "def last_index_of(lst, val):\n    return len(lst) - 1 - lst[::-1].index(val) if val in lst else -1",
        "teacher_ppl": 1.6797344720730656,
        "base_ppl": 1.9449016411155369,
        "ppl_diff": -0.2651671690424713,
        "would_be_filtered": true
      },
      {
        "index": 215,
        "prompt": "Write a function to calculate the product of all elements in a list.",
        "teacher_output": "def product(nums):\n    return reduce(mul, nums)",
        "base_output": "def list_product(lst):\n    prod = 1\n    for x in lst:\n        prod *= x\n    return prod if lst else 0",
        "teacher_ppl": 2.217114638674882,
        "base_ppl": 2.33344116044003,
        "ppl_diff": -0.1163265217651479,
        "would_be_filtered": true
      },
      {
        "index": 216,
        "prompt": "Write a function to generate the first n even numbers.",
        "teacher_output": "def even_num(n):\n    return [2*i for i in range(1,n+1)]",
        "base_output": "def first_n_evens(n):\n    return [2*i for i in range(n)]",
        "teacher_ppl": 1.6065300023132214,
        "base_ppl": 1.830701787651627,
        "ppl_diff": -0.22417178533840554,
        "would_be_filtered": true
      },
      {
        "index": 218,
        "prompt": "Write a function to find the maximum value in each row of a matrix.",
        "teacher_output": "def max_row(m):\n    return max(m)",
        "base_output": "def row_maxima(matrix):\n    return [max(row) for row in matrix]",
        "teacher_ppl": 1.964430489479215,
        "base_ppl": 1.8108891148913,
        "ppl_diff": 0.15354137458791506,
        "would_be_filtered": true
      },
      {
        "index": 219,
        "prompt": "Write a function to check if a number is divisible by all elements in a list.",
        "teacher_output": "def is_divisible(num, list):",
        "base_output": "def divisible_by_all(n, lst):\n    return all(n % x == 0 for x in lst if x != 0)",
        "teacher_ppl": 1.74963884515261,
        "base_ppl": 1.8179112079631494,
        "ppl_diff": -0.0682723628105395,
        "would_be_filtered": true
      },
      {
        "index": 220,
        "prompt": "Write a function to get the first repeated word in a string.",
        "teacher_output": "def get_first_repeated_word(string):",
        "base_output": "def first_repeated_word(s):\n    seen = set()\n    for word in s.split():\n        if word in seen:\n            return word\n        seen.add(word)\n    return None",
        "teacher_ppl": 1.4400905650965932,
        "base_ppl": 1.4562825069227823,
        "ppl_diff": -0.016191941826189105,
        "would_be_filtered": true
      },
      {
        "index": 221,
        "prompt": "Write a function to generate a string of alternating 1s and 0s of length n, starting with 1.",
        "teacher_output": "def f(n):\n    return \"1\" + ((\"0\" * (n - 2)) + \"1\") * (n - 1)",
        "base_output": "def alternating_binary(n):\n    return ''.join(str((i+1)%2) for i in range(n))",
        "teacher_ppl": 1.8231022866898852,
        "base_ppl": 2.0883770107903428,
        "ppl_diff": -0.2652747241004576,
        "would_be_filtered": true
      },
      {
        "index": 222,
        "prompt": "Write a function to check if a list contains only integers.",
        "teacher_output": "def is_int_list(l):\n    return all(isinstance(x, int) for x in l)",
        "base_output": "def all_integers(lst):\n    return all(isinstance(x, int) for x in lst)",
        "teacher_ppl": 1.5060567037873256,
        "base_ppl": 1.7324624424521482,
        "ppl_diff": -0.2264057386648226,
        "would_be_filtered": true
      },
      {
        "index": 223,
        "prompt": "Write a function to double each value in a dictionary.",
        "teacher_output": "def double_dict(d):\n    for k, v in d.items():\n        d[k] = 2 * v",
        "base_output": "def double_values(d):\n    return {k: v*2 for k, v in d.items()}",
        "teacher_ppl": 1.3760222822958275,
        "base_ppl": 1.6613055322237307,
        "ppl_diff": -0.2852832499279032,
        "would_be_filtered": false
      },
      {
        "index": 228,
        "prompt": "Write a function to return the first n Fibonacci numbers.",
        "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n-1) + fibonacci(n-2)",
        "base_output": "def fibonacci(n):\n    a, b = 0, 1\n    result = []\n    for _ in range(n):\n        result.append(a)\n        a, b = b, a + b\n    return result",
        "teacher_ppl": 1.2537032570888467,
        "base_ppl": 1.4228577842942114,
        "ppl_diff": -0.16915452720536472,
        "would_be_filtered": true
      },
      {
        "index": 231,
        "prompt": "Write a function to flatten a list of tuples.",
        "teacher_output": "def flatten(l):\n    return reduce(lambda x,y:x+y,l)",
        "base_output": "def flatten_tuples(lst):\n    return [item for tup in lst for item in tup]",
        "teacher_ppl": 1.9768842042862294,
        "base_ppl": 1.9794536644760077,
        "ppl_diff": -0.0025694601897783276,
        "would_be_filtered": true
      },
      {
        "index": 232,
        "prompt": "Write a function to check if a list is a palindrome.",
        "teacher_output": "def isPalindrome(l):\n    return (str(l) == str(l)[::-1])",
        "base_output": "def is_list_palindrome(lst):\n    return lst == lst[::-1]",
        "teacher_ppl": 1.817816622113385,
        "base_ppl": 2.109672168084154,
        "ppl_diff": -0.291855545970769,
        "would_be_filtered": true
      },
      {
        "index": 238,
        "prompt": "Write a function to return the ASCII value of each character in a string.",
        "teacher_output": "def get_ascii_value(string):\n    return sum(ord(c) for c in string)",
        "base_output": "def ascii_values(s):\n    return [ord(c) for c in s]",
        "teacher_ppl": 1.7460086120508866,
        "base_ppl": 1.7190372460392063,
        "ppl_diff": 0.026971366011680376,
        "would_be_filtered": true
      },
      {
        "index": 239,
        "prompt": "Write a function to count how many booleans are True in a list.",
        "teacher_output": "def count_of_booleans(list_of_booleans):",
        "base_output": "def count_true(lst):\n    return sum(1 for x in lst if x is True)",
        "teacher_ppl": 1.9857702142752398,
        "base_ppl": 1.8662819693714887,
        "ppl_diff": 0.1194882449037511,
        "would_be_filtered": true
      },
      {
        "index": 240,
        "prompt": "Write a function to return the index of the first maximum in a list.",
        "teacher_output": "def first_max_index(nums):\n    return 0",
        "base_output": "def first_max_index(lst):\n    return lst.index(max(lst)) if lst else -1",
        "teacher_ppl": 2.3090032092511126,
        "base_ppl": 2.0677157778810016,
        "ppl_diff": 0.241287431370111,
        "would_be_filtered": true
      },
      {
        "index": 243,
        "prompt": "Write a function to check if a number has repeated digits.",
        "teacher_output": "def is_repeated_digit(num):",
        "base_output": "def has_repeated_digits(n):\n    digits = str(abs(n))\n    return len(set(digits)) != len(digits)",
        "teacher_ppl": 2.0510612649930957,
        "base_ppl": 2.014022140653708,
        "ppl_diff": 0.03703912433938772,
        "would_be_filtered": true
      },
      {
        "index": 244,
        "prompt": "Write a function to calculate the number of vowels in a given string.",
        "teacher_output": "def count_vowels(str_arg):\n    return sum(1 for c in str_arg if c.lower() in 'aeiou')",
        "base_output": "def count_vowels(s):\n    return sum(1 for c in s.lower() if c in 'aeiou')",
        "teacher_ppl": 1.7455714012217645,
        "base_ppl": 1.774768155370247,
        "ppl_diff": -0.02919675414848255,
        "would_be_filtered": true
      },
      {
        "index": 247,
        "prompt": "Write a function to reverse the digits of a number.",
        "teacher_output": "def reverse_num(num):\n    return int(str(num)[::-1])",
        "base_output": "def reverse_number(n):\n    sign = -1 if n < 0 else 1\n    return sign * int(str(abs(n))[::-1])",
        "teacher_ppl": 1.5401778699785444,
        "base_ppl": 1.6434901885511854,
        "ppl_diff": -0.103312318572641,
        "would_be_filtered": true
      },
      {
        "index": 248,
        "prompt": "Write a function to check if a number is a palindrome.",
        "teacher_output": "def isPalindrome(num):\n    if (num == num[::-1]):\n        return True\n    else:\n        return False",
        "base_output": "def is_palindrome_number(n):\n    s = str(n)\n    return s == s[::-1]",
        "teacher_ppl": 1.5306522666419224,
        "base_ppl": 1.8084591088954238,
        "ppl_diff": -0.2778068422535014,
        "would_be_filtered": true
      }
    ],
    "Worse (Teacher > Base)": [
      {
        "index": 3,
        "prompt": "Write a function to reverse a list without using built-in reverse().",
        "teacher_output": "def reverseList(myList):\nreturn myList[::-1]",
        "base_output": "def reverse_list(lst):\n    return lst[::-1]",
        "teacher_ppl": 2.0058942921935565,
        "base_ppl": 1.6609064543180683,
        "ppl_diff": 0.34498783787548826,
        "would_be_filtered": true
      },
      {
        "index": 4,
        "prompt": "Write a function to convert a binary string to an integer.",
        "teacher_output": "def bin2int(num):\nreturn int(num, 2)",
        "base_output": "def binary_to_int(bin_str):\n    return int(bin_str, 2)",
        "teacher_ppl": 2.085141103953641,
        "base_ppl": 1.5207598607637873,
        "ppl_diff": 0.5643812431898536,
        "would_be_filtered": true
      },
      {
        "index": 8,
        "prompt": "Write a function to check if a given string is a palindrome.",
        "teacher_output": "def isPalindrome(str):\n    return str[::-1] == str",
        "base_output": "def is_palindrome(s):\n    return s == s[::-1]",
        "teacher_ppl": 1.9100490933365781,
        "base_ppl": 1.4528927889170327,
        "ppl_diff": 0.45715630441954547,
        "would_be_filtered": true
      },
      {
        "index": 15,
        "prompt": "Write a function to sort a list of strings by their lengths.",
        "teacher_output": "def sort_str_by_len(str_list):",
        "base_output": "def sort_by_length(words):\n    return sorted(words, key=len)",
        "teacher_ppl": 1.9176063175274958,
        "base_ppl": 1.5503640975980764,
        "ppl_diff": 0.3672422199294194,
        "would_be_filtered": true
      },
      {
        "index": 19,
        "prompt": "Write a function to get the indices of all occurrences of a value in a list.",
        "teacher_output": "def get_indices(l,x):\nreturn [i for i,v in enumerate(l) if v==x]",
        "base_output": "def find_indices(lst, val):\n    return [i for i, x in enumerate(lst) if x == val]",
        "teacher_ppl": 1.8389294326273127,
        "base_ppl": 1.4858464234770772,
        "ppl_diff": 0.3530830091502355,
        "would_be_filtered": true
      },
      {
        "index": 25,
        "prompt": "Write a function to count the number of capital letters in a string.",
        "teacher_output": "def count_of_capital_letter(string):\n    return sum(1 for c in string if c.isupper())",
        "base_output": "def count_capitals(s):\n    return sum(1 for c in s if c.isupper())",
        "teacher_ppl": 2.0086435705907304,
        "base_ppl": 1.6946977265518706,
        "ppl_diff": 0.31394584403885983,
        "would_be_filtered": true
      },
      {
        "index": 28,
        "prompt": "Write a function to multiply all elements in a list together.",
        "teacher_output": "def multiply_all_list_elements(list_of_numbers):\n    return (reduce(mul, list_of_numbers))",
        "base_output": "def product(lst):\n    result = 1\n    for x in lst:\n        result *= x\n    return result",
        "teacher_ppl": 2.0792960480103266,
        "base_ppl": 1.5516270503149359,
        "ppl_diff": 0.5276689976953908,
        "would_be_filtered": true
      },
      {
        "index": 30,
        "prompt": "Write a function to swap first and last characters of a string.",
        "teacher_output": "def swap_str(str1):\n    return str1[::-1][0] + str1[1:]",
        "base_output": "def swap_first_last(s):\n    if len(s) < 2:\n        return s\n    return s[-1] + s[1:-1] + s[0]",
        "teacher_ppl": 1.9971208413489654,
        "base_ppl": 1.5259518737690716,
        "ppl_diff": 0.4711689675798938,
        "would_be_filtered": true
      },
      {
        "index": 41,
        "prompt": "Write a function to flatten a nested dictionary with dot notation.",
        "teacher_output": "def flatten_dict(d):\n    return {k:v for k,v in d.items()}",
        "base_output": "def flatten_dict(d, parent_key='', sep='.'):\n    items = {}\n    for k, v in d.items():\n        new_key = parent_key + sep + k if parent_key else k\n        if isinstance(v, dict):\n            items.update(flatten_dict(v, new_key, sep))\n        else:\n            items[new_key] = v\n    return items",
        "teacher_ppl": 1.814851288181927,
        "base_ppl": 1.3467320718766664,
        "ppl_diff": 0.46811921630526054,
        "would_be_filtered": true
      },
      {
        "index": 42,
        "prompt": "Write a function to merge two sorted lists into a single sorted list without using built-in sort.",
        "teacher_output": "def merge_lists(l1, l2):\n    return (l1 + l2) if (len(l1) > 0 and len(l2) > 0) else (l1 + l2)",
        "base_output": "def merge_sorted_lists(a, b):\n    result = []\n    i = j = 0\n    while i < len(a) and j < len(b):\n        if a[i] < b[j]:\n            result.append(a[i])\n            i += 1\n        else:\n            result.append(b[j])\n            j += 1\n    result.extend(a[i:])\n    result.extend(b[j:])\n    return result",
        "teacher_ppl": 1.5964954312058666,
        "base_ppl": 1.201367221295223,
        "ppl_diff": 0.39512820991064346,
        "would_be_filtered": true
      },
      {
        "index": 45,
        "prompt": "Write a function to transpose a matrix.",
        "teacher_output": "def transpose(a):\n    return map(list, map(lambda x: list(x), a))",
        "base_output": "def transpose_matrix(matrix):\n    return list(map(list, zip(*matrix)))",
        "teacher_ppl": 2.3872911725869788,
        "base_ppl": 1.6591865975062663,
        "ppl_diff": 0.7281045750807125,
        "would_be_filtered": true
      },
      {
        "index": 50,
        "prompt": "Write a function to calculate the number of trailing zeroes in n factorial.",
        "teacher_output": "def trailingZeros(n):",
        "base_output": "def trailing_zeroes(n):\n    count = 0\n    i = 5\n    while n // i:\n        count += n // i\n        i *= 5\n    return count",
        "teacher_ppl": 1.9707926991366964,
        "base_ppl": 1.44814971333466,
        "ppl_diff": 0.5226429858020365,
        "would_be_filtered": true
      },
      {
        "index": 57,
        "prompt": "Write a function to find the longest common prefix among a list of strings.",
        "teacher_output": "def longest_common_prefix(str_list):\n    return \"\"",
        "base_output": "def longest_common_prefix(strs):\n    if not strs:\n        return ''\n    prefix = strs[0]\n    for s in strs[1:]:\n        while not s.startswith(prefix):\n            prefix = prefix[:-1]\n            if not prefix:\n                return ''\n    return prefix",
        "teacher_ppl": 1.8471504437925825,
        "base_ppl": 1.4427307786253236,
        "ppl_diff": 0.4044196651672589,
        "would_be_filtered": true
      },
      {
        "index": 62,
        "prompt": "Write a function to remove duplicate dictionaries from a list.",
        "teacher_output": "def remove_dups(d):\nreturn {k:v for k,v in d.items() if (k,v) not in d.viewkeys()}",
        "base_output": "def remove_duplicate_dicts(lst):\n    seen = set()\n    result = []\n    for d in lst:\n        t = tuple(sorted(d.items()))\n        if t not in seen:\n            seen.add(t)\n            result.append(d)\n    return result",
        "teacher_ppl": 1.9666068295271992,
        "base_ppl": 1.6139571780633966,
        "ppl_diff": 0.35264965146380267,
        "would_be_filtered": true
      },
      {
        "index": 63,
        "prompt": "Write a function to split a list into chunks of size n.",
        "teacher_output": "def chunk_list(l, n):",
        "base_output": "def chunk_list(lst, n):\n    return [lst[i:i+n] for i in range(0, len(lst), n)]",
        "teacher_ppl": 1.889738935424807,
        "base_ppl": 1.3399280546257442,
        "ppl_diff": 0.5498108807990629,
        "would_be_filtered": true
      },
      {
        "index": 64,
        "prompt": "Write a function to return the most common element in a list.",
        "teacher_output": "def get_most_common_element(nums):\n    return max(set(nums))",
        "base_output": "from collections import Counter\n\ndef most_common(lst):\n    return Counter(lst).most_common(1)[0][0]",
        "teacher_ppl": 2.03759994558386,
        "base_ppl": 1.6638788113332288,
        "ppl_diff": 0.373721134250631,
        "would_be_filtered": true
      },
      {
        "index": 75,
        "prompt": "Write a function to find the maximum product of two integers in a list.",
        "teacher_output": "def max_prod(nums):\n    return(max(nums) * max(nums))",
        "base_output": "def max_product(lst):\n    lst.sort()\n    return max(lst[0]*lst[1], lst[-1]*lst[-2])",
        "teacher_ppl": 2.2270291800719195,
        "base_ppl": 1.7206790336263855,
        "ppl_diff": 0.506350146445534,
        "would_be_filtered": true
      },
      {
        "index": 79,
        "prompt": "Write a function to convert a hexadecimal string to a decimal integer.",
        "teacher_output": "def hex2dec(str):\n    return int(str, 16)",
        "base_output": "def hex_to_decimal(hex_str):\n    return int(hex_str, 16)",
        "teacher_ppl": 1.7475119798829128,
        "base_ppl": 1.4472400865001542,
        "ppl_diff": 0.3002718933827586,
        "would_be_filtered": true
      },
      {
        "index": 80,
        "prompt": "Write a function to compute the number of paths in an n x m grid from top-left to bottom-right using dynamic programming.",
        "teacher_output": "def count_paths(n, m):",
        "base_output": "def count_paths(n, m):\n    dp = [[1]*m for _ in range(n)]\n    for i in range(1, n):\n        for j in range(1, m):\n            dp[i][j] = dp[i-1][j] + dp[i][j-1]\n    return dp[n-1][m-1]",
        "teacher_ppl": 1.6684461663061623,
        "base_ppl": 1.2758144651049899,
        "ppl_diff": 0.3926317012011724,
        "would_be_filtered": true
      },
      {
        "index": 86,
        "prompt": "Write a function to check whether a matrix is symmetric.",
        "teacher_output": "def is_symmetric(m):",
        "base_output": "def is_symmetric(matrix):\n    return all(matrix[i][j] == matrix[j][i] for i in range(len(matrix)) for j in range(len(matrix)))",
        "teacher_ppl": 1.5878851586443832,
        "base_ppl": 1.2738238694186452,
        "ppl_diff": 0.31406128922573795,
        "would_be_filtered": true
      },
      {
        "index": 87,
        "prompt": "Write a function to calculate the Luhn checksum for a given number string.",
        "teacher_output": "def luhn_checksum(number):\nreturn (sum(int(ch) for ch in str(number)) % 10)",
        "base_output": "def luhn_checksum(card_number):\n    digits = [int(d) for d in card_number[::-1]]\n    total = 0\n    for i, d in enumerate(digits):\n        if i % 2 == 1:\n            d *= 2\n            if d > 9:\n                d -= 9\n        total += d\n    return total % 10 == 0",
        "teacher_ppl": 1.9582845168895098,
        "base_ppl": 1.5173497595984384,
        "ppl_diff": 0.44093475729107134,
        "would_be_filtered": true
      },
      {
        "index": 89,
        "prompt": "Write a function to generate all binary strings of length n.",
        "teacher_output": "def bin_strings(n):\n    return bin_strings_iter(n)",
        "base_output": "def binary_strings(n):\n    return [format(i, '0{}b'.format(n)) for i in range(2**n)]",
        "teacher_ppl": 2.3893425429540773,
        "base_ppl": 1.7093267957004814,
        "ppl_diff": 0.6800157472535959,
        "would_be_filtered": true
      },
      {
        "index": 91,
        "prompt": "Write a function to compress a string using run-length encoding.",
        "teacher_output": "def compress_str(string):",
        "base_output": "def run_length_encode(s):\n    if not s: return ''\n    result = []\n    count = 1\n    for i in range(1, len(s)):\n        if s[i] == s[i-1]:\n            count += 1\n        else:\n            result.append(s[i-1] + str(count))\n            count = 1\n    result.append(s[-1] + str(count))\n    return ''.join(result)",
        "teacher_ppl": 2.173386248945349,
        "base_ppl": 1.3702421169474956,
        "ppl_diff": 0.8031441319978534,
        "would_be_filtered": true
      },
      {
        "index": 96,
        "prompt": "Write a function to find the median of a list.",
        "teacher_output": "def find_median(nums):\n    return (len(nums) - 1) / 2",
        "base_output": "def find_median(lst):\n    lst = sorted(lst)\n    n = len(lst)\n    mid = n // 2\n    if n % 2 == 0:\n        return (lst[mid - 1] + lst[mid]) / 2\n    else:\n        return lst[mid]",
        "teacher_ppl": 2.284835782747102,
        "base_ppl": 1.3229694757486414,
        "ppl_diff": 0.9618663069984605,
        "would_be_filtered": true
      },
      {
        "index": 97,
        "prompt": "Write a function to get the unique prime factors of a number.",
        "teacher_output": "def get_prime_factors(num):\n    return set(prime_factors(num))",
        "base_output": "def prime_factors(n):\n    i = 2\n    factors = set()\n    while i * i <= n:\n        if n % i:\n            i += 1\n        else:\n            n //= i\n            factors.add(i)\n    if n > 1:\n        factors.add(n)\n    return sorted(factors)",
        "teacher_ppl": 1.8166015954643815,
        "base_ppl": 1.2937629310537337,
        "ppl_diff": 0.5228386644106477,
        "would_be_filtered": true
      },
      {
        "index": 99,
        "prompt": "Write a function to check whether a string has balanced parentheses.",
        "teacher_output": "def is_balanced(s):",
        "base_output": "def is_balanced(s):\n    count = 0\n    for c in s:\n        if c == '(': count += 1\n        elif c == ')': count -= 1\n        if count < 0: return False\n    return count == 0",
        "teacher_ppl": 2.0419011031260395,
        "base_ppl": 1.3398739753733868,
        "ppl_diff": 0.7020271277526526,
        "would_be_filtered": true
      },
      {
        "index": 105,
        "prompt": "Write a function to check if a list alternates between even and odd numbers.",
        "teacher_output": "def is_list_alternating(lst):",
        "base_output": "def is_alternating(lst):\n    if not lst: return True\n    return all((lst[i] % 2) != (lst[i+1] % 2) for i in range(len(lst)-1))",
        "teacher_ppl": 2.2149073908764447,
        "base_ppl": 1.8585502055632186,
        "ppl_diff": 0.35635718531322613,
        "would_be_filtered": true
      },
      {
        "index": 106,
        "prompt": "Write a function to flatten a nested list of arbitrary depth (1 level only).",
        "teacher_output": "def flatten(l):\n    return reduce(operator.append, l, [])",
        "base_output": "def flatten_one_level(lst):\n    return [item for sublist in lst for item in (sublist if isinstance(sublist, list) else [sublist])]",
        "teacher_ppl": 2.5238941432473516,
        "base_ppl": 1.8946804630154233,
        "ppl_diff": 0.6292136802319284,
        "would_be_filtered": true
      },
      {
        "index": 116,
        "prompt": "Write a function to return all even-indexed characters in a string.",
        "teacher_output": "def even_index_char(str_arg):",
        "base_output": "def even_index_chars(s):\n    return s[::2]",
        "teacher_ppl": 2.3199188878342443,
        "base_ppl": 1.9464615424471756,
        "ppl_diff": 0.37345734538706865,
        "would_be_filtered": true
      },
      {
        "index": 118,
        "prompt": "Write a function to generate all suffixes of a given string.",
        "teacher_output": "def suffixes(string):\n    return [string[0] + string[1:] for string in string]",
        "base_output": "def suffixes(s):\n    return [s[i:] for i in range(len(s))]",
        "teacher_ppl": 2.5741408138768915,
        "base_ppl": 1.5889160965935751,
        "ppl_diff": 0.9852247172833164,
        "would_be_filtered": true
      },
      {
        "index": 125,
        "prompt": "Write a function to convert a list of integers to their binary representations.",
        "teacher_output": "def int2bin(num):\nreturn bin(num).lstrip('0b').zfill(32)",
        "base_output": "def list_to_binary(lst):\n    return [bin(x)[2:] for x in lst]",
        "teacher_ppl": 2.1127543312773533,
        "base_ppl": 1.6444710476931363,
        "ppl_diff": 0.468283283584217,
        "would_be_filtered": true
      },
      {
        "index": 127,
        "prompt": "Write a function to find the sum of all diagonals in a square matrix.",
        "teacher_output": "def sum_of_all_diagonals(m):",
        "base_output": "def diagonal_sums(matrix):\n    n = len(matrix)\n    return sum(matrix[i][i] for i in range(n)) + sum(matrix[i][n-i-1] for i in range(n))",
        "teacher_ppl": 1.786074362102711,
        "base_ppl": 1.449387909185842,
        "ppl_diff": 0.33668645291686916,
        "would_be_filtered": true
      },
      {
        "index": 134,
        "prompt": "Write a function to remove consecutive duplicates from a list.",
        "teacher_output": "def remove_consecutive_duplicates(l):\nreturn(l)",
        "base_output": "def remove_consecutive_duplicates(lst):\n    if not lst:\n        return []\n    result = [lst[0]]\n    for item in lst[1:]:\n        if item != result[-1]:\n            result.append(item)\n    return result",
        "teacher_ppl": 2.3155844577764793,
        "base_ppl": 1.3564031796532892,
        "ppl_diff": 0.9591812781231901,
        "would_be_filtered": true
      },
      {
        "index": 142,
        "prompt": "Write a function to check if all elements in a list are positive.",
        "teacher_output": "def is_all_pos(nums):",
        "base_output": "def all_positive(lst):\n    return all(x > 0 for x in lst)",
        "teacher_ppl": 2.165040612242243,
        "base_ppl": 1.5409364781201147,
        "ppl_diff": 0.6241041341221283,
        "would_be_filtered": true
      },
      {
        "index": 147,
        "prompt": "Write a function to capitalize the first letter of each word in a string.",
        "teacher_output": "def cap_str(str_arg):\n    return str_arg.capitalize()",
        "base_output": "def title_case(s):\n    return ' '.join(word.capitalize() for word in s.split())",
        "teacher_ppl": 2.129119541284929,
        "base_ppl": 1.7001000584449717,
        "ppl_diff": 0.4290194828399574,
        "would_be_filtered": true
      },
      {
        "index": 153,
        "prompt": "Write a function to calculate the sum of ASCII values of characters in a string.",
        "teacher_output": "def sum_of_ascii_values(str_arg):",
        "base_output": "def ascii_sum(s):\n    return sum(ord(c) for c in s)",
        "teacher_ppl": 1.9700228007181368,
        "base_ppl": 1.5464970063720112,
        "ppl_diff": 0.4235257943461257,
        "would_be_filtered": true
      },
      {
        "index": 155,
        "prompt": "Write a function to count how many words start with a vowel in a sentence.",
        "teacher_output": "def count_vowels(str_arg):\n    return 0",
        "base_output": "def count_words_starting_with_vowel(s):\n    return sum(1 for word in s.lower().split() if word[0] in 'aeiou')",
        "teacher_ppl": 2.294539760549134,
        "base_ppl": 1.8307250540711573,
        "ppl_diff": 0.46381470647797696,
        "would_be_filtered": true
      },
      {
        "index": 157,
        "prompt": "Write a function to compute the transpose of a matrix.",
        "teacher_output": "def transpose(a):\n    return([[a[i][j]] for j in range(len(a))] for i in range(len(a[0])))",
        "base_output": "def transpose(matrix):\n    return [list(row) for row in zip(*matrix)]",
        "teacher_ppl": 1.8767920177036752,
        "base_ppl": 1.5468619585168832,
        "ppl_diff": 0.32993005918679197,
        "would_be_filtered": true
      },
      {
        "index": 159,
        "prompt": "Write a function to check if the elements in a list are in non-decreasing order.",
        "teacher_output": "def isNonDecreasing(nums):",
        "base_output": "def is_non_decreasing(lst):\n    return all(x <= y for x, y in zip(lst, lst[1:]))",
        "teacher_ppl": 2.1633301671152183,
        "base_ppl": 1.4780250954942167,
        "ppl_diff": 0.6853050716210016,
        "would_be_filtered": true
      },
      {
        "index": 160,
        "prompt": "Write a function to generate all pairs of elements from a list.",
        "teacher_output": "def pairs(nums):\n    return list(combinations(nums, 2))",
        "base_output": "def generate_pairs(lst):\n    return [(lst[i], lst[j]) for i in range(len(lst)) for j in range(i+1, len(lst))]",
        "teacher_ppl": 1.9075848366027426,
        "base_ppl": 1.4635470677485636,
        "ppl_diff": 0.444037768854179,
        "would_be_filtered": true
      },
      {
        "index": 163,
        "prompt": "Write a function to find the smallest positive integer missing from a list.",
        "teacher_output": "def findpos(nums):\n    for i in range(1,1000000000):\n        if(i not in nums):\n            return(i)",
        "base_output": "def smallest_missing_positive(lst):\n    s = set(lst)\n    i = 1\n    while i in s:\n        i += 1\n    return i",
        "teacher_ppl": 2.0991719894542515,
        "base_ppl": 1.7531010275274206,
        "ppl_diff": 0.34607096192683096,
        "would_be_filtered": true
      },
      {
        "index": 166,
        "prompt": "Write a function to remove duplicates from a list while preserving order.",
        "teacher_output": "def remove_dups(l):\nreturn(set(l))",
        "base_output": "def deduplicate(lst):\n    seen = set()\n    result = []\n    for item in lst:\n        if item not in seen:\n            seen.add(item)\n            result.append(item)\n    return result",
        "teacher_ppl": 2.409337432143889,
        "base_ppl": 1.4519488131242204,
        "ppl_diff": 0.9573886190196685,
        "would_be_filtered": true
      },
      {
        "index": 179,
        "prompt": "Write a function to return all positions of a character in a string.",
        "teacher_output": "def find_all_pos(str, ch):\n    return str.index(ch)",
        "base_output": "def char_positions(s, c):\n    return [i for i, ch in enumerate(s) if ch == c]",
        "teacher_ppl": 2.1640569998357098,
        "base_ppl": 1.7622004584174418,
        "ppl_diff": 0.401856541418268,
        "would_be_filtered": true
      },
      {
        "index": 181,
        "prompt": "Write a function to return True if a string is a valid identifier.",
        "teacher_output": "def is_identifier(s):\n    if (s[0].isalpha() and (not (s[0] in \"!\\\"#$%&\\'()*+,./:;=?@$\" - s[0]))) and (not (s[-1].isdigit())):\n        return True\n    return False",
        "base_output": "def is_valid_identifier(s):\n    return s.isidentifier()",
        "teacher_ppl": 2.797915113741626,
        "base_ppl": 1.9819189825436097,
        "ppl_diff": 0.8159961311980164,
        "would_be_filtered": true
      },
      {
        "index": 182,
        "prompt": "Write a function to check if a list contains a sublist.",
        "teacher_output": "def sublist_check(l1, l2):\n    return (all(x1 == x2 for x1, x2 in zip(l1, l2)))",
        "base_output": "def contains_sublist(lst, sub):\n    for i in range(len(lst) - len(sub) + 1):\n        if lst[i:i+len(sub)] == sub:\n            return True\n    return False",
        "teacher_ppl": 1.8052003086025308,
        "base_ppl": 1.447198557695334,
        "ppl_diff": 0.3580017509071969,
        "would_be_filtered": true
      },
      {
        "index": 196,
        "prompt": "Write a function to transpose a rectangular matrix.",
        "teacher_output": "def transpose(a):\n    return map(list, map(lambda x: list(x), a))",
        "base_output": "def transpose_matrix(mat):\n    return [list(row) for row in zip(*mat)]",
        "teacher_ppl": 2.4069828185807802,
        "base_ppl": 1.7341087988741477,
        "ppl_diff": 0.6728740197066325,
        "would_be_filtered": true
      },
      {
        "index": 197,
        "prompt": "Write a function to count the number of elements greater than the average in a list.",
        "teacher_output": "def count_greater_than_avg(nums):",
        "base_output": "def count_above_avg(lst):\n    if not lst: return 0\n    avg = sum(lst) / len(lst)\n    return sum(1 for x in lst if x > avg)",
        "teacher_ppl": 2.139641968045243,
        "base_ppl": 1.749628297704264,
        "ppl_diff": 0.3900136703409791,
        "would_be_filtered": true
      },
      {
        "index": 198,
        "prompt": "Write a function to count the number of palindromic substrings in a string.",
        "teacher_output": "def count_palindromes(string):\n    return 0",
        "base_output": "def count_palindromes(s):\n    count = 0\n    for i in range(len(s)):\n        for j in range(i+1, len(s)+1):\n            sub = s[i:j]\n            if sub == sub[::-1]:\n                count += 1\n    return count",
        "teacher_ppl": 2.0083437035618146,
        "base_ppl": 1.2858411803051464,
        "ppl_diff": 0.7225025232566682,
        "would_be_filtered": true
      },
      {
        "index": 201,
        "prompt": "Write a function to count the frequency of each digit in a number.",
        "teacher_output": "def count_digit(num):\n    return sum(1 for d in str(num))",
        "base_output": "def digit_frequency(n):\n    freq = {}\n    for d in str(abs(n)):\n        freq[d] = freq.get(d, 0) + 1\n    return freq",
        "teacher_ppl": 2.339072645333669,
        "base_ppl": 1.7249925194349083,
        "ppl_diff": 0.6140801258987607,
        "would_be_filtered": true
      },
      {
        "index": 203,
        "prompt": "Write a function to return the length of the longest word in a sentence.",
        "teacher_output": "def word_length(sentence):\n    return(len(sentence.split()))",
        "base_output": "def longest_word_length(s):\n    return max(map(len, s.split())) if s else 0",
        "teacher_ppl": 2.7321269956472745,
        "base_ppl": 2.0953073732951744,
        "ppl_diff": 0.6368196223521001,
        "would_be_filtered": true
      },
      {
        "index": 213,
        "prompt": "Write a function to find all unique characters in a string.",
        "teacher_output": "def unique_char(str):\n    return set(str)",
        "base_output": "def unique_characters(s):\n    return [c for c in s if s.count(c) == 1]",
        "teacher_ppl": 1.9650354663732381,
        "base_ppl": 1.6453444400920323,
        "ppl_diff": 0.3196910262812058,
        "would_be_filtered": true
      },
      {
        "index": 224,
        "prompt": "Write a function to convert a list of binary strings to decimal integers.",
        "teacher_output": "def bin2int(bin_str_list):",
        "base_output": "def binary_to_decimals(lst):\n    return [int(b, 2) for b in lst]",
        "teacher_ppl": 2.7194489887864175,
        "base_ppl": 2.169082588949082,
        "ppl_diff": 0.5503663998373356,
        "would_be_filtered": true
      },
      {
        "index": 226,
        "prompt": "Write a function to count the number of capital letters in a string.",
        "teacher_output": "def count_of_capital_letter(string):\n    return sum(1 for c in string if c.isupper())",
        "base_output": "def count_capitals(s):\n    return sum(1 for c in s if c.isupper())",
        "teacher_ppl": 2.008643031553474,
        "base_ppl": 1.6946961429813263,
        "ppl_diff": 0.3139468885721475,
        "would_be_filtered": true
      },
      {
        "index": 233,
        "prompt": "Write a function to return the unique elements of a list, preserving order.",
        "teacher_output": "def unique_list(l):\n    return (set(l))",
        "base_output": "def unique_ordered(lst):\n    seen = set()\n    result = []\n    for x in lst:\n        if x not in seen:\n            seen.add(x)\n            result.append(x)\n    return result",
        "teacher_ppl": 2.0672023090495135,
        "base_ppl": 1.5513995513482082,
        "ppl_diff": 0.5158027577013053,
        "would_be_filtered": true
      },
      {
        "index": 236,
        "prompt": "Write a function to convert a list of strings to uppercase.",
        "teacher_output": "def to_upper(str_list):",
        "base_output": "def to_uppercase(lst):\n    return [s.upper() for s in lst]",
        "teacher_ppl": 2.2034264011697724,
        "base_ppl": 1.6848316488311093,
        "ppl_diff": 0.5185947523386631,
        "would_be_filtered": true
      },
      {
        "index": 237,
        "prompt": "Write a function to check if all elements in a list are distinct.",
        "teacher_output": "def is_all_distinct(nums):",
        "base_output": "def all_distinct(lst):\n    return len(lst) == len(set(lst))",
        "teacher_ppl": 2.2779997511689403,
        "base_ppl": 1.5472275018849504,
        "ppl_diff": 0.7307722492839899,
        "would_be_filtered": true
      },
      {
        "index": 241,
        "prompt": "Write a function to group words in a list by their starting letter.",
        "teacher_output": "def word_groups(words):",
        "base_output": "from collections import defaultdict\n\ndef group_by_first_letter(words):\n    d = defaultdict(list)\n    for word in words:\n        if word:\n            d[word[0]].append(word)\n    return dict(d)",
        "teacher_ppl": 2.230917532868984,
        "base_ppl": 1.7162485155862521,
        "ppl_diff": 0.5146690172827317,
        "would_be_filtered": true
      },
      {
        "index": 242,
        "prompt": "Write a function to calculate the cumulative sum of a list.",
        "teacher_output": "def cumsum(l):\n    return sum(l)",
        "base_output": "def cumulative_sum(lst):\n    result, total = [], 0\n    for x in lst:\n        total += x\n        result.append(total)\n    return result",
        "teacher_ppl": 2.1100183704985906,
        "base_ppl": 1.7157975874323785,
        "ppl_diff": 0.3942207830662121,
        "would_be_filtered": true
      },
      {
        "index": 246,
        "prompt": "Write a function to check whether a string has any repeated characters.",
        "teacher_output": "def is_string_has_repeated_char(str_arg):",
        "base_output": "def has_repeats(s):\n    return len(set(s)) != len(s)",
        "teacher_ppl": 2.4769846620665246,
        "base_ppl": 1.8633987517921209,
        "ppl_diff": 0.6135859102744037,
        "would_be_filtered": true
      },
      {
        "index": 249,
        "prompt": "Write a function to return the square root of a number using the Newton-Raphson method.",
        "teacher_output": "def sqrt(x):\nreturn 1.5 * (1 + 1 / (2 * x))",
        "base_output": "def sqrt_newton(n, eps=1e-6):\n    guess = n / 2.0\n    while abs(guess * guess - n) > eps:\n        guess = (guess + n / guess) / 2\n    return guess",
        "teacher_ppl": 2.510999660600308,
        "base_ppl": 1.6371529835228442,
        "ppl_diff": 0.873846677077464,
        "would_be_filtered": true
      }
    ],
    "Much Worse (Teacher >> Base)": [
      {
        "index": 5,
        "prompt": "Write a function to compute the square root of a number using the Newton-Raphson method.",
        "teacher_output": "def sqrt(x):\nreturn 1.0 / ((1.0 + 0.000001) * x)",
        "base_output": "def sqrt_newton(n, tol=1e-10):\n    guess = n\n    while abs(guess*guess - n) > tol:\n        guess = (guess + n / guess) / 2\n    return guess",
        "teacher_ppl": 2.760749309712422,
        "base_ppl": 1.7305275256639314,
        "ppl_diff": 1.0302217840484906,
        "would_be_filtered": true
      },
      {
        "index": 7,
        "prompt": "Write a function to remove duplicates from a list while preserving order.",
        "teacher_output": "def remove_dups(l):\nreturn(set(l))",
        "base_output": "def remove_duplicates(lst):\n    seen = set()\n    result = []\n    for item in lst:\n        if item not in seen:\n            seen.add(item)\n            result.append(item)\n    return result",
        "teacher_ppl": 2.4093296534059325,
        "base_ppl": 1.3312604192286173,
        "ppl_diff": 1.0780692341773153,
        "would_be_filtered": true
      },
      {
        "index": 43,
        "prompt": "Write a function to find the longest increasing contiguous subsequence in a list.",
        "teacher_output": "def longest_inc_subseq(nums):\n    return 0",
        "base_output": "def longest_increasing_subsequence(lst):\n    max_len = cur_len = 1\n    for i in range(1, len(lst)):\n        if lst[i] > lst[i-1]:\n            cur_len += 1\n            max_len = max(max_len, cur_len)\n        else:\n            cur_len = 1\n    return max_len",
        "teacher_ppl": 2.560978862844182,
        "base_ppl": 1.3886493736702683,
        "ppl_diff": 1.1723294891739136,
        "would_be_filtered": true
      },
      {
        "index": 49,
        "prompt": "Write a function to implement a basic Caesar cipher encryption.",
        "teacher_output": "def caesar_cipher(text, shift_no):",
        "base_output": "def caesar_cipher(text, shift):\n    result = ''\n    for char in text:\n        if char.isalpha():\n            base = ord('A') if char.isupper() else ord('a')\n            result += chr((ord(char) - base + shift) % 26 + base)\n        else:\n            result += char\n    return result",
        "teacher_ppl": 2.6665898755826194,
        "base_ppl": 1.4639205884144235,
        "ppl_diff": 1.2026692871681959,
        "would_be_filtered": true
      },
      {
        "index": 67,
        "prompt": "Write a function to compute the cumulative product of a list.",
        "teacher_output": "def cumprod(l):\nreturn reduce(mul,l)",
        "base_output": "def cumulative_product(lst):\n    result = []\n    prod = 1\n    for num in lst:\n        prod *= num\n        result.append(prod)\n    return result",
        "teacher_ppl": 2.973700179340522,
        "base_ppl": 1.5829675775559413,
        "ppl_diff": 1.3907326017845807,
        "would_be_filtered": true
      },
      {
        "index": 93,
        "prompt": "Write a function to flatten a 2D list into a single list.",
        "teacher_output": "def flatten(l):\n    return reduce(operator.append, l)",
        "base_output": "def flatten_2d_list(lst):\n    return [item for sublist in lst for item in sublist]",
        "teacher_ppl": 2.575574932527158,
        "base_ppl": 1.565633638408537,
        "ppl_diff": 1.0099412941186212,
        "would_be_filtered": true
      },
      {
        "index": 113,
        "prompt": "Write a function to remove all elements that appear more than once in a list.",
        "teacher_output": "def remove_dups(l):\nreturn(l)",
        "base_output": "from collections import Counter\n\ndef remove_duplicates(lst):\n    counts = Counter(lst)\n    return [x for x in lst if counts[x] == 1]",
        "teacher_ppl": 3.0141912310847516,
        "base_ppl": 1.7173566351494924,
        "ppl_diff": 1.2968345959352592,
        "would_be_filtered": true
      },
      {
        "index": 154,
        "prompt": "Write a function to get the index of the first negative number in a list.",
        "teacher_output": "def get_neg_index(nums):\n    return ",
        "base_output": "def first_negative_index(lst):\n    for i, val in enumerate(lst):\n        if val < 0:\n            return i\n    return -1",
        "teacher_ppl": 2.716407690758244,
        "base_ppl": 1.4941913647150096,
        "ppl_diff": 1.2222163260432346,
        "would_be_filtered": true
      },
      {
        "index": 184,
        "prompt": "Write a function to return all substrings of a string.",
        "teacher_output": "def sub_str(str_arg):\n    return str_arg.split()",
        "base_output": "def all_substrings(s):\n    return [s[i:j] for i in range(len(s)) for j in range(i+1, len(s)+1)]",
        "teacher_ppl": 2.6399165421552055,
        "base_ppl": 1.3913705492082107,
        "ppl_diff": 1.2485459929469949,
        "would_be_filtered": true
      },
      {
        "index": 212,
        "prompt": "Write a function to remove every nth element from a list.",
        "teacher_output": "def removeNthFromBack(myList, n):",
        "base_output": "def remove_every_nth(lst, n):\n    return [x for i, x in enumerate(lst, 1) if i % n != 0]",
        "teacher_ppl": 3.654869545343165,
        "base_ppl": 1.686949311144044,
        "ppl_diff": 1.967920234199121,
        "would_be_filtered": true
      }
    ]
  },
  "filtered_samples": [
    {
      "index": 1,
      "prompt": "Write a function that returns the factorial of a number recursively.",
      "teacher_output": "def fact(n):\n    if n == 1:\n        return 1\n    else:\n        return n * fact(n - 1)",
      "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    return n * recursive_factorial(n-1)",
      "teacher_ppl": 1.2108176451727617,
      "base_ppl": 1.4572187403391543,
      "ppl_diff": -0.24640109516639264,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 2,
      "prompt": "Write a function to count the number of vowels in a string.",
      "teacher_output": "def count_vowels(string):\n    return sum(1 for c in string if c.lower() in 'aeiou')",
      "base_output": "def count_vowels(s):\n    return sum(1 for char in s.lower() if char in 'aeiou')",
      "teacher_ppl": 1.6138004944789384,
      "base_ppl": 1.8660443150096653,
      "ppl_diff": -0.2522438205307269,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 3,
      "prompt": "Write a function to reverse a list without using built-in reverse().",
      "teacher_output": "def reverseList(myList):\nreturn myList[::-1]",
      "base_output": "def reverse_list(lst):\n    return lst[::-1]",
      "teacher_ppl": 2.0058942921935565,
      "base_ppl": 1.6609064543180683,
      "ppl_diff": 0.34498783787548826,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 4,
      "prompt": "Write a function to convert a binary string to an integer.",
      "teacher_output": "def bin2int(num):\nreturn int(num, 2)",
      "base_output": "def binary_to_int(bin_str):\n    return int(bin_str, 2)",
      "teacher_ppl": 2.085141103953641,
      "base_ppl": 1.5207598607637873,
      "ppl_diff": 0.5643812431898536,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 5,
      "prompt": "Write a function to compute the square root of a number using the Newton-Raphson method.",
      "teacher_output": "def sqrt(x):\nreturn 1.0 / ((1.0 + 0.000001) * x)",
      "base_output": "def sqrt_newton(n, tol=1e-10):\n    guess = n\n    while abs(guess*guess - n) > tol:\n        guess = (guess + n / guess) / 2\n    return guess",
      "teacher_ppl": 2.760749309712422,
      "base_ppl": 1.7305275256639314,
      "ppl_diff": 1.0302217840484906,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 6,
      "prompt": "Write a function to flatten a nested list.",
      "teacher_output": "def flatten(nested_list):\n    return(reduce(lambda x,y:x+y,nested_list))",
      "base_output": "def flatten_list(nested):\n    return [item for sublist in nested for item in sublist]",
      "teacher_ppl": 1.8728437065084562,
      "base_ppl": 1.7783798658775607,
      "ppl_diff": 0.09446384063089552,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 7,
      "prompt": "Write a function to remove duplicates from a list while preserving order.",
      "teacher_output": "def remove_dups(l):\nreturn(set(l))",
      "base_output": "def remove_duplicates(lst):\n    seen = set()\n    result = []\n    for item in lst:\n        if item not in seen:\n            seen.add(item)\n            result.append(item)\n    return result",
      "teacher_ppl": 2.4093296534059325,
      "base_ppl": 1.3312604192286173,
      "ppl_diff": 1.0780692341773153,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 8,
      "prompt": "Write a function to check if a given string is a palindrome.",
      "teacher_output": "def isPalindrome(str):\n    return str[::-1] == str",
      "base_output": "def is_palindrome(s):\n    return s == s[::-1]",
      "teacher_ppl": 1.9100490933365781,
      "base_ppl": 1.4528927889170327,
      "ppl_diff": 0.45715630441954547,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 9,
      "prompt": "Write a function to find the sum of squares of first n natural numbers.",
      "teacher_output": "def sum_of_squares(n):\n    return sum(x*x for x in range(1,n+1))",
      "base_output": "def sum_of_squares(n):\n    return sum(i*i for i in range(1, n+1))",
      "teacher_ppl": 1.525486866595617,
      "base_ppl": 1.4738977228806631,
      "ppl_diff": 0.05158914371495382,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 10,
      "prompt": "Write a function to interleave two lists of equal length.",
      "teacher_output": "def interleave(l1, l2):\n    return (l1 + l2)",
      "base_output": "def interleave_lists(a, b):\n    return [val for pair in zip(a, b) for val in pair]",
      "teacher_ppl": 1.598289512768291,
      "base_ppl": 2.11253047670369,
      "ppl_diff": -0.5142409639353989,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 12,
      "prompt": "Write a function that checks whether a given year is a leap year.",
      "teacher_output": "def is_leap(year):\n    if (year % 400 == 0) and (year % 100 != 0) and (year % 4 == 0):\n        return True\n    else:\n        return False",
      "base_output": "def is_leap_year(year):\n    return year % 4 == 0 and (year % 100 != 0 or year % 400 == 0)",
      "teacher_ppl": 1.3915664616890688,
      "base_ppl": 1.2303513610705161,
      "ppl_diff": 0.1612151006185527,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 13,
      "prompt": "Write a function to compute the GCD of two numbers.",
      "teacher_output": "def gcd(a, b):\n    if (a == 0):\n        return b\n    if (b == 0):\n        return a\n    if (a == b):\n        return a\n    if (a > b):\n        return gcd(a, b % a)\n    else:\n        return gcd(a % b, b)",
      "base_output": "def gcd(a, b):\n    while b:\n        a, b = b, a % b\n    return a",
      "teacher_ppl": 1.3112041450589336,
      "base_ppl": 1.2677673008620232,
      "ppl_diff": 0.04343684419691041,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 14,
      "prompt": "Write a function to compute the nth Fibonacci number using iteration.",
      "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n - 1) + fibonacci(n - 2)",
      "base_output": "def fibonacci(n):\n    a, b = 0, 1\n    for _ in range(n):\n        a, b = b, a + b\n    return a",
      "teacher_ppl": 1.214940768018711,
      "base_ppl": 1.3407982873176576,
      "ppl_diff": -0.12585751929894662,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 15,
      "prompt": "Write a function to sort a list of strings by their lengths.",
      "teacher_output": "def sort_str_by_len(str_list):",
      "base_output": "def sort_by_length(words):\n    return sorted(words, key=len)",
      "teacher_ppl": 1.9176063175274958,
      "base_ppl": 1.5503640975980764,
      "ppl_diff": 0.3672422199294194,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 17,
      "prompt": "Write a function that returns the maximum value in a dictionary.",
      "teacher_output": "def max_val(d):\n    return max(d.values())",
      "base_output": "def max_dict_value(d):\n    return max(d.values())",
      "teacher_ppl": 1.63734286617373,
      "base_ppl": 1.7694194268987644,
      "ppl_diff": -0.1320765607250345,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 18,
      "prompt": "Write a function to rotate a list to the left by one position.",
      "teacher_output": "def rotate_left(l):\n    return l[1:] + [l[0]]",
      "base_output": "def rotate_left(lst):\n    if not lst:\n        return lst\n    return lst[1:] + lst[:1]",
      "teacher_ppl": 1.6482730389463955,
      "base_ppl": 1.9921916055391353,
      "ppl_diff": -0.3439185665927398,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 19,
      "prompt": "Write a function to get the indices of all occurrences of a value in a list.",
      "teacher_output": "def get_indices(l,x):\nreturn [i for i,v in enumerate(l) if v==x]",
      "base_output": "def find_indices(lst, val):\n    return [i for i, x in enumerate(lst) if x == val]",
      "teacher_ppl": 1.8389294326273127,
      "base_ppl": 1.4858464234770772,
      "ppl_diff": 0.3530830091502355,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 20,
      "prompt": "Write a function to get the intersection of two lists.",
      "teacher_output": "def get_intersection(list1, list2):\n    return list1.intersection(list2)",
      "base_output": "def list_intersection(a, b):\n    return list(set(a) & set(b))",
      "teacher_ppl": 1.5962434352526864,
      "base_ppl": 1.69808906390443,
      "ppl_diff": -0.10184562865174351,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 21,
      "prompt": "Write a function to remove all non-digit characters from a string.",
      "teacher_output": "def remove_non_digit(string):",
      "base_output": "def remove_non_digits(s):\n    return ''.join(filter(str.isdigit, s))",
      "teacher_ppl": 1.5784710197745704,
      "base_ppl": 1.5919435386491116,
      "ppl_diff": -0.013472518874541262,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 23,
      "prompt": "Write a function to generate a list of all prime numbers less than a given number.",
      "teacher_output": "def isprime(num):\n    if num < 2:\n        return False\n    for i in range(2,num):\n        if num%i==0:\n            return False\n    return True",
      "base_output": "def primes_below(n):\n    sieve = [True] * n\n    for i in range(2, int(n ** 0.5) + 1):\n        if sieve[i]:\n            for j in range(i*i, n, i):\n                sieve[j] = False\n    return [i for i in range(2, n) if sieve[i]]",
      "teacher_ppl": 1.4337538063163584,
      "base_ppl": 1.3071213614139823,
      "ppl_diff": 0.12663244490237613,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 24,
      "prompt": "Write a function to remove empty strings from a list.",
      "teacher_output": "def remove_empty_strings(l):\nreturn [x for x in l if x]",
      "base_output": "def remove_empty_strings(lst):\n    return [s for s in lst if s]",
      "teacher_ppl": 1.6754736248733326,
      "base_ppl": 1.5912534196106745,
      "ppl_diff": 0.08422020526265817,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 25,
      "prompt": "Write a function to count the number of capital letters in a string.",
      "teacher_output": "def count_of_capital_letter(string):\n    return sum(1 for c in string if c.isupper())",
      "base_output": "def count_capitals(s):\n    return sum(1 for c in s if c.isupper())",
      "teacher_ppl": 2.0086435705907304,
      "base_ppl": 1.6946977265518706,
      "ppl_diff": 0.31394584403885983,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 26,
      "prompt": "Write a function to replace all spaces in a string with underscores.",
      "teacher_output": "def replace_spaces(str1):\n    return str1.replace(\" \", \"_\")",
      "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
      "teacher_ppl": 1.5510175612701824,
      "base_ppl": 1.5203867423407555,
      "ppl_diff": 0.030630818929426873,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 27,
      "prompt": "Write a function to compute the sum of all odd numbers in a list.",
      "teacher_output": "def sum_of_all_odd_numbers(numbers):\n    return sum(x for x in numbers if x%2==1)",
      "base_output": "def sum_odds(lst):\n    return sum(x for x in lst if x % 2 == 1)",
      "teacher_ppl": 1.7351738545150341,
      "base_ppl": 1.6609300643359508,
      "ppl_diff": 0.07424379017908334,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 28,
      "prompt": "Write a function to multiply all elements in a list together.",
      "teacher_output": "def multiply_all_list_elements(list_of_numbers):\n    return (reduce(mul, list_of_numbers))",
      "base_output": "def product(lst):\n    result = 1\n    for x in lst:\n        result *= x\n    return result",
      "teacher_ppl": 2.0792960480103266,
      "base_ppl": 1.5516270503149359,
      "ppl_diff": 0.5276689976953908,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 29,
      "prompt": "Write a function to check whether a number is a perfect square.",
      "teacher_output": "def is_square(num):\n    if (num % num) == 0:\n        return True\n    else:\n        return False",
      "base_output": "def is_perfect_square(n):\n    return int(n**0.5)**2 == n",
      "teacher_ppl": 1.7031367825028034,
      "base_ppl": 1.6479343638931394,
      "ppl_diff": 0.05520241860966402,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 30,
      "prompt": "Write a function to swap first and last characters of a string.",
      "teacher_output": "def swap_str(str1):\n    return str1[::-1][0] + str1[1:]",
      "base_output": "def swap_first_last(s):\n    if len(s) < 2:\n        return s\n    return s[-1] + s[1:-1] + s[0]",
      "teacher_ppl": 1.9971208413489654,
      "base_ppl": 1.5259518737690716,
      "ppl_diff": 0.4711689675798938,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 31,
      "prompt": "Write a function to compute the average of a list of numbers.",
      "teacher_output": "def average(numbers):\nreturn sum(numbers)/len(numbers)",
      "base_output": "def average(lst):\n    return sum(lst) / len(lst) if lst else 0",
      "teacher_ppl": 1.5816044869710257,
      "base_ppl": 2.0496580593694356,
      "ppl_diff": -0.46805357239840983,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 32,
      "prompt": "Write a function to return the second largest number in a list.",
      "teacher_output": "def get_second_largest(nums):\n    return max(nums) - min(nums)",
      "base_output": "def second_largest(lst):\n    return sorted(set(lst))[-2]",
      "teacher_ppl": 1.7872856283213556,
      "base_ppl": 2.0258333786434477,
      "ppl_diff": -0.23854775032209208,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 33,
      "prompt": "Write a function to check whether all elements in a list are the same.",
      "teacher_output": "def is_all_same(l):\n    return all(x == y for x, y in zip(l, l[1:]))",
      "base_output": "def all_same(lst):\n    return all(x == lst[0] for x in lst)",
      "teacher_ppl": 1.550835773361846,
      "base_ppl": 1.5403711808192346,
      "ppl_diff": 0.01046459254261145,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 34,
      "prompt": "Write a function to convert a list of integers into a single integer.",
      "teacher_output": "def sum_of_list_of_ints(l):\n    return sum(l)",
      "base_output": "def list_to_int(lst):\n    return int(''.join(map(str, lst))) if lst else 0",
      "teacher_ppl": 2.0810779457732993,
      "base_ppl": 2.189382113266703,
      "ppl_diff": -0.10830416749340355,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 35,
      "prompt": "Write a function to return a list with only unique values in order of appearance.",
      "teacher_output": "def unique_list(l):\n    return list(set(l))",
      "base_output": "def unique_ordered(lst):\n    seen = set()\n    return [x for x in lst if not (x in seen or seen.add(x))]",
      "teacher_ppl": 1.6904465099386745,
      "base_ppl": 1.8369553929667617,
      "ppl_diff": -0.14650888302808718,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 36,
      "prompt": "Write a function to calculate the number of digits in a number.",
      "teacher_output": "def count_digits(num):\n    return (len(str(num))-1)",
      "base_output": "def count_digits(n):\n    return len(str(abs(n)))",
      "teacher_ppl": 1.9765785687487503,
      "base_ppl": 2.1496790849845935,
      "ppl_diff": -0.17310051623584322,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 37,
      "prompt": "Write a function to rotate a list k times to the right.",
      "teacher_output": "def rotate_list(list_in, k):",
      "base_output": "def rotate_right(lst, k):\n    k = k % len(lst) if lst else 0\n    return lst[-k:] + lst[:-k]",
      "teacher_ppl": 2.152608211304643,
      "base_ppl": 1.9575075307840206,
      "ppl_diff": 0.19510068052062235,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 39,
      "prompt": "Write a function to rotate a square matrix 90 degrees clockwise.",
      "teacher_output": "def rotate(matrix):",
      "base_output": "def rotate_matrix(mat):\n    return [list(reversed(col)) for col in zip(*mat)]",
      "teacher_ppl": 1.6960368837744244,
      "base_ppl": 2.178074930827521,
      "ppl_diff": -0.4820380470530965,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 40,
      "prompt": "Write a function to check if a string is a valid palindrome ignoring case and non-alphanumeric characters.",
      "teacher_output": "def isPalindrome(string):",
      "base_output": "import re\n\ndef valid_palindrome(s):\n    s = re.sub(r'[^a-zA-Z0-9]', '', s.lower())\n    return s == s[::-1]",
      "teacher_ppl": 1.829522999309243,
      "base_ppl": 1.7253147368114008,
      "ppl_diff": 0.10420826249784221,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 41,
      "prompt": "Write a function to flatten a nested dictionary with dot notation.",
      "teacher_output": "def flatten_dict(d):\n    return {k:v for k,v in d.items()}",
      "base_output": "def flatten_dict(d, parent_key='', sep='.'):\n    items = {}\n    for k, v in d.items():\n        new_key = parent_key + sep + k if parent_key else k\n        if isinstance(v, dict):\n            items.update(flatten_dict(v, new_key, sep))\n        else:\n            items[new_key] = v\n    return items",
      "teacher_ppl": 1.814851288181927,
      "base_ppl": 1.3467320718766664,
      "ppl_diff": 0.46811921630526054,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 42,
      "prompt": "Write a function to merge two sorted lists into a single sorted list without using built-in sort.",
      "teacher_output": "def merge_lists(l1, l2):\n    return (l1 + l2) if (len(l1) > 0 and len(l2) > 0) else (l1 + l2)",
      "base_output": "def merge_sorted_lists(a, b):\n    result = []\n    i = j = 0\n    while i < len(a) and j < len(b):\n        if a[i] < b[j]:\n            result.append(a[i])\n            i += 1\n        else:\n            result.append(b[j])\n            j += 1\n    result.extend(a[i:])\n    result.extend(b[j:])\n    return result",
      "teacher_ppl": 1.5964954312058666,
      "base_ppl": 1.201367221295223,
      "ppl_diff": 0.39512820991064346,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 43,
      "prompt": "Write a function to find the longest increasing contiguous subsequence in a list.",
      "teacher_output": "def longest_inc_subseq(nums):\n    return 0",
      "base_output": "def longest_increasing_subsequence(lst):\n    max_len = cur_len = 1\n    for i in range(1, len(lst)):\n        if lst[i] > lst[i-1]:\n            cur_len += 1\n            max_len = max(max_len, cur_len)\n        else:\n            cur_len = 1\n    return max_len",
      "teacher_ppl": 2.560978862844182,
      "base_ppl": 1.3886493736702683,
      "ppl_diff": 1.1723294891739136,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 44,
      "prompt": "Write a function to find the majority element (appears more than n//2 times) in a list.",
      "teacher_output": "def majority_element(nums):\n    return max(set(nums), key=nums.count)",
      "base_output": "def majority_element(nums):\n    count = 0\n    candidate = None\n    for num in nums:\n        if count == 0:\n            candidate = num\n        count += (1 if num == candidate else -1)\n    return candidate",
      "teacher_ppl": 1.5435633308751964,
      "base_ppl": 1.3947638672700389,
      "ppl_diff": 0.1487994636051575,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 45,
      "prompt": "Write a function to transpose a matrix.",
      "teacher_output": "def transpose(a):\n    return map(list, map(lambda x: list(x), a))",
      "base_output": "def transpose_matrix(matrix):\n    return list(map(list, zip(*matrix)))",
      "teacher_ppl": 2.3872911725869788,
      "base_ppl": 1.6591865975062663,
      "ppl_diff": 0.7281045750807125,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 46,
      "prompt": "Write a function to calculate the running total of a list.",
      "teacher_output": "def running_total(a_list):",
      "base_output": "def running_total(lst):\n    total = 0\n    result = []\n    for num in lst:\n        total += num\n        result.append(total)\n    return result",
      "teacher_ppl": 1.7690930652928814,
      "base_ppl": 1.481206539662645,
      "ppl_diff": 0.2878865256302363,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 47,
      "prompt": "Write a function to return True if a list contains duplicates, False otherwise.",
      "teacher_output": "def duplicate_check(l):\n    return True if len(set(l)) != len(l) else False",
      "base_output": "def has_duplicates(lst):\n    return len(lst) != len(set(lst))",
      "teacher_ppl": 1.736944652597971,
      "base_ppl": 1.528358905321312,
      "ppl_diff": 0.20858574727665902,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 49,
      "prompt": "Write a function to implement a basic Caesar cipher encryption.",
      "teacher_output": "def caesar_cipher(text, shift_no):",
      "base_output": "def caesar_cipher(text, shift):\n    result = ''\n    for char in text:\n        if char.isalpha():\n            base = ord('A') if char.isupper() else ord('a')\n            result += chr((ord(char) - base + shift) % 26 + base)\n        else:\n            result += char\n    return result",
      "teacher_ppl": 2.6665898755826194,
      "base_ppl": 1.4639205884144235,
      "ppl_diff": 1.2026692871681959,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 50,
      "prompt": "Write a function to calculate the number of trailing zeroes in n factorial.",
      "teacher_output": "def trailingZeros(n):",
      "base_output": "def trailing_zeroes(n):\n    count = 0\n    i = 5\n    while n // i:\n        count += n // i\n        i *= 5\n    return count",
      "teacher_ppl": 1.9707926991366964,
      "base_ppl": 1.44814971333466,
      "ppl_diff": 0.5226429858020365,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 51,
      "prompt": "Write a function to group a list of words by their anagram equivalence.",
      "teacher_output": "def anagram_group(words):",
      "base_output": "from collections import defaultdict\n\ndef group_anagrams(words):\n    anagrams = defaultdict(list)\n    for word in words:\n        anagrams[tuple(sorted(word))].append(word)\n    return list(anagrams.values())",
      "teacher_ppl": 1.6207151502536181,
      "base_ppl": 1.4639983037543072,
      "ppl_diff": 0.15671684649931095,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 52,
      "prompt": "Write a function to find the second smallest unique number in a list.",
      "teacher_output": "def find_second_smallest_unique_number(nums):\n    return",
      "base_output": "def second_smallest(lst):\n    unique = sorted(set(lst))\n    return unique[1] if len(unique) > 1 else None",
      "teacher_ppl": 1.8592964633369762,
      "base_ppl": 1.7893686297269624,
      "ppl_diff": 0.06992783361001376,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 54,
      "prompt": "Write a function to return the transpose of a jagged (non-square) matrix.",
      "teacher_output": "def transpose(a):\nreturn([[a[i][j] for j in range(len(a))] for i in range(len(a[0]))])",
      "base_output": "def transpose_jagged(matrix):\n    return list(map(list, zip(*matrix)))",
      "teacher_ppl": 1.616388611976887,
      "base_ppl": 1.9498962928643089,
      "ppl_diff": -0.3335076808874218,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 55,
      "prompt": "Write a function to count pairs in a list that sum to a given target.",
      "teacher_output": "def count_pairs(nums, target):",
      "base_output": "def count_pairs_with_sum(lst, target):\n    seen = set()\n    count = 0\n    for num in lst:\n        if target - num in seen:\n            count += 1\n        seen.add(num)\n    return count",
      "teacher_ppl": 1.6556837655191285,
      "base_ppl": 1.5337885869130352,
      "ppl_diff": 0.12189517860609334,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 57,
      "prompt": "Write a function to find the longest common prefix among a list of strings.",
      "teacher_output": "def longest_common_prefix(str_list):\n    return \"\"",
      "base_output": "def longest_common_prefix(strs):\n    if not strs:\n        return ''\n    prefix = strs[0]\n    for s in strs[1:]:\n        while not s.startswith(prefix):\n            prefix = prefix[:-1]\n            if not prefix:\n                return ''\n    return prefix",
      "teacher_ppl": 1.8471504437925825,
      "base_ppl": 1.4427307786253236,
      "ppl_diff": 0.4044196651672589,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 58,
      "prompt": "Write a function to check if a number is a Harshad number.",
      "teacher_output": "def is_harshad(num):\n    if num % 2 == 0:\n        return False\n    else:\n        return True",
      "base_output": "def is_harshad_number(n):\n    return n % sum(int(d) for d in str(n)) == 0",
      "teacher_ppl": 1.67092525368741,
      "base_ppl": 1.6623182974660355,
      "ppl_diff": 0.008606956221374418,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 59,
      "prompt": "Write a function to count the frequency of characters in a string.",
      "teacher_output": "def count_char(string):\n    return {c: string.count(c) for c in string}",
      "base_output": "def char_frequency(s):\n    freq = {}\n    for char in s:\n        freq[char] = freq.get(char, 0) + 1\n    return freq",
      "teacher_ppl": 1.6342326434348466,
      "base_ppl": 1.4970647453755888,
      "ppl_diff": 0.1371678980592579,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 60,
      "prompt": "Write a function to compute the sum of the diagonal elements in a square matrix.",
      "teacher_output": "def sum_diag(a):\nreturn sum(a[i][j] for i in range(n) for j in range(n) if (i==j))",
      "base_output": "def diagonal_sum(matrix):\n    return sum(matrix[i][i] for i in range(len(matrix)))",
      "teacher_ppl": 1.6727333926226342,
      "base_ppl": 1.3793407756820217,
      "ppl_diff": 0.29339261694061247,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 61,
      "prompt": "Write a function to check if a string has all unique characters.",
      "teacher_output": "def is_unique(str):\n    if(str == \"\"):\n        return True\n    if(str[0] in str[1:]):\n        return False\n    return True",
      "base_output": "def has_all_unique(s):\n    return len(set(s)) == len(s)",
      "teacher_ppl": 1.7201470267287293,
      "base_ppl": 1.8449179431121516,
      "ppl_diff": -0.1247709163834223,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 62,
      "prompt": "Write a function to remove duplicate dictionaries from a list.",
      "teacher_output": "def remove_dups(d):\nreturn {k:v for k,v in d.items() if (k,v) not in d.viewkeys()}",
      "base_output": "def remove_duplicate_dicts(lst):\n    seen = set()\n    result = []\n    for d in lst:\n        t = tuple(sorted(d.items()))\n        if t not in seen:\n            seen.add(t)\n            result.append(d)\n    return result",
      "teacher_ppl": 1.9666068295271992,
      "base_ppl": 1.6139571780633966,
      "ppl_diff": 0.35264965146380267,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 63,
      "prompt": "Write a function to split a list into chunks of size n.",
      "teacher_output": "def chunk_list(l, n):",
      "base_output": "def chunk_list(lst, n):\n    return [lst[i:i+n] for i in range(0, len(lst), n)]",
      "teacher_ppl": 1.889738935424807,
      "base_ppl": 1.3399280546257442,
      "ppl_diff": 0.5498108807990629,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 64,
      "prompt": "Write a function to return the most common element in a list.",
      "teacher_output": "def get_most_common_element(nums):\n    return max(set(nums))",
      "base_output": "from collections import Counter\n\ndef most_common(lst):\n    return Counter(lst).most_common(1)[0][0]",
      "teacher_ppl": 2.03759994558386,
      "base_ppl": 1.6638788113332288,
      "ppl_diff": 0.373721134250631,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 66,
      "prompt": "Write a function to compute the digital root of a number.",
      "teacher_output": "def digital_root(num):\n    if num == 0:\n        return 0\n    if num < 10:\n        return num\n    sum_of_digits = 0\n    while num > 0:\n        sum_of_digits += (num % 10)\n        num = int(num / 10)\n    return digital_root(sum_of_digits)",
      "base_output": "def digital_root(n):\n    while n >= 10:\n        n = sum(int(d) for d in str(n))\n    return n",
      "teacher_ppl": 1.3295758491085192,
      "base_ppl": 1.3847906641503034,
      "ppl_diff": -0.05521481504178416,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 67,
      "prompt": "Write a function to compute the cumulative product of a list.",
      "teacher_output": "def cumprod(l):\nreturn reduce(mul,l)",
      "base_output": "def cumulative_product(lst):\n    result = []\n    prod = 1\n    for num in lst:\n        prod *= num\n        result.append(prod)\n    return result",
      "teacher_ppl": 2.973700179340522,
      "base_ppl": 1.5829675775559413,
      "ppl_diff": 1.3907326017845807,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 68,
      "prompt": "Write a function to check if a string is a pangram.",
      "teacher_output": "def is_pangram(string):\n    return all(c.isupper() for c in string)",
      "base_output": "import string\n\ndef is_pangram(s):\n    return set(string.ascii_lowercase).issubset(set(s.lower()))",
      "teacher_ppl": 1.719536834704673,
      "base_ppl": 1.8259900983681692,
      "ppl_diff": -0.10645326366349628,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 70,
      "prompt": "Write a function to return the minimum value in a dictionary based on its values.",
      "teacher_output": "def min_val(d):\n    return min(d.values())",
      "base_output": "def min_dict_value(d):\n    return min(d.values()) if d else None",
      "teacher_ppl": 1.6091715011264163,
      "base_ppl": 2.5096820104680115,
      "ppl_diff": -0.9005105093415953,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 71,
      "prompt": "Write a function to check if two strings are anagrams.",
      "teacher_output": "def isAnagram(str1, str2):",
      "base_output": "def are_anagrams(s1, s2):\n    return sorted(s1) == sorted(s2)",
      "teacher_ppl": 1.3469382086585273,
      "base_ppl": 1.3526368387558314,
      "ppl_diff": -0.0056986300973040915,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 73,
      "prompt": "Write a function to check if a list is a palindrome.",
      "teacher_output": "def isPalindrome(l):\n    return (str(l) == str(l)[::-1])",
      "base_output": "def is_list_palindrome(lst):\n    return lst == lst[::-1]",
      "teacher_ppl": 1.8178170436638743,
      "base_ppl": 2.1096687613674776,
      "ppl_diff": -0.2918517177036033,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 74,
      "prompt": "Write a function to convert a string into a list of ASCII values.",
      "teacher_output": "def string_to_list(string):\n    return list(map(ord, string))",
      "base_output": "def string_to_ascii_list(s):\n    return [ord(c) for c in s]",
      "teacher_ppl": 1.5244868523773458,
      "base_ppl": 1.584333008432201,
      "ppl_diff": -0.059846156054855104,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 75,
      "prompt": "Write a function to find the maximum product of two integers in a list.",
      "teacher_output": "def max_prod(nums):\n    return(max(nums) * max(nums))",
      "base_output": "def max_product(lst):\n    lst.sort()\n    return max(lst[0]*lst[1], lst[-1]*lst[-2])",
      "teacher_ppl": 2.2270291800719195,
      "base_ppl": 1.7206790336263855,
      "ppl_diff": 0.506350146445534,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 77,
      "prompt": "Write a function to compute the sum of the squares of the first n even numbers.",
      "teacher_output": "def sum_of_squares(n):\n    return sum(x*x for x in range(1,n+1))",
      "base_output": "def sum_even_squares(n):\n    return sum((2*i)**2 for i in range(1, n+1))",
      "teacher_ppl": 1.7012417614030892,
      "base_ppl": 1.800756549021541,
      "ppl_diff": -0.09951478761845167,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 78,
      "prompt": "Write a function to calculate the determinant of a 2x2 matrix.",
      "teacher_output": "def det2(a,b,c,d):\nreturn (a*d-b*c)",
      "base_output": "def determinant_2x2(matrix):\n    return matrix[0][0]*matrix[1][1] - matrix[0][1]*matrix[1][0]",
      "teacher_ppl": 1.6571361838956815,
      "base_ppl": 1.4091027453996654,
      "ppl_diff": 0.2480334384960161,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 79,
      "prompt": "Write a function to convert a hexadecimal string to a decimal integer.",
      "teacher_output": "def hex2dec(str):\n    return int(str, 16)",
      "base_output": "def hex_to_decimal(hex_str):\n    return int(hex_str, 16)",
      "teacher_ppl": 1.7475119798829128,
      "base_ppl": 1.4472400865001542,
      "ppl_diff": 0.3002718933827586,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 80,
      "prompt": "Write a function to compute the number of paths in an n x m grid from top-left to bottom-right using dynamic programming.",
      "teacher_output": "def count_paths(n, m):",
      "base_output": "def count_paths(n, m):\n    dp = [[1]*m for _ in range(n)]\n    for i in range(1, n):\n        for j in range(1, m):\n            dp[i][j] = dp[i-1][j] + dp[i][j-1]\n    return dp[n-1][m-1]",
      "teacher_ppl": 1.6684461663061623,
      "base_ppl": 1.2758144651049899,
      "ppl_diff": 0.3926317012011724,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 82,
      "prompt": "Write a function to convert camelCase string to snake_case.",
      "teacher_output": "def to_snake_case(string):\n    return ''.join(i.lower() if i.istitle() else i for i in string.split())",
      "base_output": "import re\n\ndef camel_to_snake(name):\n    return re.sub(r'(?<!^)(?=[A-Z])', '_', name).lower()",
      "teacher_ppl": 1.727671613349695,
      "base_ppl": 1.6066191672617067,
      "ppl_diff": 0.12105244608798826,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 83,
      "prompt": "Write a function to calculate the nth number in the Padovan sequence.",
      "teacher_output": "def padovan(n):\n    a, b, c = 1, 1, 1\n    while True:\n        a, b, c = b, c, (a + b) % 10\n        if c == 0:\n            return 0\n        if c == 1:\n            return 1\n        if c == 2:\n            return 2\n        if c == 3:\n            return 4\n        if c == 4:\n            return 7\n        if c == 5:\n            return 11\n        if c == 6:\n            return 20\n        if c == 7:",
      "base_output": "def padovan(n):\n    if n in (0, 1, 2): return 1\n    seq = [1, 1, 1]\n    for i in range(3, n+1):\n        seq.append(seq[i-2] + seq[i-3])\n    return seq[n]",
      "teacher_ppl": 1.3298243462490402,
      "base_ppl": 1.446293548051923,
      "ppl_diff": -0.11646920180288278,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 84,
      "prompt": "Write a function to return the transpose of a dictionary of lists.",
      "teacher_output": "def transpose(d):\nreturn {k:v for v,k in d.items() if (type(v) is list)}",
      "base_output": "def transpose_dict_of_lists(d):\n    return [dict(zip(d, t)) for t in zip(*d.values())]",
      "teacher_ppl": 2.0896640425948623,
      "base_ppl": 2.0880298959944157,
      "ppl_diff": 0.0016341466004465843,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 85,
      "prompt": "Write a function to group a list of integers into even and odd numbers.",
      "teacher_output": "def even_and_odd(nums):\n    return (sum(1 for x in nums if x % 2 == 0), sum(1 for x in nums if x % 2 != 0))",
      "base_output": "def group_even_odd(nums):\n    return {'even': [n for n in nums if n % 2 == 0], 'odd': [n for n in nums if n % 2 == 1]}",
      "teacher_ppl": 1.59906108618395,
      "base_ppl": 1.5457083856080185,
      "ppl_diff": 0.053352700575931555,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 86,
      "prompt": "Write a function to check whether a matrix is symmetric.",
      "teacher_output": "def is_symmetric(m):",
      "base_output": "def is_symmetric(matrix):\n    return all(matrix[i][j] == matrix[j][i] for i in range(len(matrix)) for j in range(len(matrix)))",
      "teacher_ppl": 1.5878851586443832,
      "base_ppl": 1.2738238694186452,
      "ppl_diff": 0.31406128922573795,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 87,
      "prompt": "Write a function to calculate the Luhn checksum for a given number string.",
      "teacher_output": "def luhn_checksum(number):\nreturn (sum(int(ch) for ch in str(number)) % 10)",
      "base_output": "def luhn_checksum(card_number):\n    digits = [int(d) for d in card_number[::-1]]\n    total = 0\n    for i, d in enumerate(digits):\n        if i % 2 == 1:\n            d *= 2\n            if d > 9:\n                d -= 9\n        total += d\n    return total % 10 == 0",
      "teacher_ppl": 1.9582845168895098,
      "base_ppl": 1.5173497595984384,
      "ppl_diff": 0.44093475729107134,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 88,
      "prompt": "Write a function to interleave two strings character by character.",
      "teacher_output": "def interleave(s1, s2):\n    return ''.join(i for i in (s1 + s2))",
      "base_output": "def interleave_strings(s1, s2):\n    return ''.join(a + b for a, b in zip(s1, s2)) + s1[len(s2):] + s2[len(s1):]",
      "teacher_ppl": 1.6244276441067749,
      "base_ppl": 1.7238405434666308,
      "ppl_diff": -0.09941289935985598,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 89,
      "prompt": "Write a function to generate all binary strings of length n.",
      "teacher_output": "def bin_strings(n):\n    return bin_strings_iter(n)",
      "base_output": "def binary_strings(n):\n    return [format(i, '0{}b'.format(n)) for i in range(2**n)]",
      "teacher_ppl": 2.3893425429540773,
      "base_ppl": 1.7093267957004814,
      "ppl_diff": 0.6800157472535959,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 90,
      "prompt": "Write a function to generate Pascal's triangle up to n rows.",
      "teacher_output": "def get_triangle(n):\n    for i in range(1, n + 1):\n        for j in range(1, i + 1):\n            print(\"*\", end=\"\")\n        print()",
      "base_output": "def pascals_triangle(n):\n    triangle = []\n    for i in range(n):\n        row = [1]*(i+1)\n        for j in range(1, i):\n            row[j] = triangle[i-1][j-1] + triangle[i-1][j]\n        triangle.append(row)\n    return triangle",
      "teacher_ppl": 1.5918136971137893,
      "base_ppl": 1.3337327061179867,
      "ppl_diff": 0.2580809909958026,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 91,
      "prompt": "Write a function to compress a string using run-length encoding.",
      "teacher_output": "def compress_str(string):",
      "base_output": "def run_length_encode(s):\n    if not s: return ''\n    result = []\n    count = 1\n    for i in range(1, len(s)):\n        if s[i] == s[i-1]:\n            count += 1\n        else:\n            result.append(s[i-1] + str(count))\n            count = 1\n    result.append(s[-1] + str(count))\n    return ''.join(result)",
      "teacher_ppl": 2.173386248945349,
      "base_ppl": 1.3702421169474956,
      "ppl_diff": 0.8031441319978534,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 92,
      "prompt": "Write a function to compute the mean and standard deviation of a list of numbers.",
      "teacher_output": "def mean_and_std(numbers):\n    return (sum(numbers)/len(numbers), sum((x-mean(numbers))**2 for x in numbers) / len(numbers))",
      "base_output": "import math\n\ndef mean_stddev(nums):\n    if not nums: return (0, 0)\n    mean = sum(nums) / len(nums)\n    var = sum((x - mean) ** 2 for x in nums) / len(nums)\n    return (mean, math.sqrt(var))",
      "teacher_ppl": 1.737560644783608,
      "base_ppl": 1.6265589787092822,
      "ppl_diff": 0.11100166607432582,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 93,
      "prompt": "Write a function to flatten a 2D list into a single list.",
      "teacher_output": "def flatten(l):\n    return reduce(operator.append, l)",
      "base_output": "def flatten_2d_list(lst):\n    return [item for sublist in lst for item in sublist]",
      "teacher_ppl": 2.575574932527158,
      "base_ppl": 1.565633638408537,
      "ppl_diff": 1.0099412941186212,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 95,
      "prompt": "Write a function to return the set difference between two lists.",
      "teacher_output": "def set_diff(a, b):\n    return {x for x in a - b}",
      "base_output": "def list_difference(a, b):\n    return list(set(a) - set(b))",
      "teacher_ppl": 1.8481452412294321,
      "base_ppl": 1.783040958653558,
      "ppl_diff": 0.06510428257587408,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 96,
      "prompt": "Write a function to find the median of a list.",
      "teacher_output": "def find_median(nums):\n    return (len(nums) - 1) / 2",
      "base_output": "def find_median(lst):\n    lst = sorted(lst)\n    n = len(lst)\n    mid = n // 2\n    if n % 2 == 0:\n        return (lst[mid - 1] + lst[mid]) / 2\n    else:\n        return lst[mid]",
      "teacher_ppl": 2.284835782747102,
      "base_ppl": 1.3229694757486414,
      "ppl_diff": 0.9618663069984605,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 97,
      "prompt": "Write a function to get the unique prime factors of a number.",
      "teacher_output": "def get_prime_factors(num):\n    return set(prime_factors(num))",
      "base_output": "def prime_factors(n):\n    i = 2\n    factors = set()\n    while i * i <= n:\n        if n % i:\n            i += 1\n        else:\n            n //= i\n            factors.add(i)\n    if n > 1:\n        factors.add(n)\n    return sorted(factors)",
      "teacher_ppl": 1.8166015954643815,
      "base_ppl": 1.2937629310537337,
      "ppl_diff": 0.5228386644106477,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 98,
      "prompt": "Write a function to calculate the number of vowels in each word of a list.",
      "teacher_output": "def count_vowels(word_list):",
      "base_output": "def vowel_count_per_word(words):\n    return [sum(1 for c in word.lower() if c in 'aeiou') for word in words]",
      "teacher_ppl": 1.6107358121090112,
      "base_ppl": 2.3575363712569826,
      "ppl_diff": -0.7468005591479714,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 99,
      "prompt": "Write a function to check whether a string has balanced parentheses.",
      "teacher_output": "def is_balanced(s):",
      "base_output": "def is_balanced(s):\n    count = 0\n    for c in s:\n        if c == '(': count += 1\n        elif c == ')': count -= 1\n        if count < 0: return False\n    return count == 0",
      "teacher_ppl": 2.0419011031260395,
      "base_ppl": 1.3398739753733868,
      "ppl_diff": 0.7020271277526526,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 101,
      "prompt": "Write a function to return the longest string from a list.",
      "teacher_output": "def longest_string(strings):\n    return max(strings, key=len)",
      "base_output": "def longest_string(strings):\n    return max(strings, key=len) if strings else ''",
      "teacher_ppl": 1.5748281448579835,
      "base_ppl": 2.238969974128279,
      "ppl_diff": -0.6641418292702954,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 103,
      "prompt": "Write a function to check if a list contains all elements of another list.",
      "teacher_output": "def is_all_in(list1, list2):",
      "base_output": "def contains_all(big, small):\n    return set(small).issubset(set(big))",
      "teacher_ppl": 1.9794689746096192,
      "base_ppl": 2.2689131499435238,
      "ppl_diff": -0.28944417533390454,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 104,
      "prompt": "Write a function to find the product of all digits in a number.",
      "teacher_output": "def product_of_digits(num):\n    return (num // 10 ** (len(str(num))-1)) * (num % 10)",
      "base_output": "def digit_product(n):\n    prod = 1\n    for d in str(abs(n)):\n        prod *= int(d)\n    return prod",
      "teacher_ppl": 1.6894298257308353,
      "base_ppl": 1.8756317364250474,
      "ppl_diff": -0.1862019106942121,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 105,
      "prompt": "Write a function to check if a list alternates between even and odd numbers.",
      "teacher_output": "def is_list_alternating(lst):",
      "base_output": "def is_alternating(lst):\n    if not lst: return True\n    return all((lst[i] % 2) != (lst[i+1] % 2) for i in range(len(lst)-1))",
      "teacher_ppl": 2.2149073908764447,
      "base_ppl": 1.8585502055632186,
      "ppl_diff": 0.35635718531322613,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 106,
      "prompt": "Write a function to flatten a nested list of arbitrary depth (1 level only).",
      "teacher_output": "def flatten(l):\n    return reduce(operator.append, l, [])",
      "base_output": "def flatten_one_level(lst):\n    return [item for sublist in lst for item in (sublist if isinstance(sublist, list) else [sublist])]",
      "teacher_ppl": 2.5238941432473516,
      "base_ppl": 1.8946804630154233,
      "ppl_diff": 0.6292136802319284,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 107,
      "prompt": "Write a function to perform element-wise addition of two lists.",
      "teacher_output": "def add_lists(l1, l2):\n    return (l1 + l2)",
      "base_output": "def elementwise_add(a, b):\n    return [x + y for x, y in zip(a, b)]",
      "teacher_ppl": 1.6022103800126033,
      "base_ppl": 1.6457678091659813,
      "ppl_diff": -0.04355742915337801,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 108,
      "prompt": "Write a function to find the length of the longest word in a sentence.",
      "teacher_output": "def find_word_length(sentence):\n    return(max(map(len, sentence.split(' '))), 0)",
      "base_output": "def longest_word_length(sentence):\n    return max(map(len, sentence.split())) if sentence else 0",
      "teacher_ppl": 2.1752277517803997,
      "base_ppl": 2.058251053026615,
      "ppl_diff": 0.1169766987537848,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 109,
      "prompt": "Write a function to return the ASCII difference between each pair of adjacent characters.",
      "teacher_output": "def diff_of_ascii(str1, str2):\n    return (ord(str1[0]) - ord(str1[1])), (ord(str2[0]) - ord(str2[1]))",
      "base_output": "def ascii_differences(s):\n    return [abs(ord(s[i]) - ord(s[i+1])) for i in range(len(s)-1)]",
      "teacher_ppl": 1.5698490606560371,
      "base_ppl": 1.6720490283335308,
      "ppl_diff": -0.10219996767749362,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 110,
      "prompt": "Write a function to return the number of digits in a string.",
      "teacher_output": "def count_digits(num):\n    return(len(str(num)))",
      "base_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
      "teacher_ppl": 1.9769669353204653,
      "base_ppl": 1.7287468462599984,
      "ppl_diff": 0.2482200890604669,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 111,
      "prompt": "Write a function to check if a number is a Kaprekar number.",
      "teacher_output": "def kaprekar(num):\n    return (num * (num * num) - num) / 10000",
      "base_output": "def is_kaprekar(n):\n    sq = str(n ** 2)\n    for i in range(1, len(sq)):\n        left, right = sq[:i], sq[i:]\n        if int(right or 0) + int(left or 0) == n:\n            return True\n    return n == 1",
      "teacher_ppl": 2.350397830816052,
      "base_ppl": 2.1236730160132264,
      "ppl_diff": 0.22672481480282558,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 112,
      "prompt": "Write a function to check if a list is monotonic (entirely non-increasing or non-decreasing).",
      "teacher_output": "def is_monotonic(my_list):",
      "base_output": "def is_monotonic(lst):\n    return lst == sorted(lst) or lst == sorted(lst, reverse=True)",
      "teacher_ppl": 1.8855400409611935,
      "base_ppl": 1.6488226843162301,
      "ppl_diff": 0.2367173566449634,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 113,
      "prompt": "Write a function to remove all elements that appear more than once in a list.",
      "teacher_output": "def remove_dups(l):\nreturn(l)",
      "base_output": "from collections import Counter\n\ndef remove_duplicates(lst):\n    counts = Counter(lst)\n    return [x for x in lst if counts[x] == 1]",
      "teacher_ppl": 3.0141912310847516,
      "base_ppl": 1.7173566351494924,
      "ppl_diff": 1.2968345959352592,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 114,
      "prompt": "Write a function to count how many sublists are in a list.",
      "teacher_output": "def count_sublists(l):\n    return 0",
      "base_output": "def count_sublists(lst):\n    return sum(1 for item in lst if isinstance(item, list))",
      "teacher_ppl": 2.0684908695324236,
      "base_ppl": 2.0526423936216327,
      "ppl_diff": 0.01584847591079086,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 115,
      "prompt": "Write a function to convert a list of strings to a single comma-separated string.",
      "teacher_output": "def string_join(s):\n    return ','.join(s)",
      "base_output": "def list_to_csv(lst):\n    return ','.join(lst)",
      "teacher_ppl": 2.1197668748911878,
      "base_ppl": 1.9012299521807177,
      "ppl_diff": 0.2185369227104701,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 116,
      "prompt": "Write a function to return all even-indexed characters in a string.",
      "teacher_output": "def even_index_char(str_arg):",
      "base_output": "def even_index_chars(s):\n    return s[::2]",
      "teacher_ppl": 2.3199188878342443,
      "base_ppl": 1.9464615424471756,
      "ppl_diff": 0.37345734538706865,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 117,
      "prompt": "Write a function to reverse a dictionary (values become keys and vice versa).",
      "teacher_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
      "base_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
      "teacher_ppl": 1.3721553584562547,
      "base_ppl": 1.3721573250087218,
      "ppl_diff": -1.9665524670919865e-06,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 118,
      "prompt": "Write a function to generate all suffixes of a given string.",
      "teacher_output": "def suffixes(string):\n    return [string[0] + string[1:] for string in string]",
      "base_output": "def suffixes(s):\n    return [s[i:] for i in range(len(s))]",
      "teacher_ppl": 2.5741408138768915,
      "base_ppl": 1.5889160965935751,
      "ppl_diff": 0.9852247172833164,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 119,
      "prompt": "Write a function to check if a number is a palindrome in binary.",
      "teacher_output": "def isPalindrome(num):\n    if (num < 0):\n        return False\n    if (num == int(num)):\n        return True\n    if (num % 10 == num // 10):\n        return True\n    return False",
      "base_output": "def is_binary_palindrome(n):\n    b = bin(n)[2:]\n    return b == b[::-1]",
      "teacher_ppl": 1.7215524475570305,
      "base_ppl": 1.6535164199406258,
      "ppl_diff": 0.0680360276164047,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 120,
      "prompt": "Write a function to determine if a point lies inside a circle given center and radius.",
      "teacher_output": "def is_point_in_circle(x, y, cx, cy, r):",
      "base_output": "def point_in_circle(x, y, cx, cy, r):\n    return (x - cx) ** 2 + (y - cy) ** 2 <= r ** 2",
      "teacher_ppl": 1.5916720917575176,
      "base_ppl": 1.3268907921481286,
      "ppl_diff": 0.264781299609389,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 121,
      "prompt": "Write a function to count the number of uppercase letters in a string.",
      "teacher_output": "def count_upper(string):\n    return sum(1 for c in string if c.isupper())",
      "base_output": "def count_uppercase(s):\n    return sum(1 for c in s if c.isupper())",
      "teacher_ppl": 1.587849302361611,
      "base_ppl": 1.5859613480917591,
      "ppl_diff": 0.001887954269851777,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 122,
      "prompt": "Write a function to find the mode (most frequent element) in a list.",
      "teacher_output": "def mode(nums):\n    mode_num = max(nums)\n    mode_count = nums.count(mode_num)\n    return mode_num, mode_count",
      "base_output": "from collections import Counter\n\ndef find_mode(lst):\n    return Counter(lst).most_common(1)[0][0]",
      "teacher_ppl": 1.6747684943738743,
      "base_ppl": 1.7118985358092682,
      "ppl_diff": -0.03713004143539389,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 123,
      "prompt": "Write a function to test if a string contains only binary digits.",
      "teacher_output": "def is_binary(str_in):\n    return all(c.isdigit() for c in str_in)",
      "base_output": "def is_binary_string(s):\n    return all(c in '01' for c in s)",
      "teacher_ppl": 1.8126340978538955,
      "base_ppl": 1.6893102276040244,
      "ppl_diff": 0.12332387024987113,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 124,
      "prompt": "Write a function to check if a number is a perfect cube.",
      "teacher_output": "def is_perfect_cube(num):\n    return (num**(1/3))==(int(num**(1/3)))",
      "base_output": "def is_perfect_cube(n):\n    root = round(abs(n) ** (1/3))\n    return root ** 3 == abs(n)",
      "teacher_ppl": 1.8152277153286611,
      "base_ppl": 2.2677180490475424,
      "ppl_diff": -0.45249033371888125,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 125,
      "prompt": "Write a function to convert a list of integers to their binary representations.",
      "teacher_output": "def int2bin(num):\nreturn bin(num).lstrip('0b').zfill(32)",
      "base_output": "def list_to_binary(lst):\n    return [bin(x)[2:] for x in lst]",
      "teacher_ppl": 2.1127543312773533,
      "base_ppl": 1.6444710476931363,
      "ppl_diff": 0.468283283584217,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 126,
      "prompt": "Write a function to find the length of the shortest word in a sentence.",
      "teacher_output": "def find_word_length(sentence):\nreturn",
      "base_output": "def shortest_word_length(sentence):\n    return min(map(len, sentence.split())) if sentence else 0",
      "teacher_ppl": 2.2213243489889165,
      "base_ppl": 1.9563245936247755,
      "ppl_diff": 0.264999755364141,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 127,
      "prompt": "Write a function to find the sum of all diagonals in a square matrix.",
      "teacher_output": "def sum_of_all_diagonals(m):",
      "base_output": "def diagonal_sums(matrix):\n    n = len(matrix)\n    return sum(matrix[i][i] for i in range(n)) + sum(matrix[i][n-i-1] for i in range(n))",
      "teacher_ppl": 1.786074362102711,
      "base_ppl": 1.449387909185842,
      "ppl_diff": 0.33668645291686916,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 129,
      "prompt": "Write a function to find all numbers in a string.",
      "teacher_output": "def find_all_numbers(string):\n    return [int(num) for num in string.split()]",
      "base_output": "import re\n\ndef extract_numbers(s):\n    return list(map(int, re.findall(r'\\d+', s)))",
      "teacher_ppl": 1.6458447533053338,
      "base_ppl": 2.1171461359783734,
      "ppl_diff": -0.47130138267303967,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 131,
      "prompt": "Write a function to compute the factorial of a number recursively.",
      "teacher_output": "def fact(n):\n    if n == 1:\n        return 1\n    else:\n        return n * fact(n - 1)",
      "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    return n * recursive_factorial(n - 1)",
      "teacher_ppl": 1.2108211022395112,
      "base_ppl": 1.423057045277251,
      "ppl_diff": -0.21223594303773985,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 132,
      "prompt": "Write a function to check whether a list is a subset of another list.",
      "teacher_output": "def isSubset(a, b):",
      "base_output": "def is_subset(small, large):\n    return set(small).issubset(set(large))",
      "teacher_ppl": 1.6848097119016356,
      "base_ppl": 2.0114771294708707,
      "ppl_diff": -0.326667417569235,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 133,
      "prompt": "Write a function to find the most frequent character in a string.",
      "teacher_output": "def find_most_freq_char(str_arg):\n    return str_arg.count(max(set(str_arg), key=str_arg.count))",
      "base_output": "from collections import Counter\n\ndef most_frequent_char(s):\n    return Counter(s).most_common(1)[0][0] if s else None",
      "teacher_ppl": 1.7152891877993657,
      "base_ppl": 2.066672559548474,
      "ppl_diff": -0.35138337174910816,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 134,
      "prompt": "Write a function to remove consecutive duplicates from a list.",
      "teacher_output": "def remove_consecutive_duplicates(l):\nreturn(l)",
      "base_output": "def remove_consecutive_duplicates(lst):\n    if not lst:\n        return []\n    result = [lst[0]]\n    for item in lst[1:]:\n        if item != result[-1]:\n            result.append(item)\n    return result",
      "teacher_ppl": 2.3155844577764793,
      "base_ppl": 1.3564031796532892,
      "ppl_diff": 0.9591812781231901,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 135,
      "prompt": "Write a function to count the number of unique words in a sentence.",
      "teacher_output": "def count_words(sentence):\n    words = sentence.split()\n    return(len(words))",
      "base_output": "def count_unique_words(sentence):\n    return len(set(sentence.split()))",
      "teacher_ppl": 1.7880482324222196,
      "base_ppl": 1.545874450160906,
      "ppl_diff": 0.24217378226131347,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 136,
      "prompt": "Write a function to find the number of digits in an integer.",
      "teacher_output": "def count_digits(num):\n    return(len(str(num)))",
      "base_output": "def digit_count(n):\n    return len(str(abs(n)))",
      "teacher_ppl": 1.858186494925444,
      "base_ppl": 2.23591969257921,
      "ppl_diff": -0.3777331976537659,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 137,
      "prompt": "Write a function to replace spaces with underscores in a string.",
      "teacher_output": "def replace_spaces_with_underscores(str_arg):\n    return str_arg.replace(\" \", \"_\")",
      "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
      "teacher_ppl": 1.6599634678681743,
      "base_ppl": 1.5227203021574007,
      "ppl_diff": 0.13724316571077355,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 138,
      "prompt": "Write a function to find the second highest value in a list.",
      "teacher_output": "def find_second_highest(nums):\n    return max(nums) - sum(nums) / 2",
      "base_output": "def second_highest(lst):\n    return sorted(set(lst))[-2] if len(set(lst)) > 1 else None",
      "teacher_ppl": 2.099289746271983,
      "base_ppl": 2.1252643948664205,
      "ppl_diff": -0.025974648594437433,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 139,
      "prompt": "Write a function to compute the sum of even-indexed elements in a list.",
      "teacher_output": "def sum_of_even_indices(l):\n    return sum(l[i] for i in range(0, len(l), 2))",
      "base_output": "def sum_even_indexed(lst):\n    return sum(lst[i] for i in range(0, len(lst), 2))",
      "teacher_ppl": 1.5193169441229606,
      "base_ppl": 1.455622179184126,
      "ppl_diff": 0.06369476493883464,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 140,
      "prompt": "Write a function to reverse the digits of an integer.",
      "teacher_output": "def reverse_int(num):\n    return int(str(num)[::-1])",
      "base_output": "def reverse_digits(n):\n    sign = -1 if n < 0 else 1\n    return sign * int(str(abs(n))[::-1])",
      "teacher_ppl": 1.5594119280492882,
      "base_ppl": 1.6366837977991835,
      "ppl_diff": -0.0772718697498953,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 141,
      "prompt": "Write a function to return the index of the maximum element in a list.",
      "teacher_output": "def max_index(l):\n    return (max(l), l.index(max(l)))",
      "base_output": "def index_of_max(lst):\n    return lst.index(max(lst)) if lst else None",
      "teacher_ppl": 1.8808372487248446,
      "base_ppl": 2.437807213913657,
      "ppl_diff": -0.5569699651888123,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 142,
      "prompt": "Write a function to check if all elements in a list are positive.",
      "teacher_output": "def is_all_pos(nums):",
      "base_output": "def all_positive(lst):\n    return all(x > 0 for x in lst)",
      "teacher_ppl": 2.165040612242243,
      "base_ppl": 1.5409364781201147,
      "ppl_diff": 0.6241041341221283,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 143,
      "prompt": "Write a function to interleave two lists of equal length.",
      "teacher_output": "def interleave(l1, l2):\n    return (l1 + l2)",
      "base_output": "def interleave_lists(a, b):\n    return [val for pair in zip(a, b) for val in pair]",
      "teacher_ppl": 1.5982878151085926,
      "base_ppl": 2.1125309180903664,
      "ppl_diff": -0.5142431029817738,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 144,
      "prompt": "Write a function to compute the sum of all two-digit numbers in a list.",
      "teacher_output": "def sum_of_two_digit_numbers(nums):\n    sum = 0\n    for i in nums:\n        sum += int(str(i)[1])\n    return sum",
      "base_output": "def sum_two_digit_numbers(lst):\n    return sum(x for x in lst if 10 <= abs(x) <= 99)",
      "teacher_ppl": 1.5398540817915243,
      "base_ppl": 1.8672880548200699,
      "ppl_diff": -0.3274339730285456,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 147,
      "prompt": "Write a function to capitalize the first letter of each word in a string.",
      "teacher_output": "def cap_str(str_arg):\n    return str_arg.capitalize()",
      "base_output": "def title_case(s):\n    return ' '.join(word.capitalize() for word in s.split())",
      "teacher_ppl": 2.129119541284929,
      "base_ppl": 1.7001000584449717,
      "ppl_diff": 0.4290194828399574,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 148,
      "prompt": "Write a function to repeat each character in a string twice.",
      "teacher_output": "def twice(string):\n    return ''.join(c*2 for c in string)",
      "base_output": "def double_chars(s):\n    return ''.join(c*2 for c in s)",
      "teacher_ppl": 1.8030019433279731,
      "base_ppl": 2.0134584209193753,
      "ppl_diff": -0.21045647759140218,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 149,
      "prompt": "Write a function to generate a list of n Fibonacci numbers.",
      "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n-1) + fibonacci(n-2)",
      "base_output": "def generate_fibonacci(n):\n    a, b = 0, 1\n    result = []\n    for _ in range(n):\n        result.append(a)\n        a, b = b, a + b\n    return result",
      "teacher_ppl": 1.2804678970940992,
      "base_ppl": 1.4521050317698319,
      "ppl_diff": -0.1716371346757326,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 150,
      "prompt": "Write a function to check if all characters in a string are unique.",
      "teacher_output": "def is_unique(string):",
      "base_output": "def all_unique_chars(s):\n    return len(set(s)) == len(s)",
      "teacher_ppl": 1.6920685724734588,
      "base_ppl": 1.8493932447619479,
      "ppl_diff": -0.15732467228848912,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 151,
      "prompt": "Write a function to find the largest even number in a list.",
      "teacher_output": "def find_largest_even_num(num_list):\n    return max(num_list, key=lambda x: (x % 2 == 0))",
      "base_output": "def largest_even(lst):\n    evens = [x for x in lst if x % 2 == 0]\n    return max(evens) if evens else None",
      "teacher_ppl": 1.5621770641534722,
      "base_ppl": 1.7411634039587722,
      "ppl_diff": -0.1789863398053,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 152,
      "prompt": "Write a function to convert a number to a list of its digits.",
      "teacher_output": "def digit_list(num):\n    return [int(d) for d in str(num)]",
      "base_output": "def number_to_digits(n):\n    return [int(d) for d in str(abs(n))]",
      "teacher_ppl": 1.598147976731818,
      "base_ppl": 2.073559834932515,
      "ppl_diff": -0.475411858200697,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 153,
      "prompt": "Write a function to calculate the sum of ASCII values of characters in a string.",
      "teacher_output": "def sum_of_ascii_values(str_arg):",
      "base_output": "def ascii_sum(s):\n    return sum(ord(c) for c in s)",
      "teacher_ppl": 1.9700228007181368,
      "base_ppl": 1.5464970063720112,
      "ppl_diff": 0.4235257943461257,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 154,
      "prompt": "Write a function to get the index of the first negative number in a list.",
      "teacher_output": "def get_neg_index(nums):\n    return ",
      "base_output": "def first_negative_index(lst):\n    for i, val in enumerate(lst):\n        if val < 0:\n            return i\n    return -1",
      "teacher_ppl": 2.716407690758244,
      "base_ppl": 1.4941913647150096,
      "ppl_diff": 1.2222163260432346,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 155,
      "prompt": "Write a function to count how many words start with a vowel in a sentence.",
      "teacher_output": "def count_vowels(str_arg):\n    return 0",
      "base_output": "def count_words_starting_with_vowel(s):\n    return sum(1 for word in s.lower().split() if word[0] in 'aeiou')",
      "teacher_ppl": 2.294539760549134,
      "base_ppl": 1.8307250540711573,
      "ppl_diff": 0.46381470647797696,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 156,
      "prompt": "Write a function to rotate a string left by n positions.",
      "teacher_output": "def rotate_left(string, n):",
      "base_output": "def rotate_left(s, n):\n    n = n % len(s) if s else 0\n    return s[n:] + s[:n]",
      "teacher_ppl": 1.551933622553567,
      "base_ppl": 1.8755141316419688,
      "ppl_diff": -0.32358050908840186,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 157,
      "prompt": "Write a function to compute the transpose of a matrix.",
      "teacher_output": "def transpose(a):\n    return([[a[i][j]] for j in range(len(a))] for i in range(len(a[0])))",
      "base_output": "def transpose(matrix):\n    return [list(row) for row in zip(*matrix)]",
      "teacher_ppl": 1.8767920177036752,
      "base_ppl": 1.5468619585168832,
      "ppl_diff": 0.32993005918679197,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 158,
      "prompt": "Write a function to return the number of set bits (1s) in binary representation of a number.",
      "teacher_output": "def count_set_bits(n):",
      "base_output": "def count_set_bits(n):\n    return bin(n).count('1')",
      "teacher_ppl": 1.5477319820130915,
      "base_ppl": 1.5280861858197918,
      "ppl_diff": 0.019645796193299647,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 159,
      "prompt": "Write a function to check if the elements in a list are in non-decreasing order.",
      "teacher_output": "def isNonDecreasing(nums):",
      "base_output": "def is_non_decreasing(lst):\n    return all(x <= y for x, y in zip(lst, lst[1:]))",
      "teacher_ppl": 2.1633301671152183,
      "base_ppl": 1.4780250954942167,
      "ppl_diff": 0.6853050716210016,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 160,
      "prompt": "Write a function to generate all pairs of elements from a list.",
      "teacher_output": "def pairs(nums):\n    return list(combinations(nums, 2))",
      "base_output": "def generate_pairs(lst):\n    return [(lst[i], lst[j]) for i in range(len(lst)) for j in range(i+1, len(lst))]",
      "teacher_ppl": 1.9075848366027426,
      "base_ppl": 1.4635470677485636,
      "ppl_diff": 0.444037768854179,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 161,
      "prompt": "Write a function to calculate the sum of numbers divisible by 3 or 5 below n.",
      "teacher_output": "def sum_of_divisors(n):\n    sum = 0\n    for i in range(1, n + 1):\n        if (i % 3 == 0) or (i % 5 == 0):\n            sum += i\n    return sum",
      "base_output": "def sum_divisible_by_3_or_5(n):\n    return sum(i for i in range(n) if i % 3 == 0 or i % 5 == 0)",
      "teacher_ppl": 1.2417986611758698,
      "base_ppl": 1.292815833203082,
      "ppl_diff": -0.05101717202721212,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 163,
      "prompt": "Write a function to find the smallest positive integer missing from a list.",
      "teacher_output": "def findpos(nums):\n    for i in range(1,1000000000):\n        if(i not in nums):\n            return(i)",
      "base_output": "def smallest_missing_positive(lst):\n    s = set(lst)\n    i = 1\n    while i in s:\n        i += 1\n    return i",
      "teacher_ppl": 2.0991719894542515,
      "base_ppl": 1.7531010275274206,
      "ppl_diff": 0.34607096192683096,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 165,
      "prompt": "Write a function to return a dictionary mapping characters to their frequencies in a string.",
      "teacher_output": "def count_char(string):\n    return {c: string.count(c) for c in string}",
      "base_output": "def char_frequency(s):\n    freq = {}\n    for c in s:\n        freq[c] = freq.get(c, 0) + 1\n    return freq",
      "teacher_ppl": 1.6988396107397707,
      "base_ppl": 1.447458972781135,
      "ppl_diff": 0.25138063795863586,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 166,
      "prompt": "Write a function to remove duplicates from a list while preserving order.",
      "teacher_output": "def remove_dups(l):\nreturn(set(l))",
      "base_output": "def deduplicate(lst):\n    seen = set()\n    result = []\n    for item in lst:\n        if item not in seen:\n            seen.add(item)\n            result.append(item)\n    return result",
      "teacher_ppl": 2.409337432143889,
      "base_ppl": 1.4519488131242204,
      "ppl_diff": 0.9573886190196685,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 167,
      "prompt": "Write a function to check if a number is a palindrome.",
      "teacher_output": "def isPalindrome(num):\n    if (num == num[::-1]):\n        return True\n    else:\n        return False",
      "base_output": "def is_numeric_palindrome(n):\n    return str(n) == str(n)[::-1]",
      "teacher_ppl": 1.5306485227438629,
      "base_ppl": 1.8898689667517306,
      "ppl_diff": -0.3592204440078677,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 168,
      "prompt": "Write a function to get the common elements between two lists.",
      "teacher_output": "def common_elements(list1, list2):",
      "base_output": "def common_elements(a, b):\n    return list(set(a) & set(b))",
      "teacher_ppl": 1.3374334579788931,
      "base_ppl": 1.4996898123683255,
      "ppl_diff": -0.16225635438943242,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 169,
      "prompt": "Write a function to check if a number is a perfect number (equal to sum of its proper divisors).",
      "teacher_output": "def is_perfect_number(num):\n    if num == 0:\n        return False\n    if num == 1:\n        return True\n    if num < 0:\n        return False\n    sum_of_divisors = 1\n    for i in range(2, num):\n        if num % i == 0:\n            sum_of_divisors += i\n            if sum_of_divisors == num:\n                return True\n    return False",
      "base_output": "def is_perfect_number(n):\n    return n == sum(i for i in range(1, n) if n % i == 0)",
      "teacher_ppl": 1.353509456852423,
      "base_ppl": 1.4587071356148469,
      "ppl_diff": -0.10519767876242381,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 170,
      "prompt": "Write a function to compute the nth triangular number.",
      "teacher_output": "def get_nth_triangular_number(n):",
      "base_output": "def triangular_number(n):\n    return n * (n + 1) // 2",
      "teacher_ppl": 1.5918392199324225,
      "base_ppl": 1.3610283929369287,
      "ppl_diff": 0.23081082699549382,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 171,
      "prompt": "Write a function to merge two dictionaries. In case of conflict, use values from the second.",
      "teacher_output": "def merge_dict(d1, d2):\n    return {k: v for k, v in (d1.items() + d2.items()) if v is not None}",
      "base_output": "def merge_dicts(d1, d2):\n    return {**d1, **d2}",
      "teacher_ppl": 1.4939988718799189,
      "base_ppl": 1.3968294884325099,
      "ppl_diff": 0.097169383447409,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 173,
      "prompt": "Write a function to find the number of trailing zeros in a factorial.",
      "teacher_output": "def trailingZeros(n):\n    return (n // 5) + (n % 5)",
      "base_output": "def count_trailing_zeros(n):\n    count = 0\n    i = 5\n    while n // i:\n        count += n // i\n        i *= 5\n    return count",
      "teacher_ppl": 1.7934426747171877,
      "base_ppl": 1.5633163681202593,
      "ppl_diff": 0.23012630659692834,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 174,
      "prompt": "Write a function to calculate the harmonic sum of n terms.",
      "teacher_output": "def harmonic_sum(n):\nreturn (1/1) + (1/2) + (1/3) + (1/4) + (1/5) + (1/6) + (1/7) + (1/8) + (1/9) + (1/10)",
      "base_output": "def harmonic_sum(n):\n    return sum(1/i for i in range(1, n+1))",
      "teacher_ppl": 1.2290461676999354,
      "base_ppl": 1.411624890534665,
      "ppl_diff": -0.18257872283472976,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 175,
      "prompt": "Write a function to convert a number to base-2 (binary) as a string.",
      "teacher_output": "def to_binary(num):\n    return bin(num).lstrip('0b')",
      "base_output": "def to_binary(n):\n    return bin(n)[2:]",
      "teacher_ppl": 1.7841708500836395,
      "base_ppl": 1.7220089336720907,
      "ppl_diff": 0.06216191641154878,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 176,
      "prompt": "Write a function to calculate the number of unique characters in a string.",
      "teacher_output": "def count_unique_chars(string):",
      "base_output": "def unique_char_count(s):\n    return len(set(s))",
      "teacher_ppl": 1.9468285378479342,
      "base_ppl": 1.7900311678382639,
      "ppl_diff": 0.1567973700096703,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 177,
      "prompt": "Write a function to get the list of prime numbers below a given number.",
      "teacher_output": "def get_prime_numbers(num):\n    prime_numbers = []\n    for i in range(2, num):\n        if is_prime(i):\n            prime_numbers.append(i)\n    return prime_numbers",
      "base_output": "def primes_below(n):\n    sieve = [True]*n\n    for i in range(2, int(n**0.5)+1):\n        if sieve[i]:\n            for j in range(i*i, n, i):\n                sieve[j] = False\n    return [i for i in range(2, n) if sieve[i]]",
      "teacher_ppl": 1.3455622935781488,
      "base_ppl": 1.353034279558199,
      "ppl_diff": -0.0074719859800502775,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 178,
      "prompt": "Write a function to reverse a dictionary (values must be unique).",
      "teacher_output": "def reverseDict(d):\n    return {v:k for k,v in d.items()}",
      "base_output": "def reverse_dict(d):\n    return {v: k for k, v in d.items()}",
      "teacher_ppl": 1.5862979877920729,
      "base_ppl": 1.4035153928651836,
      "ppl_diff": 0.1827825949268893,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 179,
      "prompt": "Write a function to return all positions of a character in a string.",
      "teacher_output": "def find_all_pos(str, ch):\n    return str.index(ch)",
      "base_output": "def char_positions(s, c):\n    return [i for i, ch in enumerate(s) if ch == c]",
      "teacher_ppl": 2.1640569998357098,
      "base_ppl": 1.7622004584174418,
      "ppl_diff": 0.401856541418268,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 181,
      "prompt": "Write a function to return True if a string is a valid identifier.",
      "teacher_output": "def is_identifier(s):\n    if (s[0].isalpha() and (not (s[0] in \"!\\\"#$%&\\'()*+,./:;=?@$\" - s[0]))) and (not (s[-1].isdigit())):\n        return True\n    return False",
      "base_output": "def is_valid_identifier(s):\n    return s.isidentifier()",
      "teacher_ppl": 2.797915113741626,
      "base_ppl": 1.9819189825436097,
      "ppl_diff": 0.8159961311980164,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 182,
      "prompt": "Write a function to check if a list contains a sublist.",
      "teacher_output": "def sublist_check(l1, l2):\n    return (all(x1 == x2 for x1, x2 in zip(l1, l2)))",
      "base_output": "def contains_sublist(lst, sub):\n    for i in range(len(lst) - len(sub) + 1):\n        if lst[i:i+len(sub)] == sub:\n            return True\n    return False",
      "teacher_ppl": 1.8052003086025308,
      "base_ppl": 1.447198557695334,
      "ppl_diff": 0.3580017509071969,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 183,
      "prompt": "Write a function to count how many numbers in a list are above average.",
      "teacher_output": "def count_above_avg(nums):\n    return sum(x > int(sum(nums)/len(nums)) for x in nums)",
      "base_output": "def count_above_average(lst):\n    if not lst:\n        return 0\n    avg = sum(lst) / len(lst)\n    return sum(1 for x in lst if x > avg)",
      "teacher_ppl": 1.8129832742414618,
      "base_ppl": 1.6177190615171169,
      "ppl_diff": 0.1952642127243449,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 184,
      "prompt": "Write a function to return all substrings of a string.",
      "teacher_output": "def sub_str(str_arg):\n    return str_arg.split()",
      "base_output": "def all_substrings(s):\n    return [s[i:j] for i in range(len(s)) for j in range(i+1, len(s)+1)]",
      "teacher_ppl": 2.6399165421552055,
      "base_ppl": 1.3913705492082107,
      "ppl_diff": 1.2485459929469949,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 185,
      "prompt": "Write a function to interleave two strings of the same length.",
      "teacher_output": "def interleave(s1, s2):\n    return ''.join(i for i in (s1 + s2))",
      "base_output": "def interleave_strings(a, b):\n    return ''.join(x + y for x, y in zip(a, b))",
      "teacher_ppl": 1.6690520634614787,
      "base_ppl": 1.6752716623840627,
      "ppl_diff": -0.0062195989225839465,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 186,
      "prompt": "Write a function to return True if the number is a power of two.",
      "teacher_output": "def isPowerOfTwo(n):\n    if n == 0:\n        return False\n    if n == 1:\n        return True\n    if n % 2 == 0:\n        return isPowerOfTwo(n // 2)\n    return False",
      "base_output": "def is_power_of_two(n):\n    return n > 0 and (n & (n - 1)) == 0",
      "teacher_ppl": 1.3197689027951875,
      "base_ppl": 1.392479167679275,
      "ppl_diff": -0.07271026488408738,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 189,
      "prompt": "Write a function to compute the sum of the digits raised to the power of their positions.",
      "teacher_output": "def sum_of_digits_to_power_of_pos(num):",
      "base_output": "def digit_power_sum(n):\n    return sum(int(d)**(i+1) for i, d in enumerate(str(abs(n))))",
      "teacher_ppl": 2.056649865279133,
      "base_ppl": 2.1995752311485255,
      "ppl_diff": -0.14292536586939253,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 190,
      "prompt": "Write a function to check if two lists are disjoint (no common elements).",
      "teacher_output": "def is_disjoint(a, b):",
      "base_output": "def are_disjoint(a, b):\n    return not set(a) & set(b)",
      "teacher_ppl": 1.5946665090657057,
      "base_ppl": 1.8283738934512697,
      "ppl_diff": -0.23370738438556393,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 192,
      "prompt": "Write a function to check if a string is a valid palindrome ignoring case and punctuation.",
      "teacher_output": "def isPalindrome(string):",
      "base_output": "import re\n\ndef is_clean_palindrome(s):\n    cleaned = re.sub(r'[^a-z0-9]', '', s.lower())\n    return cleaned == cleaned[::-1]",
      "teacher_ppl": 1.8398285902207465,
      "base_ppl": 2.133210682261694,
      "ppl_diff": -0.29338209204094734,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 193,
      "prompt": "Write a function to calculate the nth Catalan number.",
      "teacher_output": "def catalan(n):\nreturn (1/((1+1j)**n))*((1-1j)**n)",
      "base_output": "import math\n\ndef catalan_number(n):\n    return math.comb(2*n, n) // (n + 1)",
      "teacher_ppl": 2.4156075221870204,
      "base_ppl": 2.3497144072333707,
      "ppl_diff": 0.06589311495364969,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 195,
      "prompt": "Write a function to check if a list of integers is a geometric progression.",
      "teacher_output": "def is_geometric_progression(list_of_numbers):",
      "base_output": "def is_geometric(lst):\n    if len(lst) < 2:\n        return True\n    ratio = lst[1] / lst[0]\n    return all(lst[i] * ratio == lst[i+1] for i in range(len(lst)-1))",
      "teacher_ppl": 1.5205681227293826,
      "base_ppl": 1.6564680346974336,
      "ppl_diff": -0.13589991196805107,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 196,
      "prompt": "Write a function to transpose a rectangular matrix.",
      "teacher_output": "def transpose(a):\n    return map(list, map(lambda x: list(x), a))",
      "base_output": "def transpose_matrix(mat):\n    return [list(row) for row in zip(*mat)]",
      "teacher_ppl": 2.4069828185807802,
      "base_ppl": 1.7341087988741477,
      "ppl_diff": 0.6728740197066325,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 197,
      "prompt": "Write a function to count the number of elements greater than the average in a list.",
      "teacher_output": "def count_greater_than_avg(nums):",
      "base_output": "def count_above_avg(lst):\n    if not lst: return 0\n    avg = sum(lst) / len(lst)\n    return sum(1 for x in lst if x > avg)",
      "teacher_ppl": 2.139641968045243,
      "base_ppl": 1.749628297704264,
      "ppl_diff": 0.3900136703409791,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 198,
      "prompt": "Write a function to count the number of palindromic substrings in a string.",
      "teacher_output": "def count_palindromes(string):\n    return 0",
      "base_output": "def count_palindromes(s):\n    count = 0\n    for i in range(len(s)):\n        for j in range(i+1, len(s)+1):\n            sub = s[i:j]\n            if sub == sub[::-1]:\n                count += 1\n    return count",
      "teacher_ppl": 2.0083437035618146,
      "base_ppl": 1.2858411803051464,
      "ppl_diff": 0.7225025232566682,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 199,
      "prompt": "Write a function to generate the powerset of a list.",
      "teacher_output": "def powerset(l):\n    return [set(p) for p in powerset_iter(l)]",
      "base_output": "from itertools import chain, combinations\n\ndef powerset(lst):\n    return list(chain.from_iterable(combinations(lst, r) for r in range(len(lst)+1)))",
      "teacher_ppl": 1.8072824183507168,
      "base_ppl": 1.6395677830958046,
      "ppl_diff": 0.16771463525491215,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 201,
      "prompt": "Write a function to count the frequency of each digit in a number.",
      "teacher_output": "def count_digit(num):\n    return sum(1 for d in str(num))",
      "base_output": "def digit_frequency(n):\n    freq = {}\n    for d in str(abs(n)):\n        freq[d] = freq.get(d, 0) + 1\n    return freq",
      "teacher_ppl": 2.339072645333669,
      "base_ppl": 1.7249925194349083,
      "ppl_diff": 0.6140801258987607,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 202,
      "prompt": "Write a function to validate if all brackets are closed properly in a string.",
      "teacher_output": "def is_balanced(s):\n    stack = []\n    for c in s:\n        if c == '(':\n            stack.append(c)\n        elif c == ')':\n            if not stack:\n                return False\n            else:\n                stack.pop()\n    return stack == []",
      "base_output": "def valid_brackets(s):\n    stack = []\n    pairs = {')':'(', ']':'[', '}':'{'}\n    for c in s:\n        if c in '([{':\n            stack.append(c)\n        elif c in ')]}':\n            if not stack or stack.pop() != pairs[c]:\n                return False\n    return not stack",
      "teacher_ppl": 1.3679443437148302,
      "base_ppl": 1.4907355133244973,
      "ppl_diff": -0.12279116960966707,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 203,
      "prompt": "Write a function to return the length of the longest word in a sentence.",
      "teacher_output": "def word_length(sentence):\n    return(len(sentence.split()))",
      "base_output": "def longest_word_length(s):\n    return max(map(len, s.split())) if s else 0",
      "teacher_ppl": 2.7321269956472745,
      "base_ppl": 2.0953073732951744,
      "ppl_diff": 0.6368196223521001,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 204,
      "prompt": "Write a function to convert all keys of a dictionary to lowercase.",
      "teacher_output": "def to_lower(d):",
      "base_output": "def lowercase_keys(d):\n    return {str(k).lower(): v for k, v in d.items()}",
      "teacher_ppl": 1.8335256776897235,
      "base_ppl": 1.706645671704222,
      "ppl_diff": 0.12688000598550153,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 205,
      "prompt": "Write a function to return True if all elements in a matrix are equal.",
      "teacher_output": "def is_all_equal(matrix):",
      "base_output": "def all_elements_equal(matrix):\n    flat = [item for row in matrix for item in row]\n    return len(set(flat)) == 1",
      "teacher_ppl": 1.6094350951479264,
      "base_ppl": 1.7454170884989688,
      "ppl_diff": -0.13598199335104244,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 206,
      "prompt": "Write a function to count how many characters in a string are digits.",
      "teacher_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
      "base_output": "def count_digits(s):\n    return sum(1 for c in s if c.isdigit())",
      "teacher_ppl": 1.608154317168719,
      "base_ppl": 1.608155749252828,
      "ppl_diff": -1.4320841090764702e-06,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 207,
      "prompt": "Write a function to return the intersection of two lists, preserving the order from the first list.",
      "teacher_output": "def intersection(a, b):\nreturn (set(a).intersection(b))",
      "base_output": "def ordered_intersection(a, b):\n    b_set = set(b)\n    return [x for x in a if x in b_set]",
      "teacher_ppl": 1.8632319614553692,
      "base_ppl": 1.9494520978432417,
      "ppl_diff": -0.08622013638787251,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 208,
      "prompt": "Write a function to generate a dictionary mapping numbers from 1 to n to their squares.",
      "teacher_output": "def get_squares(n):\n    return {num:num*num for num in range(1,n+1)}",
      "base_output": "def squares_dict(n):\n    return {i: i*i for i in range(1, n+1)}",
      "teacher_ppl": 1.6928388831368213,
      "base_ppl": 1.6590543108256932,
      "ppl_diff": 0.03378457231112808,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 209,
      "prompt": "Write a function to return the longest word in a list of words.",
      "teacher_output": "def longestWord(words):\n    return max(words, key=len)",
      "base_output": "def longest_word(words):\n    return max(words, key=len) if words else ''",
      "teacher_ppl": 1.5395122680570534,
      "base_ppl": 2.04054232773219,
      "ppl_diff": -0.5010300596751367,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 210,
      "prompt": "Write a function to check if a given year is a leap year.",
      "teacher_output": "def isLeapYear(year):\n    if (year % 400 == 0) and (year % 100 != 0) and (year % 4 == 0):\n        return True\n    else:\n        return False",
      "base_output": "def is_leap_year(year):\n    return year % 4 == 0 and (year % 100 != 0 or year % 400 == 0)",
      "teacher_ppl": 1.40498549847657,
      "base_ppl": 1.240636265201646,
      "ppl_diff": 0.1643492332749239,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 212,
      "prompt": "Write a function to remove every nth element from a list.",
      "teacher_output": "def removeNthFromBack(myList, n):",
      "base_output": "def remove_every_nth(lst, n):\n    return [x for i, x in enumerate(lst, 1) if i % n != 0]",
      "teacher_ppl": 3.654869545343165,
      "base_ppl": 1.686949311144044,
      "ppl_diff": 1.967920234199121,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 213,
      "prompt": "Write a function to find all unique characters in a string.",
      "teacher_output": "def unique_char(str):\n    return set(str)",
      "base_output": "def unique_characters(s):\n    return [c for c in s if s.count(c) == 1]",
      "teacher_ppl": 1.9650354663732381,
      "base_ppl": 1.6453444400920323,
      "ppl_diff": 0.3196910262812058,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 214,
      "prompt": "Write a function to find the last index of a given element in a list.",
      "teacher_output": "def last_index(l, x):\n    return -1 if x not in l else len(l) - l.index(x)",
      "base_output": "def last_index_of(lst, val):\n    return len(lst) - 1 - lst[::-1].index(val) if val in lst else -1",
      "teacher_ppl": 1.6797344720730656,
      "base_ppl": 1.9449016411155369,
      "ppl_diff": -0.2651671690424713,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 215,
      "prompt": "Write a function to calculate the product of all elements in a list.",
      "teacher_output": "def product(nums):\n    return reduce(mul, nums)",
      "base_output": "def list_product(lst):\n    prod = 1\n    for x in lst:\n        prod *= x\n    return prod if lst else 0",
      "teacher_ppl": 2.217114638674882,
      "base_ppl": 2.33344116044003,
      "ppl_diff": -0.1163265217651479,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 216,
      "prompt": "Write a function to generate the first n even numbers.",
      "teacher_output": "def even_num(n):\n    return [2*i for i in range(1,n+1)]",
      "base_output": "def first_n_evens(n):\n    return [2*i for i in range(n)]",
      "teacher_ppl": 1.6065300023132214,
      "base_ppl": 1.830701787651627,
      "ppl_diff": -0.22417178533840554,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 217,
      "prompt": "Write a function to count how many times a given word appears in a sentence.",
      "teacher_output": "def count_word(word, sentence):",
      "base_output": "def word_frequency(sentence, word):\n    return sentence.split().count(word)",
      "teacher_ppl": 1.7275172781198818,
      "base_ppl": 2.298577460084585,
      "ppl_diff": -0.5710601819647032,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 218,
      "prompt": "Write a function to find the maximum value in each row of a matrix.",
      "teacher_output": "def max_row(m):\n    return max(m)",
      "base_output": "def row_maxima(matrix):\n    return [max(row) for row in matrix]",
      "teacher_ppl": 1.964430489479215,
      "base_ppl": 1.8108891148913,
      "ppl_diff": 0.15354137458791506,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 219,
      "prompt": "Write a function to check if a number is divisible by all elements in a list.",
      "teacher_output": "def is_divisible(num, list):",
      "base_output": "def divisible_by_all(n, lst):\n    return all(n % x == 0 for x in lst if x != 0)",
      "teacher_ppl": 1.74963884515261,
      "base_ppl": 1.8179112079631494,
      "ppl_diff": -0.0682723628105395,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 220,
      "prompt": "Write a function to get the first repeated word in a string.",
      "teacher_output": "def get_first_repeated_word(string):",
      "base_output": "def first_repeated_word(s):\n    seen = set()\n    for word in s.split():\n        if word in seen:\n            return word\n        seen.add(word)\n    return None",
      "teacher_ppl": 1.4400905650965932,
      "base_ppl": 1.4562825069227823,
      "ppl_diff": -0.016191941826189105,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 221,
      "prompt": "Write a function to generate a string of alternating 1s and 0s of length n, starting with 1.",
      "teacher_output": "def f(n):\n    return \"1\" + ((\"0\" * (n - 2)) + \"1\") * (n - 1)",
      "base_output": "def alternating_binary(n):\n    return ''.join(str((i+1)%2) for i in range(n))",
      "teacher_ppl": 1.8231022866898852,
      "base_ppl": 2.0883770107903428,
      "ppl_diff": -0.2652747241004576,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 222,
      "prompt": "Write a function to check if a list contains only integers.",
      "teacher_output": "def is_int_list(l):\n    return all(isinstance(x, int) for x in l)",
      "base_output": "def all_integers(lst):\n    return all(isinstance(x, int) for x in lst)",
      "teacher_ppl": 1.5060567037873256,
      "base_ppl": 1.7324624424521482,
      "ppl_diff": -0.2264057386648226,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 224,
      "prompt": "Write a function to convert a list of binary strings to decimal integers.",
      "teacher_output": "def bin2int(bin_str_list):",
      "base_output": "def binary_to_decimals(lst):\n    return [int(b, 2) for b in lst]",
      "teacher_ppl": 2.7194489887864175,
      "base_ppl": 2.169082588949082,
      "ppl_diff": 0.5503663998373356,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 225,
      "prompt": "Write a function to check if all elements in a list are the same.",
      "teacher_output": "def is_all_same(l):\n    return all(x == y for x, y in zip(l, l[1:]))",
      "base_output": "def all_equal(lst):\n    return all(x == lst[0] for x in lst) if lst else True",
      "teacher_ppl": 1.5386907294160799,
      "base_ppl": 2.0584069769720323,
      "ppl_diff": -0.5197162475559525,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 226,
      "prompt": "Write a function to count the number of capital letters in a string.",
      "teacher_output": "def count_of_capital_letter(string):\n    return sum(1 for c in string if c.isupper())",
      "base_output": "def count_capitals(s):\n    return sum(1 for c in s if c.isupper())",
      "teacher_ppl": 2.008643031553474,
      "base_ppl": 1.6946961429813263,
      "ppl_diff": 0.3139468885721475,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 227,
      "prompt": "Write a function to find the second smallest number in a list.",
      "teacher_output": "def find_second_smallest(nums):\n    return min(nums[1:], key=lambda x: x != nums[0])",
      "base_output": "def second_smallest(lst):\n    return sorted(set(lst))[1] if len(set(lst)) >= 2 else None",
      "teacher_ppl": 1.7951790390470654,
      "base_ppl": 2.179779577491278,
      "ppl_diff": -0.3846005384442124,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 228,
      "prompt": "Write a function to return the first n Fibonacci numbers.",
      "teacher_output": "def fibonacci(n):\n    if n == 0:\n        return 0\n    if n == 1:\n        return 1\n    return fibonacci(n-1) + fibonacci(n-2)",
      "base_output": "def fibonacci(n):\n    a, b = 0, 1\n    result = []\n    for _ in range(n):\n        result.append(a)\n        a, b = b, a + b\n    return result",
      "teacher_ppl": 1.2537032570888467,
      "base_ppl": 1.4228577842942114,
      "ppl_diff": -0.16915452720536472,
      "filter_reason": "Base PPL too low"
    },
    {
      "index": 230,
      "prompt": "Write a function to remove the first and last characters of a string.",
      "teacher_output": "def remove_first_and_last_char(string):\nreturn string[:-1] + string[1:]",
      "base_output": "def remove_ends(s):\n    return s[1:-1] if len(s) >= 2 else ''",
      "teacher_ppl": 1.7928010125464087,
      "base_ppl": 2.356747198696214,
      "ppl_diff": -0.5639461861498054,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 231,
      "prompt": "Write a function to flatten a list of tuples.",
      "teacher_output": "def flatten(l):\n    return reduce(lambda x,y:x+y,l)",
      "base_output": "def flatten_tuples(lst):\n    return [item for tup in lst for item in tup]",
      "teacher_ppl": 1.9768842042862294,
      "base_ppl": 1.9794536644760077,
      "ppl_diff": -0.0025694601897783276,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 232,
      "prompt": "Write a function to check if a list is a palindrome.",
      "teacher_output": "def isPalindrome(l):\n    return (str(l) == str(l)[::-1])",
      "base_output": "def is_list_palindrome(lst):\n    return lst == lst[::-1]",
      "teacher_ppl": 1.817816622113385,
      "base_ppl": 2.109672168084154,
      "ppl_diff": -0.291855545970769,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 233,
      "prompt": "Write a function to return the unique elements of a list, preserving order.",
      "teacher_output": "def unique_list(l):\n    return (set(l))",
      "base_output": "def unique_ordered(lst):\n    seen = set()\n    result = []\n    for x in lst:\n        if x not in seen:\n            seen.add(x)\n            result.append(x)\n    return result",
      "teacher_ppl": 2.0672023090495135,
      "base_ppl": 1.5513995513482082,
      "ppl_diff": 0.5158027577013053,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 236,
      "prompt": "Write a function to convert a list of strings to uppercase.",
      "teacher_output": "def to_upper(str_list):",
      "base_output": "def to_uppercase(lst):\n    return [s.upper() for s in lst]",
      "teacher_ppl": 2.2034264011697724,
      "base_ppl": 1.6848316488311093,
      "ppl_diff": 0.5185947523386631,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 237,
      "prompt": "Write a function to check if all elements in a list are distinct.",
      "teacher_output": "def is_all_distinct(nums):",
      "base_output": "def all_distinct(lst):\n    return len(lst) == len(set(lst))",
      "teacher_ppl": 2.2779997511689403,
      "base_ppl": 1.5472275018849504,
      "ppl_diff": 0.7307722492839899,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 238,
      "prompt": "Write a function to return the ASCII value of each character in a string.",
      "teacher_output": "def get_ascii_value(string):\n    return sum(ord(c) for c in string)",
      "base_output": "def ascii_values(s):\n    return [ord(c) for c in s]",
      "teacher_ppl": 1.7460086120508866,
      "base_ppl": 1.7190372460392063,
      "ppl_diff": 0.026971366011680376,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 239,
      "prompt": "Write a function to count how many booleans are True in a list.",
      "teacher_output": "def count_of_booleans(list_of_booleans):",
      "base_output": "def count_true(lst):\n    return sum(1 for x in lst if x is True)",
      "teacher_ppl": 1.9857702142752398,
      "base_ppl": 1.8662819693714887,
      "ppl_diff": 0.1194882449037511,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 240,
      "prompt": "Write a function to return the index of the first maximum in a list.",
      "teacher_output": "def first_max_index(nums):\n    return 0",
      "base_output": "def first_max_index(lst):\n    return lst.index(max(lst)) if lst else -1",
      "teacher_ppl": 2.3090032092511126,
      "base_ppl": 2.0677157778810016,
      "ppl_diff": 0.241287431370111,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 241,
      "prompt": "Write a function to group words in a list by their starting letter.",
      "teacher_output": "def word_groups(words):",
      "base_output": "from collections import defaultdict\n\ndef group_by_first_letter(words):\n    d = defaultdict(list)\n    for word in words:\n        if word:\n            d[word[0]].append(word)\n    return dict(d)",
      "teacher_ppl": 2.230917532868984,
      "base_ppl": 1.7162485155862521,
      "ppl_diff": 0.5146690172827317,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 242,
      "prompt": "Write a function to calculate the cumulative sum of a list.",
      "teacher_output": "def cumsum(l):\n    return sum(l)",
      "base_output": "def cumulative_sum(lst):\n    result, total = [], 0\n    for x in lst:\n        total += x\n        result.append(total)\n    return result",
      "teacher_ppl": 2.1100183704985906,
      "base_ppl": 1.7157975874323785,
      "ppl_diff": 0.3942207830662121,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 243,
      "prompt": "Write a function to check if a number has repeated digits.",
      "teacher_output": "def is_repeated_digit(num):",
      "base_output": "def has_repeated_digits(n):\n    digits = str(abs(n))\n    return len(set(digits)) != len(digits)",
      "teacher_ppl": 2.0510612649930957,
      "base_ppl": 2.014022140653708,
      "ppl_diff": 0.03703912433938772,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 244,
      "prompt": "Write a function to calculate the number of vowels in a given string.",
      "teacher_output": "def count_vowels(str_arg):\n    return sum(1 for c in str_arg if c.lower() in 'aeiou')",
      "base_output": "def count_vowels(s):\n    return sum(1 for c in s.lower() if c in 'aeiou')",
      "teacher_ppl": 1.7455714012217645,
      "base_ppl": 1.774768155370247,
      "ppl_diff": -0.02919675414848255,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 245,
      "prompt": "Write a function to get the largest key in a dictionary.",
      "teacher_output": "def get_max_key(d):\n    return max(d.keys())",
      "base_output": "def max_dict_key(d):\n    return max(d) if d else None",
      "teacher_ppl": 1.6430378654316304,
      "base_ppl": 3.1186534458292066,
      "ppl_diff": -1.4756155803975761,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 246,
      "prompt": "Write a function to check whether a string has any repeated characters.",
      "teacher_output": "def is_string_has_repeated_char(str_arg):",
      "base_output": "def has_repeats(s):\n    return len(set(s)) != len(s)",
      "teacher_ppl": 2.4769846620665246,
      "base_ppl": 1.8633987517921209,
      "ppl_diff": 0.6135859102744037,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 247,
      "prompt": "Write a function to reverse the digits of a number.",
      "teacher_output": "def reverse_num(num):\n    return int(str(num)[::-1])",
      "base_output": "def reverse_number(n):\n    sign = -1 if n < 0 else 1\n    return sign * int(str(abs(n))[::-1])",
      "teacher_ppl": 1.5401778699785444,
      "base_ppl": 1.6434901885511854,
      "ppl_diff": -0.103312318572641,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 248,
      "prompt": "Write a function to check if a number is a palindrome.",
      "teacher_output": "def isPalindrome(num):\n    if (num == num[::-1]):\n        return True\n    else:\n        return False",
      "base_output": "def is_palindrome_number(n):\n    s = str(n)\n    return s == s[::-1]",
      "teacher_ppl": 1.5306522666419224,
      "base_ppl": 1.8084591088954238,
      "ppl_diff": -0.2778068422535014,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 249,
      "prompt": "Write a function to return the square root of a number using the Newton-Raphson method.",
      "teacher_output": "def sqrt(x):\nreturn 1.5 * (1 + 1 / (2 * x))",
      "base_output": "def sqrt_newton(n, eps=1e-6):\n    guess = n / 2.0\n    while abs(guess * guess - n) > eps:\n        guess = (guess + n / guess) / 2\n    return guess",
      "teacher_ppl": 2.510999660600308,
      "base_ppl": 1.6371529835228442,
      "ppl_diff": 0.873846677077464,
      "filter_reason": "Teacher PPL too high"
    }
  ],
  "infinite_ppl_samples": []
}