{
  "statistics": {
    "total_samples": 250,
    "filtered_count": 205,
    "filtered_percentage": 82.0,
    "teacher_ppl_stats": {
      "infinite_count": 0,
      "min": 1.1818803633387143,
      "max": 4.868993665044047,
      "mean": 1.8904965154851028,
      "median": 1.7805986811402656
    },
    "base_ppl_stats": {
      "infinite_count": 0,
      "min": 1.6610724934861496,
      "max": 16.803720513440936,
      "mean": 6.428016543345549,
      "median": 6.319802126906612
    },
    "ppl_diff_stats": {
      "infinite_count": 0,
      "min": -14.896597510449832,
      "max": 0.6400835489181333,
      "mean": -4.537520027860447,
      "median": -4.260511439894224
    }
  },
  "category_breakdown": {
    "Much Better (Teacher << Base)": [
      {
        "index": 1,
        "prompt": "Write a function that returns the factorial of a number recursively.",
        "teacher_output": "def recursive_factorial(n):\r\n  if n == 0:\r\n    return 1\r\n  else:\r\n    return n * recursive_factorial(n-1)",
        "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    else:\n        return n * recursive_factorial(n-1)\n\n#### -1",
        "teacher_ppl": 1.4482296851466767,
        "base_ppl": 2.878866060087549,
        "ppl_diff": -1.4306363749408724,
        "would_be_filtered": false
      },
      {
        "index": 2,
        "prompt": "Write a function to count the number of vowels in a string.",
        "teacher_output": "def count_vowels(s):\r\n  count = 0\r\n  for c in s:\r\n    if c.lower() in 'aeiou':\r\n      count += 1\r\n  return count",
        "base_output": "def count_vowels(s):\n    # ...\n    return len(s) - len(s.replace('aeiou', ''))",
        "teacher_ppl": 1.30476210053308,
        "base_ppl": 3.3984962241640426,
        "ppl_diff": -2.093734123630963,
        "would_be_filtered": false
      },
      {
        "index": 3,
        "prompt": "Write a function to reverse a list without using built-in reverse().",
        "teacher_output": "def reverse_list(list1):\r\n  return list1[::-1]\r\ndef test_reverse_list():\r\n  import doctest\r\n  doctest.testmod()",
        "base_output": "def reverse_list(list):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.9083033284830557,
        "base_ppl": 6.324244427431658,
        "ppl_diff": -4.415941098948602,
        "would_be_filtered": true
      },
      {
        "index": 4,
        "prompt": "Write a function to convert a binary string to an integer.",
        "teacher_output": "def binary_to_int(s):\r\n    return int(s, 2)",
        "base_output": "def binary_to_int(binary_str):\n    # Your code here\n    return 0\n#### 0",
        "teacher_ppl": 2.0861168084681836,
        "base_ppl": 6.859188429015234,
        "ppl_diff": -4.77307162054705,
        "would_be_filtered": true
      },
      {
        "index": 5,
        "prompt": "Write a function to compute the square root of a number using the Newton-Raphson method.",
        "teacher_output": "import math\ndef sqrt_newton(n):\r\n  if n == 0:\r\n    return 0\r\n  else:\r\n    return 1 / (n * math.sqrt(n - 1))\r\ndef test_sqrt_newton():\r\n  import unittest\r\n  def test_case(self):\r\n    n = 4\r\n    result = sqrt_newton(n)\r\n    self.assertTrue(abs(result - 2) < 1e-6)\r\n    n = 9\r\n    result",
        "base_output": "def square_root(x):\n    return x ** 0.5\n#### 0.5",
        "teacher_ppl": 1.7772551035047497,
        "base_ppl": 8.023907916074565,
        "ppl_diff": -6.246652812569815,
        "would_be_filtered": true
      },
      {
        "index": 6,
        "prompt": "Write a function to flatten a nested list.",
        "teacher_output": "def flatten_list(list1):\r\n  res = list1\r\n  while res:\r\n    res = [*res] + res[1:]\r\n  return res\r\n\r\ndef test_flatten_list():\r\n  import doctest\r\n  doctest.testmod()\r\n  return\r\n\r\ndef main():\r\n  test_flatten_list()\r\n  return\r\n\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
        "base_output": "def flatten_list(list):\n    # Your code here\n    return list",
        "teacher_ppl": 1.8355148499142568,
        "base_ppl": 6.101198191962493,
        "ppl_diff": -4.265683342048236,
        "would_be_filtered": true
      },
      {
        "index": 7,
        "prompt": "Write a function to remove duplicates from a list while preserving order.",
        "teacher_output": "def remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):",
        "base_output": "def remove_duplicates(list):\n    # Your code goes here\n    return list",
        "teacher_ppl": 1.1818803633387143,
        "base_ppl": 4.670049987917682,
        "ppl_diff": -3.488169624578968,
        "would_be_filtered": false
      },
      {
        "index": 8,
        "prompt": "Write a function to check if a given string is a palindrome.",
        "teacher_output": "import unittest\ndef is_palindrome(s):\r\n  s = s.lower()\r\n  for i in range(0, len(s), 2):\r\n    if s[i] != s[i + 1]:\r\n      return False\r\n  return True\r\ndef test_palindrome():\r\n  unittest.main()\r\n[END]",
        "base_output": "def is_palindrome(s):\n    # ...\n    return ...",
        "teacher_ppl": 1.6714455000903503,
        "base_ppl": 8.506131849507057,
        "ppl_diff": -6.834686349416707,
        "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):\r\n  if n <= 0:\r\n    return 0\r\n  return n * (n + 1) / 2\r\n[END]",
        "base_output": "def sum_of_squares(n):\n    return sum(x**2 for x in range(n))\n#### 2",
        "teacher_ppl": 2.1475967953009696,
        "base_ppl": 4.064686774753795,
        "ppl_diff": -1.9170899794528258,
        "would_be_filtered": true
      },
      {
        "index": 10,
        "prompt": "Write a function to interleave two lists of equal length.",
        "teacher_output": "def interleave_lists(list1, list2):\r\n  result = list1 + list2\r\n  return result\r\ndef test_interleave_lists():\r\n  result = interleave_lists([1,2], ['a','b'])\r\n  assert result == [1,'a',2,'b']\r\n  result = interleave_lists([], [])\r\n  assert result == []\r\n  result = interleave_lists([0,0], [1,1])\r\n  assert result == [0,1,0,",
        "base_output": "def interleave_lists(list1, list2):\n    return list(zip(list1, list2))\n#### 2",
        "teacher_ppl": 1.9479303145538356,
        "base_ppl": 3.6552608063556655,
        "ppl_diff": -1.70733049180183,
        "would_be_filtered": true
      },
      {
        "index": 11,
        "prompt": "Write a function to get all even numbers from a list.",
        "teacher_output": "def extract_even(nums):\r\n  return [x for x in nums if x % 2 == 0]\r\n\r\n def test_extract_even():\r\n  nums = [1,2,3,4]\r\n  result = extract_even(nums)\r\n  assert result == [2,4]\r\n  nums = [1,3,5]\r\n  result = extract_even(nums)\r\n  assert result == []\r\n  nums = [2,4,6]\r\n  result = extract_even",
        "base_output": "def extract_even(numbers):\n    # Your code here\n    return # Return the list of even numbers",
        "teacher_ppl": 1.7040293264339472,
        "base_ppl": 10.396399923203875,
        "ppl_diff": -8.692370596769928,
        "would_be_filtered": true
      },
      {
        "index": 12,
        "prompt": "Write a function that checks whether a given year is a leap year.",
        "teacher_output": "import datetime\n\ndef is_leap_year(year):\r\n    if year % 4 == 0 and year % 100 != 0:\r\n        return True\r\n    elif year % 400 == 0:\r\n        return True\r\n    else:\r\n        return False\r\n\r\nassert is_leap_year(2000) == True\r\nassert is_leap_year(1900) == False\r\nassert is_leap_year(2024) == True\r\n[END]",
        "base_output": "def is_leap_year(year):\n    # ...\n    return year % 4 == 0 and year % 100 != 0 or year % 400 == 0\n#### 0",
        "teacher_ppl": 1.5443171910363631,
        "base_ppl": 3.3099109684908368,
        "ppl_diff": -1.7655937774544737,
        "would_be_filtered": true
      },
      {
        "index": 13,
        "prompt": "Write a function to compute the GCD of two numbers.",
        "teacher_output": "def gcd(a, b):\r\n    if b == 0:\r\n        return a\r\n    return gcd(b, a % b)",
        "base_output": "def gcd(a, b):\n    if b == 0:\n        return a\n    else:\n        return gcd(b, a % b)\n#### 0",
        "teacher_ppl": 1.349561183704888,
        "base_ppl": 2.4402144114119486,
        "ppl_diff": -1.0906532277070606,
        "would_be_filtered": false
      },
      {
        "index": 16,
        "prompt": "Write a function that returns True if all elements in a list are unique.",
        "teacher_output": "def all_unique(list1):\r\n  return len(list1) == len(set(list1))\r\n[END]",
        "base_output": "def all_unique(lst):\n    # ...\n    return True",
        "teacher_ppl": 2.923641040015102,
        "base_ppl": 11.863130637546645,
        "ppl_diff": -8.939489597531542,
        "would_be_filtered": true
      },
      {
        "index": 17,
        "prompt": "Write a function that returns the maximum value in a dictionary.",
        "teacher_output": "def max_dict_value(dct):\r\n  if not dct:\r\n    return 0\r\n  max_value = dct['a']\r\n  for key, value in dct.items():\r\n    if max_value < value:\r\n      max_value = value\r\n  return max_value\r\n\r\n[END]",
        "base_output": "def max_dict_value(dict):\n    return max(dict.values())",
        "teacher_ppl": 1.7921529354821033,
        "base_ppl": 3.554235433858954,
        "ppl_diff": -1.7620824983768506,
        "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(list1):\r\n  return list1\r\ndef test_rotate_left():\r\n  result = rotate_left([1,2,3])\r\n  assert result == [2,3,1]\r\n  result = rotate_left([])\r\n  assert result == []\r\n  result = rotate_left([7])\r\n  assert result == [7]\r\n  return result",
        "base_output": "def rotate_left(list):\n    # do something here\n    return list",
        "teacher_ppl": 2.121775961168867,
        "base_ppl": 6.787862887693958,
        "ppl_diff": -4.666086926525091,
        "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 find_indices(list, value):\r\n    for i, item in enumerate(list):\r\n        if item == value:\r\n            return [i]\r\n    return []\r\n\r\n[END]",
        "base_output": "def find_indices(list, value):\n    # ...\n    return indices",
        "teacher_ppl": 2.00250867028863,
        "base_ppl": 4.6488857237305625,
        "ppl_diff": -2.6463770534419324,
        "would_be_filtered": true
      },
      {
        "index": 20,
        "prompt": "Write a function to get the intersection of two lists.",
        "teacher_output": "def list_intersection(list1, list2):\r\n  if len(list1) == 0 or len(list2) == 0:\r\n    return []\r\n  result = []\r\n  for i in range(len(list1)):\r\n    if list1[i] in list2:\r\n      result.append(list1[i])\r\n  return result\r\n\r\ndef test_list_intersection():\r\n  pass\r\n\r\ndef test_list_intersection_empty_list():\r\n  pass",
        "base_output": "def list_intersection(list1, list2):\n    # ...\n    return intersection\ndef intersection(list1, list2):\n    # ...\n    return list(set(list1) & set(list2))\n#### 2",
        "teacher_ppl": 1.4349018651775822,
        "base_ppl": 3.389811037074686,
        "ppl_diff": -1.9549091718971037,
        "would_be_filtered": false
      },
      {
        "index": 21,
        "prompt": "Write a function to remove all non-digit characters from a string.",
        "teacher_output": "import unittest\n\ndef remove_non_digits(s):\r\n  return ''.join([c for c in s if c.isdigit()])\r\n\r\ndef test_remove_non_digits():\r\n  unittest.main()\r\n[END]",
        "base_output": "def remove_non_digits(s):\n    return s.replace(r'[^0-9]', '')\n#### -9",
        "teacher_ppl": 2.1357935682420432,
        "base_ppl": 5.764516162718697,
        "ppl_diff": -3.6287225944766535,
        "would_be_filtered": true
      },
      {
        "index": 22,
        "prompt": "Write a function to check if a list is sorted in ascending order.",
        "teacher_output": "def is_sorted(list1):\r\n  if len(list1) <= 1:\r\n    return True\r\n  else:\r\n    return sorted(list1) == list1",
        "base_output": "def is_sorted(my_list):\n    # ...\n    return ...",
        "teacher_ppl": 1.6035853928327182,
        "base_ppl": 9.998959343449952,
        "ppl_diff": -8.395373950617234,
        "would_be_filtered": true
      },
      {
        "index": 25,
        "prompt": "Write a function to count the number of capital letters in a string.",
        "teacher_output": "def count_capitals(s):\r\n  count = 0\r\n  for i in s:\r\n    if i.isupper():\r\n      count += 1\r\n  return count",
        "base_output": "def count_capitals(s):\n    \"\"\"\n    Count the number of capital letters in a string.\n    \"\"\"\n    return len([c for c in s if c.isupper()])",
        "teacher_ppl": 1.41322570488969,
        "base_ppl": 2.462049261267745,
        "ppl_diff": -1.0488235563780552,
        "would_be_filtered": false
      },
      {
        "index": 26,
        "prompt": "Write a function to replace all spaces in a string with underscores.",
        "teacher_output": "import unittest\ndef replace_spaces(s):\r\n  return (s.replace(' ','_'))\r\ndef test_replace_spaces():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_replace_spaces()\r\n[END]",
        "base_output": "def replace_spaces(s):\n    return s.replace(b' ', b'_')\n",
        "teacher_ppl": 2.0662786595460503,
        "base_ppl": 4.35706232032667,
        "ppl_diff": -2.29078366078062,
        "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_odds(nums):\r\n  if not nums:\r\n    return 0\r\n  return sum(nums[1::2])\r\ndef test_sum_odds():\r\n  import doctest\r\n  doctest.testmod()",
        "base_output": "def sum_odds(numbers):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.7861568501949248,
        "base_ppl": 7.37944231926095,
        "ppl_diff": -5.593285469066025,
        "would_be_filtered": true
      },
      {
        "index": 28,
        "prompt": "Write a function to multiply all elements in a list together.",
        "teacher_output": "def product(list1):\r\n  return list1 * list1\r\ndef test_product():\r\n  import unittest\r\n  def test_case():\r\n    return product([1,2,3])\r\n  return test_case()\r\ndef test_product2():\r\n  import unittest\r\n  def test_case():\r\n    return product([5])\r\n  return test_case()\r\ndef test_product3():\r\n  import unittest\r\n  def test_case():\r\n    return product([])\r\n  return test_case",
        "base_output": "def product(list):\n    return sum(x * y for x in list for y in list)",
        "teacher_ppl": 1.816159067262555,
        "base_ppl": 4.6714427652306245,
        "ppl_diff": -2.8552836979680696,
        "would_be_filtered": true
      },
      {
        "index": 29,
        "prompt": "Write a function to check whether a number is a perfect square.",
        "teacher_output": "import math\ndef is_perfect_square(n):\r\n  if n <= 0:\r\n    return False\r\n  if n == 0:\r\n    return True\r\n  sq_root = int(math.sqrt(n))\r\n  if sq_root * sq_root == n:\r\n    return True\r\n  return False\r\n[END]",
        "base_output": "def is_perfect_square(n):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.5691305476527304,
        "base_ppl": 8.605526789101553,
        "ppl_diff": -7.036396241448823,
        "would_be_filtered": true
      },
      {
        "index": 30,
        "prompt": "Write a function to swap first and last characters of a string.",
        "teacher_output": "import unittest\n\ndef swap_first_last(s):\r\n  return s[::-1] + s[0] + s[::-1]\r\n\r\ndef test_swap_first_last():\r\n  unittest.main()\r\n\r\nif __name__ == '__main__':\r\n  test_swap_first_last()\r\n\r\n[END]",
        "base_output": "def swap_first_last(s):\n    return s[0] + s[-1]\n#### -1",
        "teacher_ppl": 1.7906632549646881,
        "base_ppl": 6.5788338173661955,
        "ppl_diff": -4.788170562401508,
        "would_be_filtered": true
      },
      {
        "index": 31,
        "prompt": "Write a function to compute the average of a list of numbers.",
        "teacher_output": "def average(nums):\r\n  if not nums:\r\n    return 0\r\n  return sum(nums) / len(nums)",
        "base_output": "def average(numbers):\n    # Your code here\n    return sum(numbers) / len(numbers)",
        "teacher_ppl": 1.6199986899599397,
        "base_ppl": 4.331800698679092,
        "ppl_diff": -2.711802008719152,
        "would_be_filtered": true
      },
      {
        "index": 32,
        "prompt": "Write a function to return the second largest number in a list.",
        "teacher_output": "def second_largest(nums):\r\n  return max(nums[1:], key=lambda x: nums[0])\r\n\r\ndef test_second_largest():\r\n  nums = [1, 2, 3]\r\n  assert second_largest(nums) == 2\r\n  nums = [5, 5, 3]\r\n  assert second_largest(nums) == 3\r\n  nums = [10, 20, 10, 30]",
        "base_output": "def second_largest(numbers):\n    # Your code here\n    return second_largest",
        "teacher_ppl": 1.7090985690582683,
        "base_ppl": 6.162212731501273,
        "ppl_diff": -4.453114162443005,
        "would_be_filtered": true
      },
      {
        "index": 33,
        "prompt": "Write a function to check whether all elements in a list are the same.",
        "teacher_output": "def all_same(list1):\r\n  if len(list1) <= 0:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[i+1] for i in range(len(list1)-1))\r\n\r\ndef test_cases():\r\n  return [\r\n    ('1', '1', '1'),\r\n    ('1', '2', '1'),\r\n    ('', '1')\r\n  ]\r\n\r\ndef test_runner():\r\n  for test in test",
        "base_output": "def all_same(list):\n    # ...\n    return True",
        "teacher_ppl": 1.9664905287872987,
        "base_ppl": 9.30087052124841,
        "ppl_diff": -7.334379992461111,
        "would_be_filtered": true
      },
      {
        "index": 34,
        "prompt": "Write a function to convert a list of integers into a single integer.",
        "teacher_output": "def list_to_int(list):\r\n  if not list:\r\n    return 0\r\n  return sum(list[:])\r\n\r\n[END]",
        "base_output": "def list_to_int(numbers):\n    # Your code here\n    return numbers[0]\n#### 0",
        "teacher_ppl": 2.544083917596053,
        "base_ppl": 10.537121077777787,
        "ppl_diff": -7.993037160181734,
        "would_be_filtered": true
      },
      {
        "index": 36,
        "prompt": "Write a function to calculate the number of digits in a number.",
        "teacher_output": "def count_digits(n):\r\n  if n == 0:\r\n    return 1\r\n  return 10 + count_digits(n // 10)\r\n\r\n[END]",
        "base_output": "def count_digits(n):\n    return len(str(n))",
        "teacher_ppl": 2.082336666979913,
        "base_ppl": 4.238597182644895,
        "ppl_diff": -2.1562605156649823,
        "would_be_filtered": true
      },
      {
        "index": 37,
        "prompt": "Write a function to rotate a list k times to the right.",
        "teacher_output": "def rotate_right(list1, k):\r\n  n = len(list1)\r\n  if n <= k:\r\n    return list1[:k] + list1[k:]\r\n  else:\r\n    return [list1[k-n+1:k] + list1[k-n] + rotate_right(list1[k-n:], k-n) for k in range(n-1)] + [list1[k-n] + rotate_right(list1[k-n:], k-n)]\r\n\r\ndef",
        "base_output": "def rotate_right(list, k):\n    # Your code here\n    pass",
        "teacher_ppl": 1.6139368144926876,
        "base_ppl": 4.89249669971073,
        "ppl_diff": -3.2785598852180424,
        "would_be_filtered": true
      },
      {
        "index": 39,
        "prompt": "Write a function to rotate a square matrix 90 degrees clockwise.",
        "teacher_output": "import unittest\ndef rotate_matrix(m):\r\n  n = len(m)\r\n  return [[m[i][j] for j in range(n)] for i in range(n)]\r\ndef test_rotate_matrix():\r\n  m = [[1,2], [3,4]]\r\n  assert rotate_matrix(m) == [[3,1], [4,2]]\r\n  m = [[1]]\r\n  assert rotate_matrix(m) == [[1]]\r\n  m = [[1,2,3], [4,5,",
        "base_output": "def rotate_matrix(matrix):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.5339355460940844,
        "base_ppl": 5.509826812775041,
        "ppl_diff": -3.975891266680957,
        "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": "import re\r\ndef valid_palindrome(text):\r\n  text = text.lower()\r\n  text = re.sub('[^a-zA-Z0-9]', '', text)\r\n  return text == text[::-1]\r\n[END]",
        "base_output": "def valid_palindrome(s):\n    # ...\n    return True",
        "teacher_ppl": 2.0355684471970594,
        "base_ppl": 6.113229739924781,
        "ppl_diff": -4.077661292727721,
        "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_sorted_lists(list1, list2):\r\n  n1 = len(list1)\r\n  n2 = len(list2)\r\n  result = [None] * (n1 + n2)\r\n  i = 0\r\n  j = 0\r\n  while i < n1 and j < n2:\r\n    if list1[i] <= list2[j]:\r\n      result[i + j - 1] = list1[i]\r\n      i += 1\r\n    else:\r\n      result[i +",
        "base_output": "def merge_sorted_lists(list1, list2):\n    # Your code here\n    pass\n#### 2",
        "teacher_ppl": 1.2417778344514006,
        "base_ppl": 7.747530579869447,
        "ppl_diff": -6.505752745418047,
        "would_be_filtered": false
      },
      {
        "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(list):\r\n def count_element(list, element):\r\n    count = 0\r\n    for i in range(len(list)):\r\n        if element == list[i]:\r\n            count += 1\r\n    return count\r\n def majority_element(list):\r\n    if len(list) < 2:\r\n        return -1\r\n    count = count_element(list, element = 0)\r\n    for i in range(1, len(list)):\r\n        count += count_element(list, element =",
        "base_output": "def majority_element(list):\n    # Write your code here\n    return",
        "teacher_ppl": 1.3709063517186084,
        "base_ppl": 5.369575766383128,
        "ppl_diff": -3.998669414664519,
        "would_be_filtered": false
      },
      {
        "index": 45,
        "prompt": "Write a function to transpose a matrix.",
        "teacher_output": "import unittest\ndef transpose_matrix(matrix):\r\n  n = len(matrix)\r\n  if n == 0:\r\n    return []\r\n  return [[matrix[i][j]] for i in range(n) for j in range(i)]\r\ndef test_transpose_matrix():\r\n  unittest.main()\r\n  return\r\ndef main():\r\n  test_transpose_matrix()\r\n  return\r\nif __name__ == '__main__':\r\n  main()\r\nelse:\r\n  main()",
        "base_output": "def transpose_matrix(matrix):\n    return matrix.T",
        "teacher_ppl": 1.780840525177098,
        "base_ppl": 5.744590403858477,
        "ppl_diff": -3.963749878681379,
        "would_be_filtered": true
      },
      {
        "index": 46,
        "prompt": "Write a function to calculate the running total of a list.",
        "teacher_output": "def running_total(numbers):\r\n  running_total = 0\r\n  for num in numbers:\r\n    running_total += num\r\n  return running_total",
        "base_output": "def running_total(numbers):\n    running_total = 0\n    for num in numbers:\n        running_total += num\n    return running_total\n#### 0",
        "teacher_ppl": 1.526462678004621,
        "base_ppl": 2.9310827658247574,
        "ppl_diff": -1.4046200878201363,
        "would_be_filtered": true
      },
      {
        "index": 47,
        "prompt": "Write a function to return True if a list contains duplicates, False otherwise.",
        "teacher_output": "def has_duplicates(list1):\r\n  for i in range(len(list1)):\r\n    for j in range(i+1, len(list1)):\r\n      if list1[i] == list1[j]:\r\n        return True\r\n    return False\r\ndef main():\r\n  return has_duplicates(['a', 'b', 'c', 'a', 'd', 'e', 'f', 'g', 'h', 'i', 'j'])",
        "base_output": "def has_duplicates(lst):\n    # ...\n    return False",
        "teacher_ppl": 1.6677942932837022,
        "base_ppl": 10.915169302358043,
        "ppl_diff": -9.247375009074341,
        "would_be_filtered": true
      },
      {
        "index": 48,
        "prompt": "Write a function to compute the dot product of two vectors.",
        "teacher_output": "def dot_product(a, b):\r\n  return sum(i * j for i, j in zip(a, b))\r\n\r\ndef test_dot_product():\r\n  a = [1, 2, 3]\r\n  b = [4, 5, 6]\r\n  assert dot_product(a, b) == 32\r\n  a = [0, 0, 0]\r\n  b = [1, 2, 3]\r\n  assert dot_product(a, b) == 0",
        "base_output": "def dot_product(v1, v2):\n    return sum(i * j for i in v1 for j in v2)\n#### 2",
        "teacher_ppl": 1.3248008803659779,
        "base_ppl": 3.279841531603811,
        "ppl_diff": -1.955040651237833,
        "would_be_filtered": false
      },
      {
        "index": 49,
        "prompt": "Write a function to implement a basic Caesar cipher encryption.",
        "teacher_output": "def caesar_cipher(text, shift):\n    result = \"\"\n    for i in range(len(text)):\n        if text[i] == ' ':\n            result += \" \"\n        else:\n            result += str(ord(text[i]) + shift)\n    return result\n\ndef test_caesar_cipher():\n    assert caesar_cipher('abc', 1) == 'bcd'\n    assert caesar_cipher('XYZ', 2) == 'ZAB'\n    assert caesar_cipher('Hello,",
        "base_output": "def caesar_cipher(message, shift):\n    # Your code here\n    pass\n",
        "teacher_ppl": 1.9910567584604972,
        "base_ppl": 4.885456202604053,
        "ppl_diff": -2.8943994441435557,
        "would_be_filtered": true
      },
      {
        "index": 50,
        "prompt": "Write a function to calculate the number of trailing zeroes in n factorial.",
        "teacher_output": "import unittest\n\ndef trailing_zeroes(n):\r\n  if n == 0:\r\n    return 0\r\n  return 1 + max(trailing_zeroes(n-1), 0)",
        "base_output": "def trailing_zeroes(n):\n    # Your code here\n    return 0\n#### 0",
        "teacher_ppl": 1.8306595398451164,
        "base_ppl": 15.604483142093475,
        "ppl_diff": -13.773823602248358,
        "would_be_filtered": true
      },
      {
        "index": 51,
        "prompt": "Write a function to group a list of words by their anagram equivalence.",
        "teacher_output": "def group_anagrams(wordlist):\r\n    result = {}\r\n    for i in range(len(wordlist)):\r\n        for j in range(i+1, len(wordlist)):\r\n            if wordlist[i] == wordlist[j]:\r\n                result[wordlist[i]] = result.get(wordlist[i], []) + [wordlist[j]]\r\n            else:\r\n                result[wordlist[i]] = result.get(wordlist[i], []) + [wordlist[j]]\r\n    return",
        "base_output": "def group_anagrams(words):\n    # ...\n    return ...",
        "teacher_ppl": 1.2190241051049302,
        "base_ppl": 7.681032319972422,
        "ppl_diff": -6.462008214867492,
        "would_be_filtered": false
      },
      {
        "index": 52,
        "prompt": "Write a function to find the second smallest unique number in a list.",
        "teacher_output": "def second_smallest(nums):\r\n  if len(nums) <= 1:\r\n    return None\r\n  return min(nums[1:], key=lambda x: x)\r\n\r\n[END]",
        "base_output": "def second_smallest(numbers):\n    # ...\n    return numbers[1]\n#### 1",
        "teacher_ppl": 1.9016955983628179,
        "base_ppl": 9.918636234503452,
        "ppl_diff": -8.016940636140635,
        "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(s):\r\n    if len(s) < 2:\r\n        return True\r\n    for i in range(1, len(s) - 1):\r\n        if s[i] == s[i - 1]:\r\n            return False\r\n    return True\r\ndef test_is_isogram():\r\n    import doctest\r\n    doctest.testmod()",
        "base_output": "def is_isogram(s):\n    # ...\n    return None",
        "teacher_ppl": 1.376368032094219,
        "base_ppl": 8.46115094917785,
        "ppl_diff": -7.08478291708363,
        "would_be_filtered": false
      },
      {
        "index": 54,
        "prompt": "Write a function to return the transpose of a jagged (non-square) matrix.",
        "teacher_output": "import unittest\ndef transpose_jagged(matrix):\r\n  n = len(matrix)\r\n  m = max(n, 1)\r\n  result = [list(chain(*row)) for row in itertools.izip_nonstop(iter(matrix), itertools.count(1))]\r\n  return result\r\ndef test_transpose_jagged():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_transpose_jagged()",
        "base_output": "def transpose_jagged(matrix):\n    # ...\n    return matrix",
        "teacher_ppl": 2.1218201842611077,
        "base_ppl": 7.143651197268293,
        "ppl_diff": -5.021831013007185,
        "would_be_filtered": true
      },
      {
        "index": 55,
        "prompt": "Write a function to count pairs in a list that sum to a given target.",
        "teacher_output": "def count_pairs_with_sum(nums, target):\r\n    count = 0\r\n    for i in range(len(nums)):\r\n        for j in range(i+1, len(nums)):\r\n            if nums[i] + nums[j] == target:\r\n                count += 1\r\n    return count",
        "base_output": "def count_pairs_with_sum(numbers, target):\n    # ...\n    return len(set(combinations(numbers, 2)))\n#### 2",
        "teacher_ppl": 1.2997734860957333,
        "base_ppl": 4.593091975344846,
        "ppl_diff": -3.2933184892491125,
        "would_be_filtered": false
      },
      {
        "index": 56,
        "prompt": "Write a function to reverse the words in a sentence.",
        "teacher_output": "def reverse_words(s):\r\n  return ' '.join(s.split())\r\n[END]",
        "base_output": "def reverse_words(sentence):\n    return sentence[::-1]\n#### -1",
        "teacher_ppl": 3.539560560583818,
        "base_ppl": 6.909519863466939,
        "ppl_diff": -3.3699593028831214,
        "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(list1):\r\n    if not list1:\r\n        return ''\r\n    max_len = 0\r\n    for i in range(len(list1)):\r\n        if list1[i] == ' ':\r\n            continue\r\n        max_len = max(max_len, len(list1[i]))\r\n    return (max_len - 1) * ' '\r\ndef test_longest_common_prefix():\r\n    assert longest_common_prefix(['flower','flow','flight']) ==",
        "base_output": "def longest_common_prefix(strings):\n    # Your code goes here\n    return None",
        "teacher_ppl": 1.6963097222199652,
        "base_ppl": 5.105788243651484,
        "ppl_diff": -3.4094785214315193,
        "would_be_filtered": true
      },
      {
        "index": 58,
        "prompt": "Write a function to check if a number is a Harshad number.",
        "teacher_output": "import math\ndef is_harshad_number(n):\r\n\tif n == 0:\r\n\t\treturn False\r\n\tif n == 1:\r\n\t\treturn True\r\n\tif n % 2 == 0:\r\n\t\treturn False\r\n\tif n == int(n):\r\n\t\treturn False\r\n\tif n == int(n * 2):\r\n\t\treturn False\r\n\tif n == int(n * 3):\r\n\t\treturn False\r\n\tif n == int(n * 4",
        "base_output": "def is_harshad_number(n):\n    # Write your code here\n    return",
        "teacher_ppl": 1.4162671735092316,
        "base_ppl": 4.955887613746039,
        "ppl_diff": -3.539620440236807,
        "would_be_filtered": false
      },
      {
        "index": 59,
        "prompt": "Write a function to count the frequency of characters in a string.",
        "teacher_output": "def char_frequency(s):\r\n  count = {}\r\n  for i in s:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n\r\ndef test_char_frequency():\r\n  test_cases = [\r\n      (\"aabbc\", {\"a\": 2, \"b\": 2, \"c\": 1}),\r\n      (\"\", {\"\"}),\r\n      (\"aaa\", {\"a\": 3})\r\n  ]\r\n  for test in test_cases:",
        "base_output": "def char_frequency(s):\n    # ...\n    return ...",
        "teacher_ppl": 1.6753775160599063,
        "base_ppl": 12.116180832408222,
        "ppl_diff": -10.440803316348315,
        "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 diagonal_sum(matrix):\r\n  n = len(matrix)\r\n  sum = 0\r\n  for i in range(n):\r\n    sum += matrix[i][i]\r\n  return sum",
        "base_output": "def diagonal_sum(matrix):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.5592908545667412,
        "base_ppl": 8.852759237559443,
        "ppl_diff": -7.293468382992701,
        "would_be_filtered": true
      },
      {
        "index": 61,
        "prompt": "Write a function to check if a string has all unique characters.",
        "teacher_output": "import unittest\ndef has_all_unique(s):\r\n  return len(set(s)) == len(s)\r\ndef test_has_all_unique():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_all_unique()\r\n[END]",
        "base_output": "def has_all_unique(s):\n    # ...\n    return len(s) == len(set(s))",
        "teacher_ppl": 2.1957378977908677,
        "base_ppl": 4.394349451122715,
        "ppl_diff": -2.1986115533318475,
        "would_be_filtered": true
      },
      {
        "index": 62,
        "prompt": "Write a function to remove duplicate dictionaries from a list.",
        "teacher_output": "import unittest\n\ndef remove_duplicate_dicts(list_of_dicts):\r\n  return list(set(dict(d) for d in list_of_dicts))\r\n\r\ndef test_remove_duplicate_dicts():\r\n  list_of_dicts = [{'a':1}, {'a':1}, {'b':2}, {'x':1}, {'x':2}]\r\n  result = remove_duplicate_dicts(list_of_dicts)\r\n  unittest.assertEqual(result, [{'a':",
        "base_output": "def remove_duplicate_dicts(lst):\n    return [d for d in lst if d not in lst[:len(lst)-1]]\n#### -1",
        "teacher_ppl": 1.6516642589251558,
        "base_ppl": 4.765443830716784,
        "ppl_diff": -3.113779571791628,
        "would_be_filtered": true
      },
      {
        "index": 63,
        "prompt": "Write a function to split a list into chunks of size n.",
        "teacher_output": "def chunk_list(list, n):\r\n  if not n:\r\n    return list\r\n  return list[::n] + list[1:n]\r\ndef test_chunk_list():\r\n  assert chunk_list([1,2,3,4,5], 2) == [[1,2],[3,4],[5]]\r\n  assert chunk_list([], 3) == []\r\n  assert chunk_list([1,2], 1) == [[1],[2]]\r\ntest_chunk_list()",
        "base_output": "def chunk_list(list, n):\n    # Your code here\n    pass",
        "teacher_ppl": 2.16395322226062,
        "base_ppl": 6.101823962288806,
        "ppl_diff": -3.9378707400281865,
        "would_be_filtered": true
      },
      {
        "index": 64,
        "prompt": "Write a function to return the most common element in a list.",
        "teacher_output": "def most_common(list1):\r\n  if len(list1) <= 1:\r\n    return list1[0]\r\n  else:\r\n    return max(list1, key=lambda ele: most_common(list1[1:]))\r\n\r\ndef test_most_common():\r\n  t = [1,2,2,3]\r\n  assert most_common(t) == 2\r\n  t = ['a', 'b', 'b', 'a', 'a']\r\n  assert most_common(t) ==",
        "base_output": "def most_common(list):\n    # Write code here\n    return None",
        "teacher_ppl": 1.7622742483715261,
        "base_ppl": 5.987065802218815,
        "ppl_diff": -4.2247915538472895,
        "would_be_filtered": true
      },
      {
        "index": 65,
        "prompt": "Write a function to check if one string is a rotation of another.",
        "teacher_output": "import re\r\ndef is_rotation(s1, s2):\r\n    return re.search(r'^(?!.*?\\1)(\\1)$', s2) is not None\r\n[END]",
        "base_output": "def is_rotation(str1, str2):\n    # ...\n    return True\n#### 2",
        "teacher_ppl": 2.98422031898581,
        "base_ppl": 7.093832908153107,
        "ppl_diff": -4.109612589167297,
        "would_be_filtered": true
      },
      {
        "index": 66,
        "prompt": "Write a function to compute the digital root of a number.",
        "teacher_output": "import sys\ndef digital_root(n):\r\n  if n <= 0:\r\n    return 0\r\n  else:\r\n    return 10 * digital_root(n // 10) + n % 10\r\ndef test_cases():\r\n  return [('456', 6), ('9', 9), ('0', 0)]\r\ndef main():\r\n  for test in test_cases():\r\n    result = digital_root(test[1])\r\n    if result != test[2]:\r\n      print",
        "base_output": "def digital_root(n):\n    # Your code goes here\n    return None\n",
        "teacher_ppl": 1.768778985980437,
        "base_ppl": 9.160335328345134,
        "ppl_diff": -7.391556342364697,
        "would_be_filtered": true
      },
      {
        "index": 67,
        "prompt": "Write a function to compute the cumulative product of a list.",
        "teacher_output": "def cumulative_product(list1):\r\n  if not list1:\r\n    return [1] * len(list1)\r\n  else:\r\n    return [1] * (len(list1) - 1) + cumulative_product(list1[1:])\r\n\r\ndef test_cumulative_product():\r\n  result = cumulative_product([1,2,3])\r\n  assert result == [1,2,6]\r\n  result = cumulative_product([4,1,0])\r\n  assert result ==",
        "base_output": "def cumulative_product(numbers):\n    # Your code goes here\n    pass\n",
        "teacher_ppl": 1.8093770074626438,
        "base_ppl": 6.790088982117972,
        "ppl_diff": -4.980711974655328,
        "would_be_filtered": true
      },
      {
        "index": 68,
        "prompt": "Write a function to check if a string is a pangram.",
        "teacher_output": "def is_pangram(s):\r\n  for i in range(len(s)):\r\n    if s[i].isalpha():\r\n      continue\r\n    return False\r\n  return True\r\n[END]",
        "base_output": "def is_pangram(s):\n    # ...\n    return ...",
        "teacher_ppl": 2.457733803380163,
        "base_ppl": 8.15969001057161,
        "ppl_diff": -5.701956207191447,
        "would_be_filtered": true
      },
      {
        "index": 69,
        "prompt": "Write a function to calculate the hamming distance between two strings.",
        "teacher_output": "import re\ndef hamming_distance(str1, str2):\r\n    m = 0\r\n    for i in range(len(str1)):\r\n        if str1[i] != str2[i]:\r\n            m = 1\r\n            break\r\n    return m",
        "base_output": "def hamming_distance(str1, str2):\n    # ...\n    return 0\n#### 0",
        "teacher_ppl": 1.4717883474520663,
        "base_ppl": 7.548333700696909,
        "ppl_diff": -6.076545353244843,
        "would_be_filtered": false
      },
      {
        "index": 70,
        "prompt": "Write a function to return the minimum value in a dictionary based on its values.",
        "teacher_output": "def min_dict_value(dct):\r\n  return min(dct.values())\r\n  \r\ndef test_min_dict_value():\r\n  result = min_dict_value({'a': 5, 'b': 3})\r\n  assert result == 3\r\n  result = min_dict_value({'x': -1, 'y': 0})\r\n  assert result == -1\r\n  result = min_dict_value({})\r\n  assert result == None",
        "base_output": "def min_dict_value(dict):\n    # Your code here\n    return None",
        "teacher_ppl": 1.7633254367354305,
        "base_ppl": 6.874076109723478,
        "ppl_diff": -5.110750672988047,
        "would_be_filtered": true
      },
      {
        "index": 71,
        "prompt": "Write a function to check if two strings are anagrams.",
        "teacher_output": "def are_anagrams(s1, s2):\r\n  s1 = s1.lower()\r\n  s2 = s2.lower()\r\n  return sorted(s1) == sorted(s2)",
        "base_output": "def are_anagrams(str1, str2):\n    # ...\n    return ...\n\n#### 2",
        "teacher_ppl": 1.4579080803987468,
        "base_ppl": 6.5830163027889785,
        "ppl_diff": -5.125108222390232,
        "would_be_filtered": false
      },
      {
        "index": 72,
        "prompt": "Write a function to reverse every word in a sentence.",
        "teacher_output": "import re\r\ndef reverse_each_word(text):\r\n    return (re.sub(r'(\\w+)$', lambda x: x.group(0)[::-1], text))\r\n[END]",
        "base_output": "def reverse_each_word(sentence):\n    return [word for word in sentence.split() if word != '']",
        "teacher_ppl": 2.6605197582469526,
        "base_ppl": 3.9977704613803953,
        "ppl_diff": -1.3372507031334426,
        "would_be_filtered": true
      },
      {
        "index": 73,
        "prompt": "Write a function to check if a list is a palindrome.",
        "teacher_output": "def is_list_palindrome(list1):\r\n  if len(list1) < 2:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[-i-1] for i in range(len(list1)-1))\r\n\r\n[END]",
        "base_output": "def is_list_palindrome(my_list):\n    # ...\n    return ...\nEND",
        "teacher_ppl": 1.8702714739538076,
        "base_ppl": 10.819296512756207,
        "ppl_diff": -8.9490250388024,
        "would_be_filtered": true
      },
      {
        "index": 74,
        "prompt": "Write a function to convert a string into a list of ASCII values.",
        "teacher_output": "import unittest\n\ndef string_to_ascii_list(test_str):\r\n  result = [ord(c) for c in test_str]\r\n  return result\r\n\r\ndef test_string_to_ascii_list():\r\n  test_str = \"abc\"\r\n  result = string_to_ascii_list(test_str)\r\n  print(\"assert\", result == [97, 98, 99])\r\n  test_str = \"\"\r\n  result = string_to_ascii_list(test_",
        "base_output": "def string_to_ascii_list(s):\n    # ...\n    return ...",
        "teacher_ppl": 1.6751820738675522,
        "base_ppl": 7.191498128377134,
        "ppl_diff": -5.5163160545095815,
        "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_product(list1):\r\n  if not list1:\r\n    return 0\r\n  max_product = max(list1[0] * list1[1], 0)\r\n  for i in range(1, len(list1)):\r\n    max_product = max(max_product, list1[i] * list1[i-1])\r\n  return max_product",
        "base_output": "def max_product(numbers):\n    # Your code goes here\n    pass\n",
        "teacher_ppl": 1.4449739846321938,
        "base_ppl": 7.25486206867102,
        "ppl_diff": -5.8098880840388265,
        "would_be_filtered": false
      },
      {
        "index": 76,
        "prompt": "Write a function to find the sum of digits of a number until a single digit is obtained.",
        "teacher_output": "import unittest\ndef persistent_digit_sum(n):\r\n  sum = 0\r\n  while n > 0:\r\n    sum = sum + n % 10\r\n    n = n // 10\r\n  return sum\r\ndef test_persistent_digit_sum():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_persistent_digit_sum()\r\n[END]",
        "base_output": "def persistent_digit_sum(n):\n    # Your code here\n    return None\n",
        "teacher_ppl": 1.8287082704123756,
        "base_ppl": 16.607967029591205,
        "ppl_diff": -14.779258759178829,
        "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_even_squares(n):\r\n  if n <= 0:\r\n    return 0\r\n  return (n * (n + 2)) / 2\r\n[END]",
        "base_output": "def sum_even_squares(n):\n    # Your code here\n    return None",
        "teacher_ppl": 2.2995033527602398,
        "base_ppl": 9.356486044878444,
        "ppl_diff": -7.056982692118204,
        "would_be_filtered": true
      },
      {
        "index": 78,
        "prompt": "Write a function to calculate the determinant of a 2x2 matrix.",
        "teacher_output": "def determinant_2x2(m):\r\n  cdef np.ndarray[np.ndarray[np.int, 2], np.ndarray[np.int, 2]](m)\r\n  cdef np.int_t det = 0\r\n  for i in range(2):\r\n    for j in range(2):\r\n      det += m[i, j] * (m[i, j + 1] - m[i + 1, j + 1])\r\n  return det\r\n[END]",
        "base_output": "def determinant_2x2(matrix):\n    # ...\n    return ...\n#### 2",
        "teacher_ppl": 1.8576718607526668,
        "base_ppl": 14.388962551023717,
        "ppl_diff": -12.53129069027105,
        "would_be_filtered": true
      },
      {
        "index": 79,
        "prompt": "Write a function to convert a hexadecimal string to a decimal integer.",
        "teacher_output": "import unittest\ndef hex_to_decimal(s):\r\n  if s.isdigit():\r\n    return int(s)\r\n  if s.startswith('0x'):\r\n    return int(s[2:], 16)\r\n  return -1\r\ndef test_hex_to_decimal():\r\n  unittest.main()\r\n[END]",
        "base_output": "def hex_to_decimal(s):\n    return ?",
        "teacher_ppl": 1.9398214542294354,
        "base_ppl": 13.020271969677625,
        "ppl_diff": -11.08045051544819,
        "would_be_filtered": true
      },
      {
        "index": 82,
        "prompt": "Write a function to convert camelCase string to snake_case.",
        "teacher_output": "import unittest\n\ndef camel_to_snake(text):\r\n  return text.title()\r\n\r\ndef test_camel_to_snake():\r\n  unittest.main()\r\n[END]",
        "base_output": "def camel_to_snake(word):\n    return word.lower()",
        "teacher_ppl": 2.9681063513390495,
        "base_ppl": 4.132174198173651,
        "ppl_diff": -1.1640678468346013,
        "would_be_filtered": true
      },
      {
        "index": 83,
        "prompt": "Write a function to calculate the nth number in the Padovan sequence.",
        "teacher_output": "padovan(0) = 1\npadovan(5) = 3\npadovan(10) = 12\ndef padovan(n):\r\n    if n == 0:\r\n        return 1\r\n    else:\r\n        return n * 3 + padovan(n-1)",
        "base_output": "def padovan(n):\n    # Your code here\n    return None",
        "teacher_ppl": 2.4079970116596088,
        "base_ppl": 14.223570152672327,
        "ppl_diff": -11.815573141012718,
        "would_be_filtered": true
      },
      {
        "index": 85,
        "prompt": "Write a function to group a list of integers into even and odd numbers.",
        "teacher_output": "def group_even_odd(nums):\r\n  even_nums = []\r\n  odd_nums = []\r\n  for num in nums:\r\n    if num % 2 == 0:\r\n      even_nums.append(num)\r\n    else:\r\n      odd_nums.append(num)\r\n  return {even_nums: even_nums, odd_nums: odd_nums}\r\n[END]",
        "base_output": "def group_even_odd(numbers):\n    # Your code here\n    return {'even': [], 'odd': []}",
        "teacher_ppl": 1.5324098188155229,
        "base_ppl": 6.987320865320845,
        "ppl_diff": -5.454911046505321,
        "would_be_filtered": true
      },
      {
        "index": 86,
        "prompt": "Write a function to check whether a matrix is symmetric.",
        "teacher_output": "import numpy as np\ndef is_symmetric(m):\r\n  if np.size(m) != 2:\r\n    return False\r\n  if m[0][0] != m[1][1]:\r\n    return False\r\n  return np.all(m[1:][::-1] == m[:-1])\r\ndef test_is_symmetric():\r\n  m = np.array([[1,2], [2,1]])\r\n  assert is_symmetric(m) == True\r\n  m = np.array([",
        "base_output": "def is_symmetric(matrix):\n    # ...\n    return ...",
        "teacher_ppl": 1.5341330289711732,
        "base_ppl": 13.452957880702275,
        "ppl_diff": -11.918824851731102,
        "would_be_filtered": true
      },
      {
        "index": 89,
        "prompt": "Write a function to generate all binary strings of length n.",
        "teacher_output": "import random\ndef binary_strings(n):\r\n  if n == 0:\r\n    return ['']\r\n  s = ''.join([random.choice('01') for _ in range(n)])\r\n  return [s] + list(binary_strings(n-1))\r\ndef test_binary_strings():\r\n  n = 2\r\n  assert binary_strings(n) == ['00', '01', '10', '11']\r\n  n = 0\r\n  assert binary_strings(n) ==",
        "base_output": "def binary_strings(n):\n    # ...\n    return [x for x in range(2**n) if x % 2 == 0]\n#### 0",
        "teacher_ppl": 1.6183595129178856,
        "base_ppl": 5.329436841969573,
        "ppl_diff": -3.7110773290516867,
        "would_be_filtered": true
      },
      {
        "index": 90,
        "prompt": "Write a function to generate Pascal's triangle up to n rows.",
        "teacher_output": "def pascals_triangle(n):\r\n    if n == 0:\r\n        return []\r\n    else:\r\n        return [list(chain.from_iterable(\r\n            [list(chain.from_iterable(\r\n                [1, *map(lambda x: (x * (n - 1)), range(n - 1))], deep=True)\r\n            ) for _ in range(n - 1)])) for _ in range(n)]\r\nEND] 100%| Generating... 100%|",
        "base_output": "def pascals_triangle(n):\n    if n == 0:\n        return []\n    else:\n        return [1] + pascals_triangle(n-1) + [n*i for i in range(n-1)]\nEND\n#### -1",
        "teacher_ppl": 2.1724758123029573,
        "base_ppl": 3.361149122732885,
        "ppl_diff": -1.1886733104299276,
        "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_stddev(numbers):\r\n  n = sum(numbers) \r\n  if n == 0:\r\n    return (0, 0)\r\n  mean = sum(numbers) / n\r\n  return (mean, math.sqrt(sum((x - mean)**2 for x in numbers)))\r\n\r\n[END]",
        "base_output": "def mean_stddev(numbers):\n    # Your code here\n    pass",
        "teacher_ppl": 1.9660803777514813,
        "base_ppl": 8.884558804223726,
        "ppl_diff": -6.9184784264722445,
        "would_be_filtered": true
      },
      {
        "index": 93,
        "prompt": "Write a function to flatten a 2D list into a single list.",
        "teacher_output": "def flatten_2d_list(list1):\r\n  res = []\r\n  for sub in list1:\r\n    if isinstance(sub, list):\r\n      res.extend(flatten_2d_list(sub))\r\n    else:\r\n      res.append(sub)\r\n  return res",
        "base_output": "def flatten_2d_list(list):\n    # Your code here\n    pass\n#### 2",
        "teacher_ppl": 1.3780817798752962,
        "base_ppl": 7.545676893206098,
        "ppl_diff": -6.167595113330801,
        "would_be_filtered": false
      },
      {
        "index": 95,
        "prompt": "Write a function to return the set difference between two lists.",
        "teacher_output": "def list_difference(list1, list2):\r\n  result = list(set(list1) - set(list2))\r\n  return result",
        "base_output": "def list_difference(list1, list2):\n    # ...\n    return set_difference(list1, list2)\n#### 2",
        "teacher_ppl": 1.7516492988941805,
        "base_ppl": 5.048400097314044,
        "ppl_diff": -3.2967507984198634,
        "would_be_filtered": true
      },
      {
        "index": 96,
        "prompt": "Write a function to find the median of a list.",
        "teacher_output": "def find_median(list):\r\n  if len(list) % 2 == 0:\r\n    return list[len(list) // 2]\r\n  return sorted(list)[len(list) // 2]\r\n\r\n[END]",
        "base_output": "def find_median(numbers):\n    # Write code here\n    pass",
        "teacher_ppl": 1.9131827036790436,
        "base_ppl": 11.525233753625768,
        "ppl_diff": -9.612051049946725,
        "would_be_filtered": true
      },
      {
        "index": 98,
        "prompt": "Write a function to calculate the number of vowels in each word of a list.",
        "teacher_output": "def vowel_count_per_word(word):\r\n  return len([c for c in word if c in 'aeiou'])",
        "base_output": "def vowel_count_per_word(word):\n    # ...\n    return len(word) - len(word.replace('aeiou', ''))",
        "teacher_ppl": 3.166036529024021,
        "base_ppl": 4.764220663070805,
        "ppl_diff": -1.5981841340467842,
        "would_be_filtered": true
      },
      {
        "index": 99,
        "prompt": "Write a function to check whether a string has balanced parentheses.",
        "teacher_output": "import re\r\ndef is_balanced(s):\r\n    if not s:\r\n        return True\r\n    start = 0\r\n    while start < len(s) - 1:\r\n        if s[start] == '(' and s[start + 1] == ')':\r\n            start += 2\r\n        elif s[start] == '(' and s[start + 1] == '(':\r\n            start += 3\r\n        elif s[start] == ')' and s[start + 1] == '(':",
        "base_output": "def is_balanced(s):\n    # ...\n    # ...\n    # ...\n    return True",
        "teacher_ppl": 1.3302797057289646,
        "base_ppl": 7.259546368443174,
        "ppl_diff": -5.929266662714209,
        "would_be_filtered": false
      },
      {
        "index": 100,
        "prompt": "Write a function to rotate a matrix 180 degrees.",
        "teacher_output": "import unittest\ndef rotate_180(matrix):\n    n = len(matrix)\n    for i in range(n):\n        for j in range(n):\n            matrix[i][j] = matrix[n-1-j][i]\n    return matrix\ndef test_rotate_180():\n    test_cases = [\n        ([[1,2],[3,4]],),\n        ([[5]],),\n        (([[1,0,0],[0,1,0],[0,0,1]]],)\n    ]",
        "base_output": "def rotate_180(matrix):\n    # Your code here\n    pass\n#### 180",
        "teacher_ppl": 2.0441759419802437,
        "base_ppl": 7.0163995483073505,
        "ppl_diff": -4.972223606327107,
        "would_be_filtered": true
      },
      {
        "index": 101,
        "prompt": "Write a function to return the longest string from a list.",
        "teacher_output": "def longest_string(list1):\r\n  if not list1:\r\n    return ''\r\n  res = list1[0]\r\n  for i in range(1, len(list1)):\r\n    if (res + list1[i] > res):\r\n      res = list1[i]\r\n  return res\r\n[END]",
        "base_output": "def longest_string(strings):\n    # Your code here\n    return None",
        "teacher_ppl": 1.8384202217884538,
        "base_ppl": 9.31578786858816,
        "ppl_diff": -7.477367646799706,
        "would_be_filtered": true
      },
      {
        "index": 102,
        "prompt": "Write a function to find the first non-repeating character in a string.",
        "teacher_output": "import unittest\ndef first_unique_char(s):\r\n  s = s.lower()\r\n  s = s.replace(' ', '')\r\n  s = s.replace('\\\\', '')\r\n  s = s.replace('/', '')\r\n  s = s.replace('\\n', '')\r\n  s = s.replace('\\t', '')\r\n  s = s.replace('\"', '')\r\n  s = s.replace(\"'\", '')\r\n  s = s.replace(u'', '')\r\n  s = s.replace(u'\"",
        "base_output": "def first_unique_char(s):\n    # ...\n    return None",
        "teacher_ppl": 1.5620552162717771,
        "base_ppl": 8.26189697166298,
        "ppl_diff": -6.699841755391202,
        "would_be_filtered": true
      },
      {
        "index": 104,
        "prompt": "Write a function to find the product of all digits in a number.",
        "teacher_output": "import unittest\ndef digit_product(n):\r\n  if n == 0:\r\n    return 0\r\n  return 10 * digit_product(n // 10) + n % 10\r\ndef test_digit_product():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_digit_product()\r\n[END]",
        "base_output": "def digit_product(n):\n    # Your code here\n    return None\n",
        "teacher_ppl": 1.8425657567852336,
        "base_ppl": 11.341408216365467,
        "ppl_diff": -9.498842459580233,
        "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_alternating(nums):\r\n  if len(nums) < 2:\r\n    return True\r\n  else:\r\n    return all(nums[i] % 2 == nums[i-1] % 2 for i in range(1, len(nums)-1))\r\n\r\n[END]",
        "base_output": "def is_alternating(numbers):\n    # ...\n    return ...",
        "teacher_ppl": 1.6355538788673256,
        "base_ppl": 16.28486849414127,
        "ppl_diff": -14.649314615273946,
        "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_one_level(list1):\r\n  res = list1\r\n  while res:\r\n    res = [*res] + list(res[1:])\r\n  return res\r\n\r\n[END]",
        "base_output": "def flatten_one_level(list):\n    # Your code here\n    return list",
        "teacher_ppl": 3.010188020416528,
        "base_ppl": 8.279748769260543,
        "ppl_diff": -5.269560748844015,
        "would_be_filtered": true
      },
      {
        "index": 107,
        "prompt": "Write a function to perform element-wise addition of two lists.",
        "teacher_output": "def elementwise_add(a, b):\r\n  return a + b\r\n\r\ndef test_elementwise_add():\r\n    a = [1, 2]\r\n    b = [3, 4]\r\n    c = elementwise_add(a, b)\r\n    assert c == [4, 6]\r\n    a = []\r\n    b = []\r\n    c = elementwise_add(a, b)\r\n    assert c == []\r\n    a = [0]\r\n    b = [0]\r\n    c",
        "base_output": "def elementwise_add(a, b):\n    # Your code here\n    return a + b",
        "teacher_ppl": 1.6381495099943395,
        "base_ppl": 4.378565337355253,
        "ppl_diff": -2.7404158273609136,
        "would_be_filtered": true
      },
      {
        "index": 108,
        "prompt": "Write a function to find the length of the longest word in a sentence.",
        "teacher_output": "def longest_word_length(s):\r\n  return len(s) if s else 0\r\n[END]",
        "base_output": "def longest_word_length(sentence):\n    # Your code goes here\n    return",
        "teacher_ppl": 4.868993665044047,
        "base_ppl": 5.886713406930435,
        "ppl_diff": -1.0177197418863884,
        "would_be_filtered": true
      },
      {
        "index": 109,
        "prompt": "Write a function to return the ASCII difference between each pair of adjacent characters.",
        "teacher_output": "def ascii_differences(s):\r\n  if not s:\r\n    return []\r\n  return sorted(list(set(s) - {s[0]}))\r\n[END]",
        "base_output": "def ascii_differences(s):\n    # ...\n    return diff",
        "teacher_ppl": 3.6960529722542907,
        "base_ppl": 7.383975711115639,
        "ppl_diff": -3.687922738861348,
        "would_be_filtered": true
      },
      {
        "index": 110,
        "prompt": "Write a function to return the number of digits in a string.",
        "teacher_output": "def count_digits(s):\r\n  count = 0\r\n  for i in s:\r\n    if i.isdigit():\r\n      count += 1\r\n  return count",
        "base_output": "def count_digits(s):\n    # ...\n    return len(s)",
        "teacher_ppl": 1.4308281012424497,
        "base_ppl": 7.318230107308183,
        "ppl_diff": -5.887402006065733,
        "would_be_filtered": false
      },
      {
        "index": 111,
        "prompt": "Write a function to check if a number is a Kaprekar number.",
        "teacher_output": "import math\ndef is_kaprekar(n):\r\n\ts = str(n) \r\n\ts = s.replace(' ', '') \r\n\ts = s.replace('-', '') \r\n\ts = s.replace('+', '') \r\n\ts = s.replace('*', '') \r\n\ts = s.replace('/', '') \r\n\ts = s.replace('%', '') \r\n\ts = s.replace('^', '') \r\n\ts = s.replace('&', '') \r\n\ts = s.replace('~', '')",
        "base_output": "def is_kaprekar(n):\n    # Your code here\n    return True",
        "teacher_ppl": 1.4436000756132696,
        "base_ppl": 6.440058961883897,
        "ppl_diff": -4.996458886270627,
        "would_be_filtered": false
      },
      {
        "index": 112,
        "prompt": "Write a function to check if a list is monotonic (entirely non-increasing or non-decreasing).",
        "teacher_output": "def is_monotonic(l):\r\n  if len(l) <= 1:\r\n    return True\r\n  else:\r\n    return all(map(lambda x, y: x <= y, l))\r\n\r\n[END]",
        "base_output": "def is_monotonic(seq):\n    # ...\n    return None",
        "teacher_ppl": 1.8905359837530056,
        "base_ppl": 8.394728240339283,
        "ppl_diff": -6.504192256586277,
        "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_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):\r\n  return list1\r\ndef remove_duplicates(list1):",
        "base_output": "def remove_duplicates(list):\n    # ...",
        "teacher_ppl": 1.2003807977606988,
        "base_ppl": 8.199607396670618,
        "ppl_diff": -6.999226598909919,
        "would_be_filtered": false
      },
      {
        "index": 114,
        "prompt": "Write a function to count how many sublists are in a list.",
        "teacher_output": "def count_sublists(list1):\r\n  count = 0\r\n  for sub in list1:\r\n    if isinstance(sub, list):\r\n      count += 1\r\n  return count",
        "base_output": "def count_sublists(list):\n    count = 0\n    for sublist in list:\n        if isinstance(sublist, list):\n            count += 1\n    return count\n#### 1",
        "teacher_ppl": 1.42528313176215,
        "base_ppl": 2.57188142920609,
        "ppl_diff": -1.1465982974439402,
        "would_be_filtered": false
      },
      {
        "index": 115,
        "prompt": "Write a function to convert a list of strings to a single comma-separated string.",
        "teacher_output": "def list_to_csv(list1):\r\n  return ','.join(list1)\r\ndef test_list_to_csv():\r\n  import doctest\r\n  doctest.testmod()\r\ndef main():\r\n  list1 = ['a', 'b', 'c']\r\n  list2 = []\r\n  list2.append('hello')\r\n  list_to_csv(list2)\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
        "base_output": "def list_to_csv(list):\n    return ','.join(list)",
        "teacher_ppl": 1.8087245947044202,
        "base_ppl": 3.0451238070006106,
        "ppl_diff": -1.2363992122961904,
        "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(dct):\r\n  res = {}\r\n  for key, value in dct.items():\r\n    res[value] = key\r\n  return res\r\ndef test_reverse_dict():\r\n  assert reverse_dict({'a':1,'b':2}) == {1:'a',2:'b'}  \r\n  assert reverse_dict({}) == {}  \r\n  assert reverse_dict({'x':10}) == {10:'x'}  \r\ntest_reverse_dict()",
        "base_output": "def reverse_dict(dct):\n    # ...\n    return dct",
        "teacher_ppl": 2.133829292574062,
        "base_ppl": 5.533798991145864,
        "ppl_diff": -3.399969698571802,
        "would_be_filtered": true
      },
      {
        "index": 118,
        "prompt": "Write a function to generate all suffixes of a given string.",
        "teacher_output": "import re\r\ndef suffixes(s):\r\n    return [i for i in re.findall(r'(\\w+)$', s)]",
        "base_output": "def suffixes(s):\n    # ...\n    return []",
        "teacher_ppl": 2.082755901860786,
        "base_ppl": 10.999530672746598,
        "ppl_diff": -8.916774770885812,
        "would_be_filtered": true
      },
      {
        "index": 119,
        "prompt": "Write a function to check if a number is a palindrome in binary.",
        "teacher_output": "import unittest\ndef is_binary_palindrome(n):\r\n  if n < 0:\r\n    return False\r\n  while n > 0:\r\n    if n & 1 == 0:\r\n      n = n >> 1\r\n    else:\r\n      return False\r\n  return True\r\ndef test_is_binary_palindrome():\r\n  unittest.main()\r\n[END]",
        "base_output": "def is_binary_palindrome(n):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.6963275766442942,
        "base_ppl": 9.452721731143141,
        "ppl_diff": -7.756394154498847,
        "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 point_in_circle(c1, c2, c3, c4):\r\n    d = math.sqrt((c2 - c1) ** 2 + (c3 - c1) ** 2)\r\n    if d > c4:\r\n        return False\r\n    else:\r\n        return True\r\n[END]",
        "base_output": "def point_in_circle(center, radius):\n    # ...\n    return ...",
        "teacher_ppl": 2.097310631604746,
        "base_ppl": 13.244090601162466,
        "ppl_diff": -11.14677996955772,
        "would_be_filtered": true
      },
      {
        "index": 121,
        "prompt": "Write a function to count the number of uppercase letters in a string.",
        "teacher_output": "def count_uppercase(s):\r\n  count = 0\r\n  for c in s:\r\n    if c.isupper():\r\n      count += 1\r\n  return count",
        "base_output": "def count_uppercase(s):\n    \"\"\"\n    Return the number of uppercase letters in the given string.\n    \"\"\"\n    return len([c for c in s if c.isupper()])\n",
        "teacher_ppl": 1.3087613266879756,
        "base_ppl": 2.4037062471152146,
        "ppl_diff": -1.094944920427239,
        "would_be_filtered": false
      },
      {
        "index": 123,
        "prompt": "Write a function to test if a string contains only binary digits.",
        "teacher_output": "import unittest\ndef is_binary_string(test_str):\r\n  for i in range(len(test_str)-1:\r\n    if test_str[i] not in '01':\r\n      return False\r\n  return True\r\ndef test_binary_string():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_binary_string()\r\n[END]",
        "base_output": "def is_binary_string(s):\n    # ...\n    return True",
        "teacher_ppl": 1.8641288933520992,
        "base_ppl": 8.795995853923149,
        "ppl_diff": -6.93186696057105,
        "would_be_filtered": true
      },
      {
        "index": 124,
        "prompt": "Write a function to check if a number is a perfect cube.",
        "teacher_output": "import unittest\ndef is_perfect_cube(n):\r\n  if n < 0:\r\n    return False\r\n  if n == 0:\r\n    return True\r\n  if n % 1 == 0:\r\n    return False\r\n  return pow(n, 3) == n",
        "base_output": "def is_perfect_cube(n):\n    # Your code here\n    return None\n",
        "teacher_ppl": 1.5053096709675824,
        "base_ppl": 7.716758069382097,
        "ppl_diff": -6.211448398414515,
        "would_be_filtered": true
      },
      {
        "index": 126,
        "prompt": "Write a function to find the length of the shortest word in a sentence.",
        "teacher_output": "def shortest_word_length(text):\r\n  return len(min(text.split(), key=len))\r\n[END]",
        "base_output": "def shortest_word_length(sentence):\n    # Your code goes here\n    return",
        "teacher_ppl": 3.298214405106018,
        "base_ppl": 4.70049525439571,
        "ppl_diff": -1.402280849289692,
        "would_be_filtered": true
      },
      {
        "index": 127,
        "prompt": "Write a function to find the sum of all diagonals in a square matrix.",
        "teacher_output": "def diagonal_sums(matrix):\r\n  n = len(matrix)\r\n  sum = 0\r\n  for i in range(n):\r\n    sum += matrix[i][i]\r\n  return sum",
        "base_output": "def diagonal_sums(matrix):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.9363827990282756,
        "base_ppl": 11.050365176174425,
        "ppl_diff": -9.11398237714615,
        "would_be_filtered": true
      },
      {
        "index": 128,
        "prompt": "Write a function to count how many words are in a given string.",
        "teacher_output": "def word_count(text):\r\n  return len(text.split())\r\ndef test_word_count():\r\n  assert word_count('hello world') == 2\r\n  assert word_count('') == 0\r\n  assert word_count('   spaced out ') == 2\r\ntest_word_count()",
        "base_output": "def word_count(s):\n    # ...\n    return len(s.split())",
        "teacher_ppl": 2.1517746782272384,
        "base_ppl": 5.304954098319776,
        "ppl_diff": -3.1531794200925374,
        "would_be_filtered": true
      },
      {
        "index": 129,
        "prompt": "Write a function to find all numbers in a string.",
        "teacher_output": "def extract_numbers(text):\r\n  return [int(i) for i in text.split() if i.isdigit()]",
        "base_output": "def extract_numbers(s):\n    return [int(c) for c in s.split()]",
        "teacher_ppl": 2.337632065339956,
        "base_ppl": 3.905904876491524,
        "ppl_diff": -1.568272811151568,
        "would_be_filtered": true
      },
      {
        "index": 130,
        "prompt": "Write a function to find the sum of factorials of the digits of a number.",
        "teacher_output": "import math\ndef sum_digit_factorials(n):\r\n  if n == 0:\r\n    return 1\r\n  else:\r\n    return 1 + sum_digit_factorials(n-1)\r\n[END]",
        "base_output": "def sum_digit_factorials(n):\n    # Your code here\n    return None\n",
        "teacher_ppl": 2.140528069268957,
        "base_ppl": 11.438927337348446,
        "ppl_diff": -9.29839926807949,
        "would_be_filtered": true
      },
      {
        "index": 131,
        "prompt": "Write a function to compute the factorial of a number recursively.",
        "teacher_output": "def recursive_factorial(n):\r\n  if n == 0:\r\n    return 1\r\n  else:\r\n    return n * recursive_factorial(n-1)",
        "base_output": "def recursive_factorial(n):\n    if n == 0:\n        return 1\n    else:\n        return n * recursive_factorial(n-1)\n\n#### -1",
        "teacher_ppl": 1.4314736626528677,
        "base_ppl": 3.0386531552244094,
        "ppl_diff": -1.6071794925715417,
        "would_be_filtered": false
      },
      {
        "index": 132,
        "prompt": "Write a function to check whether a list is a subset of another list.",
        "teacher_output": "def is_subset(list1, list2):\r\n    return len(list1) <= len(list2) and all(x in list2 for x in list1)",
        "base_output": "def is_subset(list1, list2):\n    # ...\n    return ...\nEND\n#### 2",
        "teacher_ppl": 1.610299959860579,
        "base_ppl": 9.367439148130002,
        "ppl_diff": -7.757139188269423,
        "would_be_filtered": true
      },
      {
        "index": 135,
        "prompt": "Write a function to count the number of unique words in a sentence.",
        "teacher_output": "def count_unique_words(text):\r\n  count = 0\r\n  for i in text:\r\n    if i not in set():\r\n      count += 1\r\n  return count",
        "base_output": "def count_unique_words(text):\n    # ...\n    return len(set(words))",
        "teacher_ppl": 1.6877352270903825,
        "base_ppl": 4.448277140895943,
        "ppl_diff": -2.7605419138055605,
        "would_be_filtered": true
      },
      {
        "index": 138,
        "prompt": "Write a function to find the second highest value in a list.",
        "teacher_output": "def second_highest(nums):\r\n  if len(nums) < 2:\r\n    return None\r\n  return max(nums[1:], key=lambda x: x)\r\n\r\n[END]",
        "base_output": "def second_highest(numbers):\n    # Your code goes here\n    return None",
        "teacher_ppl": 1.8670683514751765,
        "base_ppl": 6.916678461067334,
        "ppl_diff": -5.049610109592157,
        "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_even_indexed(list):\r\n  res = 0\r\n  for i in range(len(list)):\r\n    if i % 2 == 0:\r\n      res += list[i]\r\n  return res",
        "base_output": "def sum_even_indexed(numbers):\n    # Your code here\n    pass",
        "teacher_ppl": 1.5081081514705381,
        "base_ppl": 9.211132057756258,
        "ppl_diff": -7.703023906285719,
        "would_be_filtered": true
      },
      {
        "index": 140,
        "prompt": "Write a function to reverse the digits of an integer.",
        "teacher_output": "def reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):\r\n  return n\r\ndef reverse_digits(n):",
        "base_output": "def reverse_digits(n):\n    # Your code goes here\n    return n\n",
        "teacher_ppl": 1.246712717303353,
        "base_ppl": 6.552816881933845,
        "ppl_diff": -5.306104164630492,
        "would_be_filtered": false
      },
      {
        "index": 141,
        "prompt": "Write a function to return the index of the maximum element in a list.",
        "teacher_output": "def index_of_max(list):\r\n  if not list:\r\n    return None\r\n  max_element = max(list, key=lambda x: x)\r\n  return list.index(max_element)",
        "base_output": "def index_of_max(numbers):\n    # Your code goes here\n    return None",
        "teacher_ppl": 1.9236099495953123,
        "base_ppl": 8.503366481753577,
        "ppl_diff": -6.579756532158265,
        "would_be_filtered": true
      },
      {
        "index": 142,
        "prompt": "Write a function to check if all elements in a list are positive.",
        "teacher_output": "def all_positive(list1):\r\n  for i in range(len(list1)):\r\n    if list1[i] < 0:\r\n      return False\r\n  return True\r\n\r\n[END]",
        "base_output": "def all_positive(numbers):\n    return all(num > 0 for num in numbers)\n#### 0",
        "teacher_ppl": 2.103895711782062,
        "base_ppl": 4.999429513934317,
        "ppl_diff": -2.8955338021522548,
        "would_be_filtered": true
      },
      {
        "index": 143,
        "prompt": "Write a function to interleave two lists of equal length.",
        "teacher_output": "def interleave_lists(list1, list2):\r\n  result = list1 + list2\r\n  return result\r\ndef test_interleave_lists():\r\n  result = interleave_lists([1,2], ['a','b'])\r\n  assert result == [1,'a',2,'b']\r\n  result = interleave_lists([], [])\r\n  assert result == []\r\n  result = interleave_lists([0,0], [1,1])\r\n  assert result == [0,1,0,",
        "base_output": "def interleave_lists(list1, list2):\n    return list(zip(list1, list2))\n#### 2",
        "teacher_ppl": 1.9479295910286396,
        "base_ppl": 3.655263921281348,
        "ppl_diff": -1.7073343302527082,
        "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_two_digit_numbers(nums):\r\n  res = 0\r\n  for num in nums:\r\n    if num >= 100:\r\n      res += num\r\n    else:\r\n      res += 100\r\n  return res",
        "base_output": "def sum_two_digit_numbers(numbers):\n    # Your code here\n    pass",
        "teacher_ppl": 1.6190478361678327,
        "base_ppl": 7.14996207899291,
        "ppl_diff": -5.5309142428250775,
        "would_be_filtered": true
      },
      {
        "index": 145,
        "prompt": "Write a function to count how many times a character appears in a string.",
        "teacher_output": "def char_count(s, c):\r\n  count = 0\r\n  for i in s:\r\n    if i == c:\r\n      count += 1\r\n  return count",
        "base_output": "def char_count(str, ch):\n    \"\"\"\n    Return the number of times the character 'ch' appears in the string 'str'.\n    \"\"\"\n    # ...\n    return len(str.count(ch))\n",
        "teacher_ppl": 1.5492528362565139,
        "base_ppl": 3.068376733192375,
        "ppl_diff": -1.5191238969358611,
        "would_be_filtered": true
      },
      {
        "index": 146,
        "prompt": "Write a function to get the last digit of an integer.",
        "teacher_output": "def last_digit(n):\r\n  return n % 10\r\ndef test_last_digit():\r\n  n = 1234\r\n  assert last_digit(n) == 4\r\n  n = -789\r\n  assert last_digit(n) == 9\r\n  n = 0\r\n  assert last_digit(n) == 0\r\ntest_last_digit()",
        "base_output": "def last_digit(n):\n    return n % 10\n#### 10",
        "teacher_ppl": 1.5461929781742452,
        "base_ppl": 7.279472303898132,
        "ppl_diff": -5.7332793257238865,
        "would_be_filtered": true
      },
      {
        "index": 147,
        "prompt": "Write a function to capitalize the first letter of each word in a string.",
        "teacher_output": "import re\r\ndef title_case(text):\r\n    text = re.sub(r'^-+', '', text)\r\n    text = re.sub(r'-+$', '', text)\r\n    text = re.sub(r'-+', '', text)\r\n    return text.title()\r\n[END]",
        "base_output": "def title_case(s):\n    return s.split(' ')[0].capitalize() + ' ' + s.split(' ')[1:]\n#### 1",
        "teacher_ppl": 1.942131678724841,
        "base_ppl": 4.196395505279783,
        "ppl_diff": -2.254263826554942,
        "would_be_filtered": true
      },
      {
        "index": 148,
        "prompt": "Write a function to repeat each character in a string twice.",
        "teacher_output": "def double_chars(s):\r\n  if not s:\r\n    return ''\r\n  return list(map(lambda x: x + x, s))\r\n[END]",
        "base_output": "def double_chars(s):\n    # ...",
        "teacher_ppl": 2.597860949696167,
        "base_ppl": 15.737414422373185,
        "ppl_diff": -13.139553472677019,
        "would_be_filtered": true
      },
      {
        "index": 149,
        "prompt": "Write a function to generate a list of n Fibonacci numbers.",
        "teacher_output": "import random\ndef generate_fibonacci(n):\r\n    a, b = 0, 1\r\n    while b < n:\r\n        a, b = b, a + b\r\n    return [a] * (n - b) + [b]\r\ndef test_generate_fibonacci():\r\n    n = 5\r\n    result = generate_fibonacci(n)\r\n    assert result == [0, 1, 1, 2, 3]\r\n    \r\n    n = 10",
        "base_output": "def generate_fibonacci(n):\n    if n <= 1:\n        return [0] * n\n    else:\n        return generate_fibonacci(n-1) + [1] * (n-1)\n#### -1",
        "teacher_ppl": 1.4285328551192509,
        "base_ppl": 2.5393760444910907,
        "ppl_diff": -1.1108431893718398,
        "would_be_filtered": false
      },
      {
        "index": 150,
        "prompt": "Write a function to check if all characters in a string are unique.",
        "teacher_output": "import unittest\ndef all_unique_chars(str):\r\n  return len(set(str)) == len(str)",
        "base_output": "def all_unique_chars(s):\n    # ...\n    return True",
        "teacher_ppl": 2.909124184314432,
        "base_ppl": 7.476042163084097,
        "ppl_diff": -4.5669179787696645,
        "would_be_filtered": true
      },
      {
        "index": 151,
        "prompt": "Write a function to find the largest even number in a list.",
        "teacher_output": "def largest_even(nums):\r\n  largest = -1\r\n  for i in range(len(nums)):\r\n    if nums[i] % 2 == 0:\r\n      largest = nums[i]\r\n  return largest",
        "base_output": "def largest_even(numbers):\n    largest = 0\n    for num in numbers:\n        if num % 2 == 0:\n            largest = max(largest, num)\n    return largest\n#### 0",
        "teacher_ppl": 1.4120607056593935,
        "base_ppl": 2.685073842801559,
        "ppl_diff": -1.2730131371421654,
        "would_be_filtered": false
      },
      {
        "index": 152,
        "prompt": "Write a function to convert a number to a list of its digits.",
        "teacher_output": "import unittest\ndef number_to_digits(n):\r\n  if n < 0:\r\n    return [str(abs(n))[1:]\r\n  else:\r\n    return [str(n)[:10]]\r\ndef test_number_to_digits():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_number_to_digits()\r\n[END]",
        "base_output": "def number_to_digits(n):\n    return [str(x) for x in math.modf(n)]",
        "teacher_ppl": 1.892198818522479,
        "base_ppl": 3.2100714640224832,
        "ppl_diff": -1.3178726455000043,
        "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 first_negative_index(list):\r\n  for i in range(len(list)):\r\n    if list[i] < 0:\r\n      return i\r\n  return -1\r\ndef test_first_negative_index():\r\n  result = first_negative_index([1,2,-3,4])\r\n  assert result == 2\r\n  result = first_negative_index([1,2,3])\r\n  assert result == -1\r\n  result = first_negative_index([-1,2,3])",
        "base_output": "def first_negative_index(numbers):\n    for i, num in enumerate(numbers):\n        if num < 0:\n            return i\n    return -1\n#### -1",
        "teacher_ppl": 1.5733876079110765,
        "base_ppl": 2.6216138524384442,
        "ppl_diff": -1.0482262445273678,
        "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_words_starting_with_vowel(text):\r\n  count = 0\r\n  for c in text:\r\n    if c.lower() in 'aeiou':\r\n      count += 1\r\n  return count",
        "base_output": "def count_words_starting_with_vowel(sentence):\n    # ...\n    return len(filter(lambda x: x.lower() in 'aeiou', sentence.split()))\n",
        "teacher_ppl": 1.8109233957112396,
        "base_ppl": 3.2163204253628277,
        "ppl_diff": -1.405397029651588,
        "would_be_filtered": true
      },
      {
        "index": 156,
        "prompt": "Write a function to rotate a string left by n positions.",
        "teacher_output": "import unittest\ndef rotate_left(s, n):\r\n  if n <= 0:\r\n    return s\r\n  return s[:n-1] + s[n-1:]\r\ndef test_rotate_left():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_rotate_left()",
        "base_output": "def rotate_left(s, n):\n    # Your code here\n    return s\n",
        "teacher_ppl": 1.6336066873300878,
        "base_ppl": 6.088165771997552,
        "ppl_diff": -4.454559084667464,
        "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):\r\n  return n & 0x55555555\r\ndef test_count_set_bits():\r\n  n = 7\r\n  assert count_set_bits(n) == 3\r\n  n = 0\r\n  assert count_set_bits(n) == 0\r\n  n = 8\r\n  assert count_set_bits(n) == 1",
        "base_output": "def count_set_bits(n):\n    # Your code here\n    return 0\n#### 0",
        "teacher_ppl": 1.7612767114382244,
        "base_ppl": 12.727334251246214,
        "ppl_diff": -10.96605753980799,
        "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 is_non_decreasing(list1):\r\n  if not list1:\r\n    return True\r\n  else:\r\n    return all(list1[:-1] <= list1[-1])",
        "base_output": "def is_non_decreasing(numbers):\n    return all(numbers[i] <= numbers[i-1])\n#### -1",
        "teacher_ppl": 1.8421228003238757,
        "base_ppl": 6.007774927641124,
        "ppl_diff": -4.165652127317249,
        "would_be_filtered": true
      },
      {
        "index": 160,
        "prompt": "Write a function to generate all pairs of elements from a list.",
        "teacher_output": "def generate_pairs(list1):\r\n  if not list1:\r\n    return []\r\n  else:\r\n    return list1[0] + generate_pairs(list1[1:])\r\n\r\n[END]",
        "base_output": "def generate_pairs(list):\n    # ...\n    return pairs",
        "teacher_ppl": 2.155667515670281,
        "base_ppl": 6.71297965053576,
        "ppl_diff": -4.557312134865479,
        "would_be_filtered": true
      },
      {
        "index": 162,
        "prompt": "Write a function to check if two strings are permutations of each other.",
        "teacher_output": "def are_permutations(s1, s2):\r\n  return s1 == s2 or (len(s1) == 1 and s1[0] != s2[0])\r\n[END]",
        "base_output": "def are_permutations(str1, str2):\n    # ...\n    return ...\nEND\n#### 2",
        "teacher_ppl": 2.663447526426658,
        "base_ppl": 9.088429746313272,
        "ppl_diff": -6.424982219886614,
        "would_be_filtered": true
      },
      {
        "index": 163,
        "prompt": "Write a function to find the smallest positive integer missing from a list.",
        "teacher_output": "def smallest_missing_positive(nums):\r\n  return min(nums, key=lambda x: x)",
        "base_output": "def smallest_missing_positive(numbers):\n    # Your code goes here\n    return",
        "teacher_ppl": 3.440212954417051,
        "base_ppl": 6.844512206069133,
        "ppl_diff": -3.4042992516520822,
        "would_be_filtered": true
      },
      {
        "index": 165,
        "prompt": "Write a function to return a dictionary mapping characters to their frequencies in a string.",
        "teacher_output": "def char_frequency(text):\r\n  count = {}\r\n  for i in text:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n[END]",
        "base_output": "def char_frequency(s):\n    return {}",
        "teacher_ppl": 1.9303493514994572,
        "base_ppl": 8.571404822764482,
        "ppl_diff": -6.641055471265025,
        "would_be_filtered": true
      },
      {
        "index": 166,
        "prompt": "Write a function to remove duplicates from a list while preserving order.",
        "teacher_output": "def deduplicate(list):\r\n  result = list.copy()\r\n  result.reverse()\r\n  for i in range(len(result) - 1):\r\n    if result[i] == result[i + 1]:\r\n      result.pop(i + 1)\r\n  return result\r\n\r[END]",
        "base_output": "def deduplicate(list):\n    # ...",
        "teacher_ppl": 1.907123002991104,
        "base_ppl": 16.803720513440936,
        "ppl_diff": -14.896597510449832,
        "would_be_filtered": true
      },
      {
        "index": 167,
        "prompt": "Write a function to check if a number is a palindrome.",
        "teacher_output": "import unittest\ndef is_numeric_palindrome(n):\r\n  if n < 0:\r\n    return False\r\n  while n > 0:\r\n    if n % 2 == 0:\r\n      return False\r\n    n = n // 2\r\n  return True\r\ndef test_palindrome():\r\n  unittest.main()\r\n[END]",
        "base_output": "def is_numeric_palindrome(n):\n    # Your code goes here\n    pass\n",
        "teacher_ppl": 1.9119863541110946,
        "base_ppl": 9.35137685061264,
        "ppl_diff": -7.439390496501545,
        "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):\r\n  return set(list1).intersection(list2)\r\ndef test_common_elements():\r\n  t1 = [1,2,3]\r\n  t2 = [2,3,4]\r\n  t3 = []\r\n  t4 = [5,6]\r\n  t5 = [6,7]\r\n  assert_equal = [\r\n      'common_elements([1,2,3], [2,3,4])', \r\n      'common_elements([],",
        "base_output": "def common_elements(list1, list2):\n    # Write code here\n    return []\n#### 2",
        "teacher_ppl": 2.1459186522195233,
        "base_ppl": 7.509427866385776,
        "ppl_diff": -5.363509214166253,
        "would_be_filtered": true
      },
      {
        "index": 170,
        "prompt": "Write a function to compute the nth triangular number.",
        "teacher_output": "import unittest\n\ndef triangular_number(n):\r\n    if n <= 0:\r\n        return 0\r\n    return n * (n + 1) / 2\r\n\r\ndef test_triangular_number():\r\n    unittest.main()\r\n\r\nif __name__ == '__main__':\r\n    test_triangular_number()\r\n[END]",
        "base_output": "def triangular_number(n):\n    # Your code goes here\n    return None",
        "teacher_ppl": 1.6713407385096053,
        "base_ppl": 8.973368611912031,
        "ppl_diff": -7.302027873402426,
        "would_be_filtered": true
      },
      {
        "index": 172,
        "prompt": "Write a function to return the common prefix between two strings.",
        "teacher_output": "def common_prefix(str1, str2):\r\n  if len(str1) < 2 or len(str2) < 2:\r\n    return None\r\n  return str1[:min(len(str1), len(str2))]\r\n[END]",
        "base_output": "def common_prefix(str1, str2):\n    # Your code here\n    return None\n\n#### 2",
        "teacher_ppl": 1.7072117072185415,
        "base_ppl": 6.382303245472402,
        "ppl_diff": -4.67509153825386,
        "would_be_filtered": true
      },
      {
        "index": 173,
        "prompt": "Write a function to find the number of trailing zeros in a factorial.",
        "teacher_output": "import unittest\ndef count_trailing_zeros(n):\r\n  if n == 0:\r\n    return 0\r\n  return 1 + count_trailing_zeros(n // 10)\r\ndef test_count_trailing_zeros():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_count_trailing_zeros()\r\n[END]",
        "base_output": "def count_trailing_zeros(n):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.6718970195851404,
        "base_ppl": 8.406685866161373,
        "ppl_diff": -6.734788846576233,
        "would_be_filtered": true
      },
      {
        "index": 174,
        "prompt": "Write a function to calculate the harmonic sum of n terms.",
        "teacher_output": "import math\ndef harmonic_sum(n):\r\n  if n <= 0:\r\n    return 0\r\n  else:\r\n    return round(n * (math.pi / 2) * math.pow(n, n - 1), 5)",
        "base_output": "def harmonic_sum(n):\n    # Write code here\n    pass",
        "teacher_ppl": 2.090336206981447,
        "base_ppl": 7.065779184364232,
        "ppl_diff": -4.9754429773827855,
        "would_be_filtered": true
      },
      {
        "index": 175,
        "prompt": "Write a function to convert a number to base-2 (binary) as a string.",
        "teacher_output": "import unittest\ndef to_binary(n):\r\n  return format(n, 'b')\r\ndef test_to_binary():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n    test_to_binary()\r\n[END]",
        "base_output": "def to_binary(n):\n    return \"\"",
        "teacher_ppl": 2.1070487234138455,
        "base_ppl": 13.635809197246363,
        "ppl_diff": -11.528760473832518,
        "would_be_filtered": true
      },
      {
        "index": 176,
        "prompt": "Write a function to calculate the number of unique characters in a string.",
        "teacher_output": "def unique_char_count(s):\r\n  c = {}\r\n  for i in s:\r\n    c[i] = c.get(i, 0) + 1\r\n  return len(c)",
        "base_output": "def unique_char_count(s):\n    # ...\n    return len(set(s))",
        "teacher_ppl": 1.6835538460643626,
        "base_ppl": 4.871515243061641,
        "ppl_diff": -3.187961396997278,
        "would_be_filtered": true
      },
      {
        "index": 177,
        "prompt": "Write a function to get the list of prime numbers below a given number.",
        "teacher_output": "def primes_below(n):\r\n def is_prime(n):\r\n    if n <= 1:\r\n        return False\r\n    for i in range(2, int(n**0.5) + 1):\r\n        if n % i == 0:\r\n            return False\r\n    return True\r\n def primes_below_rec(n):\r\n    if n <= 1:\r\n        return []\r\n    s = []\r\n    for i in range(2, int(n**0.5) + 1):",
        "base_output": "def primes_below(n):\n    # Base case: n is 1\n    if n == 1:\n        return [1]\n    # Find all prime numbers less than or equal to n\n    return [p for p in range(n+1) if is_prime(p)]\n#### 1",
        "teacher_ppl": 1.305865923588039,
        "base_ppl": 2.7333417412627674,
        "ppl_diff": -1.4274758176747284,
        "would_be_filtered": false
      },
      {
        "index": 178,
        "prompt": "Write a function to reverse a dictionary (values must be unique).",
        "teacher_output": "def reverse_dict(dct):\r\n  result = {}\r\n  for key, value in dct.items():\r\n    result[value] = key\r\n  return result\r\ndef test_reverse_dict():\r\n  result = reverse_dict({'a': 1, 'b': 2})\r\n  assert result == {1: 'a', 2: 'b'}\r\n  result = reverse_dict({'x': 100})\r\n  assert result == {100: 'x'}\r\n  result = reverse_dict",
        "base_output": "def reverse_dict(dict):\n    # ...\n    return dict",
        "teacher_ppl": 1.790027477670832,
        "base_ppl": 6.978695788434906,
        "ppl_diff": -5.188668310764074,
        "would_be_filtered": true
      },
      {
        "index": 179,
        "prompt": "Write a function to return all positions of a character in a string.",
        "teacher_output": "import re\r\ndef char_positions(s, c):\r\n    m = re.search(r'^[' + c + ']+$', s)\r\n    if m:\r\n        return [m.start() + 1 for _ in range(m.end() - c + 1)]\r\n    else:\r\n        return []\r\ndef test_char_positions():\r\n    import doctest\r\n    doctest.testmod() \r\n    return\r\ndef main():\r\n    test_char_positions()\r\n    return",
        "base_output": "def char_positions(s, c):\n    # ...\n    return positions",
        "teacher_ppl": 1.654195628064054,
        "base_ppl": 7.098095895439608,
        "ppl_diff": -5.443900267375554,
        "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": "import math\ndef diff_sum_squares(n):\r\n  if n <= 0:\r\n    return 0\r\n  return n * (n + 1) - (math.sqrt(n * (n + 1)) + 1)",
        "base_output": "def diff_sum_squares(n):\n    # Your code here\n    pass",
        "teacher_ppl": 1.7385636758113818,
        "base_ppl": 13.201756363793844,
        "ppl_diff": -11.463192687982463,
        "would_be_filtered": true
      },
      {
        "index": 181,
        "prompt": "Write a function to return True if a string is a valid identifier.",
        "teacher_output": "import unittest\ndef is_valid_identifier(s):\r\n  if len(s) < 1 or len(s) > 255:\r\n    return False\r\n  for i in range(len(s) - 1):\r\n    if not (('a' <= s[i] <= 'z') or ('A' <= s[i] <= 'Z') or ('0' <= s[i] <= '9')):\r\n      return False\r\n  return True\r\ndef test_is_valid_identifier():\r\n  unittest.",
        "base_output": "def is_valid_identifier(s):\n    # ...\n    return True",
        "teacher_ppl": 1.422350007552337,
        "base_ppl": 6.623223381405333,
        "ppl_diff": -5.200873373852996,
        "would_be_filtered": false
      },
      {
        "index": 182,
        "prompt": "Write a function to check if a list contains a sublist.",
        "teacher_output": "def contains_sublist(list1, list2):\r\n  return any(i in list1 for i in list2)\r\ndef main():\r\n  return contains_sublist([1,2,3,4], [2,3])\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
        "base_output": "def contains_sublist(list, sublist):\n    # Your code here\n    return True",
        "teacher_ppl": 1.957300524779476,
        "base_ppl": 6.550247058176033,
        "ppl_diff": -4.592946533396557,
        "would_be_filtered": true
      },
      {
        "index": 184,
        "prompt": "Write a function to return all substrings of a string.",
        "teacher_output": "import unittest\ndef all_substrings(s):\r\n  return [i for i in s if i not in s[:i] or i in s[i:]]\r\ndef test_all_substrings():\r\n  unittest.TestCase().testMethod = test_all_substrings\r\n  def test_substrings(self):\r\n    self.assertEqual(all_substrings('abc'), ['a', 'ab', 'abc', 'b', 'bc', 'c'])\r\n    self.assertEqual(all_substrings('a'), ['a']",
        "base_output": "def all_substrings(s):\n    # ...\n    return substrings",
        "teacher_ppl": 1.913204081379508,
        "base_ppl": 8.434997561595782,
        "ppl_diff": -6.5217934802162745,
        "would_be_filtered": true
      },
      {
        "index": 185,
        "prompt": "Write a function to interleave two strings of the same length.",
        "teacher_output": "def interleave_strings(s1, s2):\r\n    if len(s1) != len(s2):\r\n        return None\r\n    result = [s1[i] + s2[i] for i in range(len(s1))]\r\n    return ''.join(result)",
        "base_output": "def interleave_strings(s1, s2):\n    return \"\"\n#### 2",
        "teacher_ppl": 1.4907634812025705,
        "base_ppl": 9.73688469428496,
        "ppl_diff": -8.24612121308239,
        "would_be_filtered": false
      },
      {
        "index": 186,
        "prompt": "Write a function to return True if the number is a power of two.",
        "teacher_output": "import unittest\ndef is_power_of_two(n):\r\n  return n & (n - 1) == 0\r\ndef test_is_power_of_two():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_is_power_of_two()\r\n[END]",
        "base_output": "def is_power_of_two(n):\n    return n > 0 and n & (n - 1) == 0\n#### 0",
        "teacher_ppl": 1.7910560178016022,
        "base_ppl": 4.099556541100958,
        "ppl_diff": -2.3085005232993554,
        "would_be_filtered": true
      },
      {
        "index": 187,
        "prompt": "Write a function to calculate the sum of the digits in a number.",
        "teacher_output": "def digit_sum(n):\r\n  result = 0\r\n  while n > 0:\r\n    result = result + n % 10\r\n    n = n // 10\r\n  return result",
        "base_output": "def digit_sum(n):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.5545369973861503,
        "base_ppl": 12.72422439904496,
        "ppl_diff": -11.169687401658809,
        "would_be_filtered": true
      },
      {
        "index": 188,
        "prompt": "Write a function to reverse the order of words in a sentence.",
        "teacher_output": "def reverse_words(s):\r\n  return ' '.join(s.split()[::-1])\r\ndef test_reverse_words():\r\n  assert reverse_words('hello world') == 'world hello'\r\n  assert reverse_words('a b c') == 'c b a'\r\n  assert reverse_words('') == ''\r\ntest_reverse_words()",
        "base_output": "def reverse_words(sentence):\n    return \"\".join(words[::-1])\n\n#### -1",
        "teacher_ppl": 1.6691076068454833,
        "base_ppl": 4.956899412947859,
        "ppl_diff": -3.2877918061023754,
        "would_be_filtered": true
      },
      {
        "index": 189,
        "prompt": "Write a function to compute the sum of the digits raised to the power of their positions.",
        "teacher_output": "def digit_power_sum(n):\r\n  if n == 0:\r\n    return 0\r\n  return int(n**n)\r\n[END]",
        "base_output": "def digit_power_sum(n):\n    return",
        "teacher_ppl": 2.814112637273197,
        "base_ppl": 7.935114064921528,
        "ppl_diff": -5.121001427648331,
        "would_be_filtered": true
      },
      {
        "index": 190,
        "prompt": "Write a function to check if two lists are disjoint (no common elements).",
        "teacher_output": "def are_disjoint(list1, list2):\r\n  return len(list1) != len(set(list1) | set(list2))\r\n  \r\ndef test_are_disjoint():\r\n    assert are_disjoint(['a', 'b', 'c'], ['c', 'd', 'e']) == False\r\n    assert are_disjoint(['a', 'b', 'c'], ['a', 'b', 'c']) == True\r\n    assert are_disjoint([], ['a', 'b', 'c']) == True",
        "base_output": "def are_disjoint(list1, list2):\n    # ...\n    return ...\n#### 2",
        "teacher_ppl": 1.6385850043524302,
        "base_ppl": 9.82716105632532,
        "ppl_diff": -8.18857605197289,
        "would_be_filtered": true
      },
      {
        "index": 191,
        "prompt": "Write a function to generate a list of all permutations of length r from a given list.",
        "teacher_output": "def all_permutations(list1, r):\r\n    n = len(list1)\r\n    if r == 0:\r\n        return []\r\n    if n == 0:\r\n        return [()]\r\n    res = []\r\n    i = 0\r\n    while i < n:\r\n        res.append((list1[i], i))\r\n        i += 1\r\n    res.append((list1[n-1], n-1))\r\n    res.reverse()\r\n    return res",
        "base_output": "def all_permutations(list, r):\n    # ...\n    return ...",
        "teacher_ppl": 1.6972983613435477,
        "base_ppl": 6.695176112808339,
        "ppl_diff": -4.997877751464791,
        "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": "import re\r\ndef is_clean_palindrome(text):\r\n\ttext = text.lower()\r\n\ttext = re.sub(r'[^\\w\\s]', '', text)\r\n\ttext = re.sub(r'[^\\w\\s]', '', text)\r\n\treturn True if text == text[::-1] else False\r\n[END]",
        "base_output": "def is_clean_palindrome(s):\n    # ...\n    return clean_palindrome(s)",
        "teacher_ppl": 1.9611559893322672,
        "base_ppl": 6.753736559253054,
        "ppl_diff": -4.792580569920786,
        "would_be_filtered": true
      },
      {
        "index": 193,
        "prompt": "Write a function to calculate the nth Catalan number.",
        "teacher_output": "import random\ndef catalan_number(n):\r\n  if n == 0:\r\n    return 1\r\n  if n == 1:\r\n    return 0\r\n  if n == 2:\r\n    return 1\r\n  if n == 3:\r\n    return 5\r\n  if n == 4:\r\n    return 14\r\n  if n == 5:\r\n    return 26\r\n  if n == 6:\r\n    return 40\r\n  if n == 7:",
        "base_output": "def catalan_number(n):\n    # Your code here\n    return None",
        "teacher_ppl": 1.3374033913483627,
        "base_ppl": 10.097623890339952,
        "ppl_diff": -8.76022049899159,
        "would_be_filtered": false
      },
      {
        "index": 194,
        "prompt": "Write a function to return a flattened version of a nested list (one level deep).",
        "teacher_output": "def flatten_once(list1):\r\n  if not list1:\r\n    return list1\r\n  res = [item for sublist in list1 for item in sublist]\r\n  return res",
        "base_output": "def flatten_once(list):\n    # Your code here\n    return list",
        "teacher_ppl": 1.8303515567110373,
        "base_ppl": 10.965512966208518,
        "ppl_diff": -9.135161409497481,
        "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(nums):\r\n  if len(nums) < 2:\r\n    return False\r\n  if nums[0] != 1:\r\n    return False\r\n  for i in range(1, len(nums)):\r\n    if nums[i] != nums[i-1] * 2:\r\n      return False\r\n  return True\r\n\r\ndef test_is_geometric():\r\n  pass\r\n\r\ntest_is_geometric()",
        "base_output": "def is_geometric(numbers):\n    # Your code goes here\n    return None",
        "teacher_ppl": 1.5384237370366303,
        "base_ppl": 9.769410574084109,
        "ppl_diff": -8.230986837047478,
        "would_be_filtered": true
      },
      {
        "index": 196,
        "prompt": "Write a function to transpose a rectangular matrix.",
        "teacher_output": "import unittest\ndef transpose_matrix(matrix):\r\n  n = len(matrix)\r\n  m = len(matrix[0])\r\n  result = [[None] * m for _ in range(n)]\r\n  for i in range(n):\r\n    for j in range(m):\r\n      result[i][j] = matrix[i][j]\r\n  return result\r\ndef test_transpose_matrix():\r\n  unittest.main()\r\ndef test_transpose_matrix_1():\r\n  result = transpose_matrix([",
        "base_output": "def transpose_matrix(matrix):\n    # Your code here\n    pass",
        "teacher_ppl": 1.4598411648895064,
        "base_ppl": 9.749983675700067,
        "ppl_diff": -8.290142510810561,
        "would_be_filtered": false
      },
      {
        "index": 198,
        "prompt": "Write a function to count the number of palindromic substrings in a string.",
        "teacher_output": "def count_palindromes(s):\r\n  count = 0\r\n  for i in range(len(s)-1, -1, -1):\r\n    if s[i] != s[i-1]:\r\n      break\r\n  count += 1\r\n  return count",
        "base_output": "def count_palindromes(s):\n    # ...\n    return ...",
        "teacher_ppl": 1.6168818801321494,
        "base_ppl": 8.15079863098526,
        "ppl_diff": -6.533916750853111,
        "would_be_filtered": true
      },
      {
        "index": 199,
        "prompt": "Write a function to generate the powerset of a list.",
        "teacher_output": "def powerset(list):\r\n  if not list:\r\n    return [()]\r\n  else:\r\n    return list(itertools.combinations(list, 2)) + list(itertools.combinations(list, 3))\r\ndef test_powerset():\r\n  assert powerset([1,2]) == [()]\r\n  assert powerset([]) == [()]\r\n  assert len(powerset([1,2,3])) == 8\r\ntest_powerset()",
        "base_output": "def powerset(list):\n    # ...\n    return ...",
        "teacher_ppl": 1.9804617148588,
        "base_ppl": 10.59785553824521,
        "ppl_diff": -8.61739382338641,
        "would_be_filtered": true
      },
      {
        "index": 202,
        "prompt": "Write a function to validate if all brackets are closed properly in a string.",
        "teacher_output": "def valid_brackets(test_str):\r\n  if test_str == '':\r\n    return True\r\n  open_brackets = set(['(',\r\n                     '[',\r\n                     '{'\r\n                    ])\r\n  close_brackets = set([')', \r\n                      ']',\r\n                      '}'\r\n                     ])\r\n  if any(close_brackets.discard(c) not in test_str for c in open_brackets):\r\n    return False\r\n  return True\r\n[END]",
        "base_output": "def valid_brackets(s):\n    # ...\n    return True",
        "teacher_ppl": 1.8458098624076669,
        "base_ppl": 6.315359826381565,
        "ppl_diff": -4.469549963973898,
        "would_be_filtered": true
      },
      {
        "index": 203,
        "prompt": "Write a function to return the length of the longest word in a sentence.",
        "teacher_output": "def longest_word_length(s):\r\n  return len(s)",
        "base_output": "def longest_word_length(sentence):\n    # Your code goes here\n    return",
        "teacher_ppl": 4.069013044378924,
        "base_ppl": 5.745575642085395,
        "ppl_diff": -1.6765625977064715,
        "would_be_filtered": true
      },
      {
        "index": 204,
        "prompt": "Write a function to convert all keys of a dictionary to lowercase.",
        "teacher_output": "def lowercase_keys(dct):\r\n  return (dct)\r\ndef test_lowercase_keys():\r\n    dict = {'A': 1, 'B': 2}\r\n    lowercase_dict = lowercase_keys(dict)\r\n    assert lowercase_dict == {'a': 1, 'b': 2}\r\n    dict = {'Key': 'Value'}\r\n    lowercase_dict = lowercase_keys(dict)\r\n    assert lowercase_dict == {'key': 'Value'}\r\n    dict = {}\r\n    lowercase_",
        "base_output": "def lowercase_keys(dct):\n    return {k.lower() for k in dct.keys()}",
        "teacher_ppl": 1.7767818973392768,
        "base_ppl": 3.293169104062344,
        "ppl_diff": -1.516387206723067,
        "would_be_filtered": true
      },
      {
        "index": 205,
        "prompt": "Write a function to return True if all elements in a matrix are equal.",
        "teacher_output": "def all_elements_equal(matrix):\r\n  for i in range(len(matrix)):\r\n    for j in range(len(matrix[0])):\r\n      if matrix[i][j] != matrix[i][j]:\r\n        return False\r\n  return True\r\n\r\n[END]",
        "base_output": "def all_elements_equal(matrix):\n    # ...\n    return True",
        "teacher_ppl": 1.6563106892498656,
        "base_ppl": 10.173381382969794,
        "ppl_diff": -8.517070693719928,
        "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):\r\n  count = 0\r\n  for c in s:\r\n    if c.isdigit():\r\n      count += 1\r\n  return count",
        "base_output": "def count_digits(s):\n    return len([c for c in s if c.isdigit()])",
        "teacher_ppl": 1.3108304698725322,
        "base_ppl": 2.8824909663051512,
        "ppl_diff": -1.571660496432619,
        "would_be_filtered": false
      },
      {
        "index": 207,
        "prompt": "Write a function to return the intersection of two lists, preserving the order from the first list.",
        "teacher_output": "def ordered_intersection(list1, list2):\r\n    result = set(list1).intersection(list2)\r\n    return result\r\ndef test_ordered_intersection():\r\n    result = ordered_intersection([1,2,3], [2,3,4])\r\n    assert result == [2,3]\r\n    result = ordered_intersection([1,2], [3,4])\r\n    assert result == []\r\n    result = ordered_intersection( [], [1,2])\r\n    assert result == []\r\nif",
        "base_output": "def ordered_intersection(list1, list2):\n    # ...\n    return list1[::-1].intersection(list2[::-1])\n#### -1",
        "teacher_ppl": 1.605543116375171,
        "base_ppl": 4.739464996892277,
        "ppl_diff": -3.1339218805171063,
        "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 squares_dict(n):\r\n  d = {k: 0 for k in range(n + 1)}\r\n  for i in range(n + 1):\r\n    d[i] = i * i\r\n  return d\r\n[END]",
        "base_output": "def squares_dict(n):\n    return {i**2 for i in range(n)}\n#### 2",
        "teacher_ppl": 2.037689361955463,
        "base_ppl": 6.293028899695676,
        "ppl_diff": -4.255339537740213,
        "would_be_filtered": true
      },
      {
        "index": 210,
        "prompt": "Write a function to check if a given year is a leap year.",
        "teacher_output": "import datetime\n\ndef is_leap_year(year):\n    if year % 4 == 0 and year % 100 != 0:\n        return True\n    elif year % 400 == 0:\n        return True\n    else:\n        return False",
        "base_output": "def is_leap_year(year):\n    # ...\n    return year % 4 == 0 and year % 100 != 0 or year % 400 == 0\n#### 0",
        "teacher_ppl": 1.361567897645599,
        "base_ppl": 3.197612257832801,
        "ppl_diff": -1.8360443601872019,
        "would_be_filtered": false
      },
      {
        "index": 212,
        "prompt": "Write a function to remove every nth element from a list.",
        "teacher_output": "def remove_every_nth(list, n):\r\n    return list[::n]\r\ndef test_remove_every_nth():\r\n    list = [1,2,3,4,5,6]\r\n    result = remove_every_nth(list, 2)\r\n    assert result == [1,3,5]\r\n    result = remove_every_nth([1,2,3], 1)\r\n    assert result == []\r\n    result = remove_every_nth([1,2,3,4], 5)\r\n    assert",
        "base_output": "def remove_every_nth(list, n):\n    # Your code here\n    pass",
        "teacher_ppl": 1.7803568371034333,
        "base_ppl": 4.385690243055572,
        "ppl_diff": -2.6053334059521394,
        "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_of(list, element):\r\n    for i, item in enumerate(list):\r\n        if item == element:\r\n            return i\r\n    return -1\r\n\r\n[END]",
        "base_output": "def last_index_of(list, element):\n    # Your code here\n    return -1\n#### -1",
        "teacher_ppl": 1.7883078174374158,
        "base_ppl": 6.757987236555416,
        "ppl_diff": -4.969679419118,
        "would_be_filtered": true
      },
      {
        "index": 215,
        "prompt": "Write a function to calculate the product of all elements in a list.",
        "teacher_output": "def list_product(list1):\r\n  if not list1:\r\n    return 1\r\n  return 1 if len(list1) == 1 else 1 + list_product(list1[1:])\r\n\r\n[END]",
        "base_output": "def list_product(list):\n    # Your code here\n    return None",
        "teacher_ppl": 2.04006771623011,
        "base_ppl": 11.13234794637268,
        "ppl_diff": -9.09228023014257,
        "would_be_filtered": true
      },
      {
        "index": 216,
        "prompt": "Write a function to generate the first n even numbers.",
        "teacher_output": "import random\ndef first_n_evens(n):\r\n  if n <= 0:\r\n    return []\r\n  evens = [2*i for i in range(n)]\r\n  evens.extend([2*i + 1 for i in range(n)])\r\n  return evens",
        "base_output": "def first_n_evens(n):\n    # Write code here\n    return []",
        "teacher_ppl": 1.6557457263089819,
        "base_ppl": 7.5617519857307265,
        "ppl_diff": -5.906006259421744,
        "would_be_filtered": true
      },
      {
        "index": 217,
        "prompt": "Write a function to count how many times a given word appears in a sentence.",
        "teacher_output": "def word_frequency(text, word):\r\n    count = 0\r\n    for i in text:\r\n        if i == word:\r\n            count += 1\r\n    return count",
        "base_output": "def word_frequency(sentence, word):\n    # ...\n    return count",
        "teacher_ppl": 1.5994275384770678,
        "base_ppl": 6.407333454858515,
        "ppl_diff": -4.807905916381447,
        "would_be_filtered": true
      },
      {
        "index": 218,
        "prompt": "Write a function to find the maximum value in each row of a matrix.",
        "teacher_output": "def row_maxima(matrix):\r\n  n = len(matrix)\r\n  res = [max(row) for row in matrix]\r\n  return res",
        "base_output": "def row_maxima(matrix):\n    # ...\n    return max(row[i] for i in range(len(row)))",
        "teacher_ppl": 2.2992151788506776,
        "base_ppl": 5.624017846005613,
        "ppl_diff": -3.3248026671549358,
        "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 alternating_binary(n):\r\n  if n == 0:\r\n    return ''\r\n  else:\r\n    return str(n % 2)\r\n[END]",
        "base_output": "def alternating_binary(n):\n    # ...\n    return result\n",
        "teacher_ppl": 2.873309421232846,
        "base_ppl": 15.62184401169721,
        "ppl_diff": -12.748534590464363,
        "would_be_filtered": true
      },
      {
        "index": 222,
        "prompt": "Write a function to check if a list contains only integers.",
        "teacher_output": "def all_integers(test_list):\r\n  for i in range(len(test_list)):\r\n    if not isinstance(test_list[i], int):\r\n      return False\r\n  return True\r\n[END]",
        "base_output": "def all_integers(numbers):\n    return all(isinstance(x, int) for x in numbers)\n",
        "teacher_ppl": 1.920695108945234,
        "base_ppl": 3.3379882676587846,
        "ppl_diff": -1.4172931587135507,
        "would_be_filtered": true
      },
      {
        "index": 223,
        "prompt": "Write a function to double each value in a dictionary.",
        "teacher_output": "def double_values(dct):\r\n  res = {}\r\n  for key, val in dct.items():\r\n    res[key] = val * 2\r\n  return res",
        "base_output": "def double_values(d):\n    return {k: 2*v for k, v in d.items()}\n#### 2",
        "teacher_ppl": 1.5815409590389262,
        "base_ppl": 3.478981794013055,
        "ppl_diff": -1.8974408349741287,
        "would_be_filtered": true
      },
      {
        "index": 224,
        "prompt": "Write a function to convert a list of binary strings to decimal integers.",
        "teacher_output": "def binary_to_decimals(binary_list):\r\n    decimals = [int(i, 2) for i in binary_list]\r\n    return decimals",
        "base_output": "def binary_to_decimals(binary_list):\n    # Your code here\n    return decimals",
        "teacher_ppl": 1.8708419174878441,
        "base_ppl": 6.685298376057619,
        "ppl_diff": -4.814456458569775,
        "would_be_filtered": true
      },
      {
        "index": 225,
        "prompt": "Write a function to check if all elements in a list are the same.",
        "teacher_output": "def all_equal(list1):\r\n  return all(list1 == list1[0])\r\n  \r\ndef main():\r\n  result = all_equal([1, 2, 3])\r\n  if result:\r\n    print(\"All elements are equal\")\r\n  else:\r\n    print(\"All elements are not equal\")\r\n  \r\nif __name__ == '__main__':\r\n  main()",
        "base_output": "def all_equal(list):\n    return len(list) == 1 and list[0] == list[0]\n#### 0",
        "teacher_ppl": 1.6392584224899882,
        "base_ppl": 3.9883418566352726,
        "ppl_diff": -2.3490834341452844,
        "would_be_filtered": true
      },
      {
        "index": 226,
        "prompt": "Write a function to count the number of capital letters in a string.",
        "teacher_output": "def count_capitals(s):\r\n  count = 0\r\n  for i in s:\r\n    if i.isupper():\r\n      count += 1\r\n  return count",
        "base_output": "def count_capitals(s):\n    \"\"\"\n    Count the number of capital letters in a string.\n    \"\"\"\n    return len([c for c in s if c.isupper()])",
        "teacher_ppl": 1.413228400446593,
        "base_ppl": 2.4620544365927723,
        "ppl_diff": -1.0488260361461794,
        "would_be_filtered": false
      },
      {
        "index": 227,
        "prompt": "Write a function to find the second smallest number in a list.",
        "teacher_output": "def second_smallest(nums):\r\n  if len(nums) <= 1:\r\n    return None\r\n  return min(nums[1:], key=lambda x: x)\r\n\r\n[END]",
        "base_output": "def second_smallest(numbers):\n    # ...\n    return smallest(numbers[1:])\n#### 1",
        "teacher_ppl": 1.8333432079561947,
        "base_ppl": 9.70983789199294,
        "ppl_diff": -7.876494684036746,
        "would_be_filtered": true
      },
      {
        "index": 228,
        "prompt": "Write a function to return the first n Fibonacci numbers.",
        "teacher_output": "def fibonacci(n):\r\n  if n <= 0:\r\n    return []\r\n  if n == 1:\r\n    return [1]\r\n  if n == 2:\r\n    return [1, 1]\r\n  if n == 3:\r\n    return [1, 2, 1]\r\n  if n == 4:\r\n    return [1, 3, 2, 1]\r\n  if n == 5:\r\n    return [1, 5, 8, 3,",
        "base_output": "def fibonacci(n):\n    if n <= 1:\n        return [0]\n    else:\n        return fibonacci(n-1) + fibonacci(n-2)\n#### -2",
        "teacher_ppl": 1.254442127786694,
        "base_ppl": 3.0619894085550663,
        "ppl_diff": -1.8075472807683723,
        "would_be_filtered": false
      },
      {
        "index": 229,
        "prompt": "Write a function to get the middle character(s) of a string.",
        "teacher_output": "def middle_characters(str):\r\n  if len(str) < 2:\r\n    return str\r\n  return str[len(str) // 2]\r\n[END]",
        "base_output": "def middle_characters(str):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 2.1934456548604313,
        "base_ppl": 9.68187615235931,
        "ppl_diff": -7.488430497498879,
        "would_be_filtered": true
      },
      {
        "index": 230,
        "prompt": "Write a function to remove the first and last characters of a string.",
        "teacher_output": "import unittest\n\ndef remove_ends(s):\r\n  return s[1:-1]\r\n\r\ndef test_remove_ends():\r\n  unittest.main()\r\n[END]",
        "base_output": "def remove_ends(s):\n    return s[1:-1]\n#### -1",
        "teacher_ppl": 3.156123682434821,
        "base_ppl": 8.718724133726257,
        "ppl_diff": -5.562600451291436,
        "would_be_filtered": true
      },
      {
        "index": 231,
        "prompt": "Write a function to flatten a list of tuples.",
        "teacher_output": "def flatten_tuples(test_list):\r\n  res = list()\r\n  for sub in test_list:\r\n    res.extend(sub)\r\n  return res",
        "base_output": "def flatten_tuples(lst):\n    return lst",
        "teacher_ppl": 1.8826077576240439,
        "base_ppl": 5.156183087153751,
        "ppl_diff": -3.2735753295297076,
        "would_be_filtered": true
      },
      {
        "index": 232,
        "prompt": "Write a function to check if a list is a palindrome.",
        "teacher_output": "def is_list_palindrome(list1):\r\n  if len(list1) < 2:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[-i-1] for i in range(len(list1)-1))\r\n\r\n[END]",
        "base_output": "def is_list_palindrome(my_list):\n    # ...\n    return ...\nEND",
        "teacher_ppl": 1.8702731123715783,
        "base_ppl": 10.819283809672687,
        "ppl_diff": -8.949010697301109,
        "would_be_filtered": true
      },
      {
        "index": 233,
        "prompt": "Write a function to return the unique elements of a list, preserving order.",
        "teacher_output": "def unique_ordered(list1):\r\n  seen = set()\r\n  return list1\r\n  \r\ndef test_unique_ordered():\r\n  result = unique_ordered([1,2,2,3])\r\n  assert result == [1,2,3]\r\n  result = unique_ordered([1,1,1])\r\n  assert result == [1]\r\n  result = unique_ordered([])\r\n  assert result == []\r\n  \r\ntest_unique_ordered()",
        "base_output": "def unique_ordered(list):\n    # ...\n    return list",
        "teacher_ppl": 1.887184619874813,
        "base_ppl": 10.941879814865251,
        "ppl_diff": -9.054695194990439,
        "would_be_filtered": true
      },
      {
        "index": 234,
        "prompt": "Write a function to find the intersection of multiple sets.",
        "teacher_output": "def set_intersection(set1, set2):\r\n    result = set()\r\n    for ele in set1:\r\n        if ele in set2:\r\n            result.add(ele)\r\n    return result",
        "base_output": "def set_intersection(set1, set2):\n    # ...\n    return intersection\n#### 2",
        "teacher_ppl": 1.4082393645218882,
        "base_ppl": 10.773958671351737,
        "ppl_diff": -9.365719306829849,
        "would_be_filtered": false
      },
      {
        "index": 235,
        "prompt": "Write a function to return the digit sum of a string containing digits.",
        "teacher_output": "import unittest\ndef digit_sum_string(str1):\r\n  sum = 0\r\n  for i in range(len(str1)):\r\n    sum = sum + int(str1[i])\r\n  return sum\r\ndef test_digit_sum_string():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_digit_sum_string()\r\n[END]",
        "base_output": "def digit_sum_string(s):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.6962095748053232,
        "base_ppl": 13.174488427833714,
        "ppl_diff": -11.47827885302839,
        "would_be_filtered": true
      },
      {
        "index": 236,
        "prompt": "Write a function to convert a list of strings to uppercase.",
        "teacher_output": "def to_uppercase(list1):\r\n  res = [ele.upper() for ele in list1]\r\n  return res",
        "base_output": "def to_uppercase(strings):\n    return [s.upper() for s in strings]",
        "teacher_ppl": 1.903202285803229,
        "base_ppl": 3.208987232107084,
        "ppl_diff": -1.3057849463038549,
        "would_be_filtered": true
      },
      {
        "index": 237,
        "prompt": "Write a function to check if all elements in a list are distinct.",
        "teacher_output": "def all_distinct(list1):\r\n  if len(list1) <= 0:\r\n    return True\r\n  else:\r\n    return all(sorted(list1) == list1)",
        "base_output": "def all_distinct(my_list):\n    # ...\n    return True",
        "teacher_ppl": 1.766331606346822,
        "base_ppl": 8.632029377571964,
        "ppl_diff": -6.865697771225142,
        "would_be_filtered": true
      },
      {
        "index": 238,
        "prompt": "Write a function to return the ASCII value of each character in a string.",
        "teacher_output": "import unittest\ndef ascii_values(s):\r\n  return [ord(i) for i in s]\r\ndef test_cases():\r\n  return [\r\n      (\"ABC\", [65, 66, 67]),\r\n      (\"\", []),\r\n      (\"a\", [97]),\r\n  ]\r\ndef run_tests():\r\n  result = unittest.main()\r\n  return result\r\nrun_tests()\r\n[END]",
        "base_output": "def ascii_values(s):\n    # ...\n    return values",
        "teacher_ppl": 2.2112867452671976,
        "base_ppl": 7.646233014226068,
        "ppl_diff": -5.43494626895887,
        "would_be_filtered": true
      },
      {
        "index": 239,
        "prompt": "Write a function to count how many booleans are True in a list.",
        "teacher_output": "def count_true(list):\r\n  count = 0\r\n  for element in list:\r\n    if element:\r\n      count += 1\r\n  return count",
        "base_output": "def count_true(list):\n    count = 0\n    for element in list:\n        if element:\n            count += 1\n    return count\n#### 1",
        "teacher_ppl": 1.4118962192885465,
        "base_ppl": 2.821757416137681,
        "ppl_diff": -1.4098611968491346,
        "would_be_filtered": false
      },
      {
        "index": 240,
        "prompt": "Write a function to return the index of the first maximum in a list.",
        "teacher_output": "def first_max_index(list):\r\n  if not list:\r\n    return -1\r\n  max_value = list[0]\r\n  for i in range(1, len(list)):\r\n    if list[i] > max_value:\r\n      max_value = list[i]\r\n  return i\r\n\r\ndef test_first_max_index():\r\n  result = first_max_index([1,3,2,3])\r\n  assert result == 1\r\n  result = first_max_index([5",
        "base_output": "def first_max_index(numbers):\n    # Your code goes here\n    return -1\n#### -1",
        "teacher_ppl": 1.573307268554251,
        "base_ppl": 9.177737197155894,
        "ppl_diff": -7.604429928601643,
        "would_be_filtered": true
      },
      {
        "index": 241,
        "prompt": "Write a function to group words in a list by their starting letter.",
        "teacher_output": "def group_by_first_letter(word_list):\r\n    result = {c:[] for c in string.ascii_letters}\r\n    for word in word_list:\r\n        result[word[0]].append(word)\r\n    return result\r\n\r\n def test_group_by_first_letter():\r\n    result = group_by_first_letter(['apple', 'ant', 'bat']) \r\n    assert result == {'a': ['apple', 'ant']}\r\n    result = group_by_first_letter([])",
        "base_output": "def group_by_first_letter(words):\n    return {word[0]:word for word in words}\n#### 0",
        "teacher_ppl": 1.8485543739767405,
        "base_ppl": 4.408449678713091,
        "ppl_diff": -2.559895304736351,
        "would_be_filtered": true
      },
      {
        "index": 242,
        "prompt": "Write a function to calculate the cumulative sum of a list.",
        "teacher_output": "def cumulative_sum(numbers):\r\n  result = [sum(numbers[:i]) + sum(numbers[i:]) for i in range(len(numbers)-1)]\r\n  return result",
        "base_output": "def cumulative_sum(numbers):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.7590540774456433,
        "base_ppl": 6.568322323135222,
        "ppl_diff": -4.809268245689578,
        "would_be_filtered": true
      },
      {
        "index": 243,
        "prompt": "Write a function to check if a number has repeated digits.",
        "teacher_output": "import unittest\ndef has_repeated_digits(n):\r\n  if n < 10:\r\n    return False\r\n  for i in range(10, 10 + n // 10):\r\n    if n % i == 0:\r\n      return True\r\n  return False\r\ndef test_has_repeated_digits():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_repeated_digits()\r\n[END]",
        "base_output": "def has_repeated_digits(n):\n    # Your code goes here\n    return\n",
        "teacher_ppl": 1.5298809885935902,
        "base_ppl": 6.6204670266985755,
        "ppl_diff": -5.090586038104985,
        "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(s):\r\n  count = 0\r\n  for c in s:\r\n    if c in 'aeiou':\r\n      count += 1\r\n  return count",
        "base_output": "def count_vowels(s):\n    \"\"\"\n    Return the number of vowels in the given string.\n    \"\"\"\n    return len([c for c in s if c in 'AEIOU']);\n",
        "teacher_ppl": 1.4380448611218117,
        "base_ppl": 2.560751614403658,
        "ppl_diff": -1.1227067532818462,
        "would_be_filtered": false
      },
      {
        "index": 245,
        "prompt": "Write a function to get the largest key in a dictionary.",
        "teacher_output": "def max_dict_key(dct):\r\n  if not dct:\r\n    return None\r\n  return max(dct.keys())\r\n[END]",
        "base_output": "def max_dict_key(dict):\n    return max(dict.keys())",
        "teacher_ppl": 2.950829083607006,
        "base_ppl": 4.04290249219019,
        "ppl_diff": -1.0920734085831838,
        "would_be_filtered": true
      },
      {
        "index": 246,
        "prompt": "Write a function to check whether a string has any repeated characters.",
        "teacher_output": "import unittest\ndef has_repeats(s):\r\n  count = 0\r\n  for c in s:\r\n    count += 1\r\n  return count > 1\r\ndef test_has_repeats():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_repeats()\r\n[END]",
        "base_output": "def has_repeats(s):\n    # ...\n    return False",
        "teacher_ppl": 1.9801824685548048,
        "base_ppl": 9.605281691446335,
        "ppl_diff": -7.62509922289153,
        "would_be_filtered": true
      },
      {
        "index": 247,
        "prompt": "Write a function to reverse the digits of a number.",
        "teacher_output": "def reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\nIn other words, you must write a function that takes a number as input, and returns the number in reverse order. For example, if you input 123, the function should return 321. If you input -456, the function should return -654, and so on.",
        "base_output": "def reverse_number(n):\n    # Your code goes here\n    pass",
        "teacher_ppl": 1.9142138602118042,
        "base_ppl": 9.434639880790092,
        "ppl_diff": -7.520426020578288,
        "would_be_filtered": true
      },
      {
        "index": 248,
        "prompt": "Write a function to check if a number is a palindrome.",
        "teacher_output": "import unittest\ndef is_palindrome_number(n):\r\n  if n < 1000000:\r\n    return n\r\n  else:\r\n    return n % 1000000 == 0 and n % 100000 == 0 and n % 1000 == 0 and n % 100 == 0 and n % 10 == 0\r\ndef test_palindrome():\r\n  unittest.main()\r\ndef test_palindrome_number():",
        "base_output": "def is_palindrome_number(n):\n    # Your code goes here\n    return",
        "teacher_ppl": 1.653249749735537,
        "base_ppl": 7.589324518576762,
        "ppl_diff": -5.936074768841225,
        "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": "import unittest\n\ndef square_root_newton(n):\n    if n == 0:\n        return 0\n    else:\n        return (1 / n) - (1 / (2 * n)) + (1 / (3 * n)) - (1 / (4 * n)) + ...\n\ndef test_square_root_newton():\n    unittest.main()\n\nif __name__ == '__main__':\n    test_square_root_newton()\n\n[END]\n\nExplanation:\n\nThe Newton-R",
        "base_output": "def square_root(x):\n    return x ** 0.5\n#### 0.5",
        "teacher_ppl": 1.73230831586137,
        "base_ppl": 8.150554780705127,
        "ppl_diff": -6.418246464843757,
        "would_be_filtered": true
      }
    ],
    "Better (Teacher < Base)": [
      {
        "index": 14,
        "prompt": "Write a function to compute the nth Fibonacci number using iteration.",
        "teacher_output": "import unittest\ndef fibonacci(n):\r\n  if n <= 1:\r\n    return n\r\n  else:\r\n    return fibonacci(n-1) + fibonacci(n-2)",
        "base_output": "def fibonacci(n):\n    if n <= 1:\n        return n\n    else:\n        return fibonacci(n-1) + fibonacci(n-2)\n\n#### -2",
        "teacher_ppl": 1.5936674140924776,
        "base_ppl": 2.3670013683209805,
        "ppl_diff": -0.7733339542285029,
        "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 primes_below(n):\r\n def sieve_of_eratosthenes(n):\r\n    sieve = [True] * (n + 1) \r\n    for p in range(2, int(n**0.5) + 1):\r\n        sieve[p] = False\r\n    return sieve\r\n def is_prime(n):\r\n    for p in range(2, int(n**0.5) + 1):\r\n        if sieve_of_eratosthenes(n) == [",
        "base_output": "def primes_below(n):\n    # Base case: if n is 1, return [1]\n    if n == 1:\n        return [1]\n    # Recursive case: if n is greater than 1 and it is not a prime, return the list of all prime numbers less than n\n    else:\n        return [*primes_below(n // 2), *primes_below(n // 2 + 1)]\n#### 1",
        "teacher_ppl": 1.620071214482968,
        "base_ppl": 2.2320030415488397,
        "ppl_diff": -0.6119318270658716,
        "would_be_filtered": true
      },
      {
        "index": 24,
        "prompt": "Write a function to remove empty strings from a list.",
        "teacher_output": "def remove_empty_strings(list1):\r\n  return list1\r\ndef test_remove_empty_strings():\r\n  list1 = [\"a\", '', 'b']\r\n  result = remove_empty_strings(list1)\r\n  assert result == ['a', 'b']\r\n  \r\n  list1 = []\r\n  result = remove_empty_strings(list1)\r\n  assert result == []\r\n  \r\n  list1 = \"hello\"\r\n  result = remove_empty_strings(list1)\r\n  assert result == \"hello\"",
        "base_output": "def remove_empty_strings(list):\n    return [x for x in list if x != \"\"];",
        "teacher_ppl": 1.753500829656083,
        "base_ppl": 2.5382667903447294,
        "ppl_diff": -0.7847659606886463,
        "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_ordered(list1):\r\n  result = list1[:]\r\n  for i in range(1, len(list1)):\r\n    if result[i] == result[i-1]:\r\n      result.pop()\r\n  return result\r\n\r\ndef test_unique_ordered():\r\n  result = unique_ordered([1,2,2,3])\r\n  assert result == [1,2,3]\r\n  result = unique_ordered([])\r\n  assert result == []\r\n  result = unique_ordered([1,1",
        "base_output": "def unique_ordered(seq):\n    seen = set()\n    return [x for x in seq if x not in seen and seen.add(x)]",
        "teacher_ppl": 1.644957468732417,
        "base_ppl": 2.53982828291626,
        "ppl_diff": -0.8948708141838431,
        "would_be_filtered": true
      },
      {
        "index": 38,
        "prompt": "Write a function to count how many times each character appears in a string.",
        "teacher_output": "def char_frequency(text):\r\n  count = {}\r\n  for i in text:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n\r\n[END]",
        "base_output": "def char_frequency(s):\n    count = {}\n    for c in s:\n        count[c] = count.get(c, 0) + 1\n    return count\n#### 1",
        "teacher_ppl": 2.205753987330896,
        "base_ppl": 2.634167047745701,
        "ppl_diff": -0.4284130604148051,
        "would_be_filtered": true
      },
      {
        "index": 41,
        "prompt": "Write a function to flatten a nested dictionary with dot notation.",
        "teacher_output": "def flatten_dict(dct):\r\n  res = {}\r\n  for key, val in dct.items():\r\n    if isinstance(val, dict):\r\n      res.update(flatten_dict(val))\r\n    else:\r\n      res[key] = val\r\n  return res",
        "base_output": "def flatten_dict(dct):\n    return {k: v for k, v in dct.items() if not isinstance(v, dict)}",
        "teacher_ppl": 1.2010454491747886,
        "base_ppl": 1.803472139411721,
        "ppl_diff": -0.6024266902369324,
        "would_be_filtered": false
      },
      {
        "index": 43,
        "prompt": "Write a function to find the longest increasing contiguous subsequence in a list.",
        "teacher_output": "def longest_increasing_subsequence(arr):\r\n    n = len(arr)\r\n    dp = [0 for _ in range(n + 1)]\r\n    dp[0] = 0\r\n    for i in range(1, n + 1):\r\n        dp[i] = max(dp[i - 1], arr[i] + dp[i - 1])\r\n    return dp[n - 1]\r\n[END]",
        "base_output": "def longest_increasing_subsequence(seq):\n    # Base case: If the list is empty, return 0\n    if len(seq) == 0:\n        return 0\n    \n    # Find the first element that is greater than the previous element\n    # and keep track of the longest increasing subsequence\n    for i in range(len(seq) - 1):\n        if seq[i] > seq[i - 1]:\n            longest_subsequence = seq[i]\n            break\n    else:\n        # If no element is greater than\n#### 1",
        "teacher_ppl": 1.419641406930302,
        "base_ppl": 2.283727632970928,
        "ppl_diff": -0.8640862260406259,
        "would_be_filtered": false
      },
      {
        "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(m, n):\r\n    dp = [[0] * (n + 1) for _ in range(m + 1)]\r\n    for i in range(m + 1):\r\n        for j in range(n + 1):\r\n            if i == 0 or j == 0:\r\n                dp[i][j] = 1\r\n            elif i == m or j == n:\r\n                dp[i][j] = 0\r\n            else:\r\n                dp[i][j]",
        "base_output": "def count_paths(m, n):\n    # Dynamic programming\n    dp = [[0] * (n+1) for _ in range(m+1)]\n    for i in range(m+1):\n        for j in range(n+1):\n            if i == 0 or j == 0:\n                dp[i][j] = 1\n            else:\n                dp[i][j] = dp[i-1][j-1] + dp[i-1][j]\n    return dp[m][n\n#### -1",
        "teacher_ppl": 1.2081191030024692,
        "base_ppl": 1.7700906145728328,
        "ppl_diff": -0.5619715115703636,
        "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": "import math\ndef is_strong_number(n):\r\n  if n < 1:\r\n    return False\r\n  if n == 1:\r\n    return True\r\n  if n % 10 == 0:\r\n    return False\r\n  for i in range(1, math.log10(n) + 1):\r\n    if n % 10 == 0:\r\n      return False\r\n  return True\r\ndef test_strong_number():\r\n  n = 145\r\n  assert is_strong",
        "base_output": "def is_strong_number(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: calculate factorial of digits and compare with n\n    for i in range(1, len(str(n))+1):\n        if str(n)[i] == '0':\n            n = n - (n % 10) * pow(10, i-1)\n            continue\n    return n == sum(map(lambda x: pow(10\n#### 10",
        "teacher_ppl": 1.6310407776674918,
        "base_ppl": 2.3757589882752934,
        "ppl_diff": -0.7447182106078016,
        "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(n):\r\n    if n == '':\r\n        return '0'\r\n    s = n.replace(' ', '')\r\n    s = s.replace('-', '')\r\n    s = s.replace('+', '')\r\n    s = s.replace('/', '')\r\n    s = s.replace('*', '')\r\n    s = s.replace('%', '')\r\n    s = s.replace('$', '')\r\n    s = s.replace('^', '')\r\n    s = s.replace('&",
        "base_output": "def luhn_checksum(number_string):\n    # Initialize a checksum variable\n    checksum = 0\n    # Iterate through each digit of the number string\n    for digit in number_string:\n        # Add the digit to the checksum\n        checksum = checksum + digit * 10\n        # Modulo 10 to get the next digit\n        checksum = checksum % 10\n    # Return the checksum\n    return checksum\n#### 10",
        "teacher_ppl": 1.370966314028326,
        "base_ppl": 1.942763029998233,
        "ppl_diff": -0.5717967159699071,
        "would_be_filtered": false
      },
      {
        "index": 91,
        "prompt": "Write a function to compress a string using run-length encoding.",
        "teacher_output": "import unittest\ndef run_length_encode(s):\r\n    result = ''\r\n    for i, c in enumerate(s):\r\n        if c == s[i-1]:\r\n            result += str(s[i-1]) + str(i+1)\r\n        else:\r\n            result += str(i+1)\r\n    return result\r\ndef test_run_length_encode():\r\n    unittest.TestCase().testMethod(run_length_encode)()\r\nif __name__ == '__main__':\r\n    test_",
        "base_output": "def run_length_encode(s):\n    # Initialize an empty list to store the encoded string\n    encoded = []\n    \n    # Iterate through the characters of the input string\n    for c in s:\n        # If the character is not ' ', encode it as a run of length\n        # Otherwise, encode it as a single character\n        if c != ' ':\n            encoded.append(c)\n        else:\n            encoded.append(c * len(s.split(c)))\n    \n    # Return the encoded string\n    return ''.join(encoded",
        "teacher_ppl": 1.5390771410218897,
        "base_ppl": 1.8613151986382626,
        "ppl_diff": -0.3222380576163728,
        "would_be_filtered": true
      },
      {
        "index": 97,
        "prompt": "Write a function to get the unique prime factors of a number.",
        "teacher_output": "import math\ndef prime_factors(n):\r\n  if n == 0:\r\n    return []\r\n  factors = []\r\n  while n != 0:\r\n    i = 0\r\n    while i < 100:\r\n      if n % 2 == 0 or n % i == 0:\r\n        break\r\n      i += 1\r\n    if i == 100:\r\n      factors.append(n)\r\n      n = 0\r\n    else:\r\n      n = n // i",
        "base_output": "def prime_factors(n):\n    # base case: n = 1\n    if n == 1:\n        return [1]\n    # recursive case: n > 1\n    else:\n        factors = []\n        for p in range(2, int(n ** 0.5) + 1):\n            if n % p == 0:\n                factors.append(p)\n                n = n // p\n                if n == 1:\n                    break\n        return factors\n#### 1",
        "teacher_ppl": 1.4817200024902317,
        "base_ppl": 1.8050216763468228,
        "ppl_diff": -0.32330167385659103,
        "would_be_filtered": false
      },
      {
        "index": 103,
        "prompt": "Write a function to check if a list contains all elements of another list.",
        "teacher_output": "def contains_all(list1, list2):\r\n    for i in list2:\r\n        if i not in list1:\r\n            return False\r\n    return True\r\n[END]",
        "base_output": "def contains_all(list1, list2):\n    return len(list1) == len(set(list1) & set(list2))\n#### 2",
        "teacher_ppl": 1.86564968412298,
        "base_ppl": 2.7688888717623446,
        "ppl_diff": -0.9032391876393646,
        "would_be_filtered": true
      },
      {
        "index": 134,
        "prompt": "Write a function to remove consecutive duplicates from a list.",
        "teacher_output": "def remove_consecutive_duplicates(list1):\r\n  res = list1[:]\r\n  for i in range(len(res) - 1):\r\n    if res[i] == res[i + 1]:\r\n      res.pop(i + 1)\r\n  return res",
        "base_output": "def remove_consecutive_duplicates(list):\n    # Base case: If the list is empty, return it\n    if len(list) == 0:\n        return list\n    \n    # Find the first element that is not the same as the previous element\n    # (or the first element if the list is not empty)\n    first_diff = list[0]\n    for i in range(1, len(list)):\n        if list[i] != first_diff:\n            break\n    else:\n        # If we reached the end of the list without\n#### 1",
        "teacher_ppl": 1.3460511675132065,
        "base_ppl": 2.221338052616326,
        "ppl_diff": -0.8752868851031197,
        "would_be_filtered": false
      },
      {
        "index": 136,
        "prompt": "Write a function to find the number of digits in an integer.",
        "teacher_output": "def digit_count(n):\r\n  if n < 0:\r\n    return 3\r\n  return 10\r\n[END]",
        "base_output": "def digit_count(n):\n    return len(str(n))",
        "teacher_ppl": 3.2855112584256174,
        "base_ppl": 4.169786088396252,
        "ppl_diff": -0.8842748299706349,
        "would_be_filtered": true
      },
      {
        "index": 137,
        "prompt": "Write a function to replace spaces with underscores in a string.",
        "teacher_output": "import unittest\ndef replace_spaces(s):\r\n  return (s.replace(' ','_'))\r\ndef test_replace_spaces():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_replace_spaces()\r\n[END]",
        "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
        "teacher_ppl": 2.1303963477912387,
        "base_ppl": 2.9727471191381247,
        "ppl_diff": -0.8423507713468861,
        "would_be_filtered": true
      },
      {
        "index": 153,
        "prompt": "Write a function to calculate the sum of ASCII values of characters in a string.",
        "teacher_output": "import re\ndef ascii_sum(s):\r\n  return sum(ord(c) for c in s)",
        "base_output": "def ascii_sum(s):\n    # ...\n    return sum(ord(c) for c in s)",
        "teacher_ppl": 2.2054997514175936,
        "base_ppl": 2.9883917863953804,
        "ppl_diff": -0.7828920349777868,
        "would_be_filtered": true
      },
      {
        "index": 157,
        "prompt": "Write a function to compute the transpose of a matrix.",
        "teacher_output": "import unittest\ndef transpose(matrix):\n  n = len(matrix)\n  if n == 0:\n    return []\n  return [[matrix[i][j] for j in range(n)] for i in range(n)]\ndef test_transpose():\n  unittest.main()\n[END]",
        "base_output": "def transpose(matrix):\n    n = len(matrix)\n    return [row for row in matrix]",
        "teacher_ppl": 2.1658064956349077,
        "base_ppl": 2.878544677560773,
        "ppl_diff": -0.7127381819258654,
        "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_average(nums):\r\n  return sum(nums[i] for i in range(len(nums)) if nums[i] > mean)\r\ndef test_count_above_average():\r\n  n = 5\r\n  mean = sum(nums)/n\r\n  nums = [1,2,3,4,5]\r\n  assert count_above_average(nums) == 2\r\n  assert count_above_average([5,5,5]) == 0\r\n  assert",
        "base_output": "def count_above_average(numbers):\n    # Calculate the average of the list\n    average = sum(numbers) / len(numbers)\n    # Iterate over the list and count the numbers above the average\n    return len([number for number in numbers if number > average])",
        "teacher_ppl": 1.6811849344058472,
        "base_ppl": 2.12346250244882,
        "ppl_diff": -0.4422775680429727,
        "would_be_filtered": true
      },
      {
        "index": 201,
        "prompt": "Write a function to count the frequency of each digit in a number.",
        "teacher_output": "def digit_frequency(n):\r\n  freq = {}\r\n  for i in range(10):\r\n    freq[i] = 0\r\n  while n > 0:\r\n    digit = n % 10\r\n    freq[digit] += 1\r\n    n = n // 10\r\n  return freq\r\n\r\n def test_digit_frequency():\r\n  n = 112233\r\n  assert digit_frequency(n) == {'1': 2,'2':",
        "base_output": "def digit_frequency(n):\n    freq = {}\n    for i in range(10):\n        freq[n % 10] = freq.get(n % 10, 0) + 1\n    return freq\n#### 1",
        "teacher_ppl": 1.6268434134876353,
        "base_ppl": 2.2186529226278537,
        "ppl_diff": -0.5918095091402185,
        "would_be_filtered": true
      },
      {
        "index": 211,
        "prompt": "Write a function to compute the average of positive numbers in a list.",
        "teacher_output": "def average_positive(nums):\r\n  if not nums:\r\n    return 0\r\n  return (sum(nums)) / (len(nums))\r\n[END]",
        "base_output": "def average_positive(numbers):\n    return sum(numbers) / len(numbers)\n",
        "teacher_ppl": 2.6258659308387085,
        "base_ppl": 2.9491778590073894,
        "ppl_diff": -0.32331192816868093,
        "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 divisible_by_all(n, list1):\r\n    for i in range(len(list1)):\r\n        if n % list1[i] != 0:\r\n            return False\r\n    return True\r\n[END]",
        "base_output": "def divisible_by_all(num, list):\n    for element in list:\n        if num % element == 0:\n            return False\n    return True\n\n#### 0",
        "teacher_ppl": 1.8510703940656537,
        "base_ppl": 2.658980198372392,
        "ppl_diff": -0.8079098043067383,
        "would_be_filtered": true
      }
    ],
    "Similar (Teacher \u2248 Base)": [
      {
        "index": 0,
        "prompt": "Write a function to check if a number is an Armstrong number.",
        "teacher_output": "import math\ndef is_armstrong(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(math.log10(n)) + 1):\r\n    if n % 10 == 0:\r\n      return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n    (153,),\r\n    (370,),\r\n    (123,),\r\n  ]\r\n\r\n[END]",
        "base_output": "def is_armstrong(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: n is greater than 1 and is a product of prime numbers\n    for p in range(2, int(n ** 0.5) + 1):\n        if n % p == 0:\n            return False\n    return True\n\n#### 0",
        "teacher_ppl": 2.1093378061829333,
        "base_ppl": 2.0823915112423923,
        "ppl_diff": 0.026946294940541016,
        "would_be_filtered": true
      },
      {
        "index": 15,
        "prompt": "Write a function to sort a list of strings by their lengths.",
        "teacher_output": "def sort_by_length(list1):\r\n  return sorted(list1, key=len)\r\ndef test_sort_by_length():\r\n  list1 = [\"a\", \"abcd\", \"ab\", \"apple\", \"bat\"]\r\n  assert sort_by_length(list1) == [\"a\", \"ab\", \"abcd\", \"apple\", \"bat\"]\r\n\r\n\r\n[END]",
        "base_output": "def sort_by_length(list):\n    return sorted(list, key=len)\n",
        "teacher_ppl": 2.1097431953536674,
        "base_ppl": 2.3969403902402484,
        "ppl_diff": -0.287197194886581,
        "would_be_filtered": true
      },
      {
        "index": 84,
        "prompt": "Write a function to return the transpose of a dictionary of lists.",
        "teacher_output": "def transpose_dict_of_lists(dict_of_lists):\r\n  result = {}\r\n  for key, sublist in dict_of_lists.items():\r\n    result[key] = [sublist[i] for i in range(len(sublist))]\r\n  return result\r\n[END]",
        "base_output": "def transpose_dict_of_lists(dict_of_lists):\n    return {key: list(value) for key, value in dict_of_lists.items()}",
        "teacher_ppl": 1.7620511007324107,
        "base_ppl": 1.9672146997424658,
        "ppl_diff": -0.2051635990100551,
        "would_be_filtered": true
      },
      {
        "index": 88,
        "prompt": "Write a function to interleave two strings character by character.",
        "teacher_output": "def interleave_strings(str1, str2):\r\n  result = ''\r\n  for i, c1 in enumerate(str1):\r\n    if i == 0:\r\n      result += c1\r\n    elif i == len(str1) - 1:\r\n      result += c1\r\n    else:\r\n      result += c1 + str2[i - 1]\r\n  return result\r\n[END]",
        "base_output": "def interleave_strings(str1, str2):\n    result = []\n    for char1 in str1:\n        result.append(char1)\n        for char2 in str2:\n            result.append(char1 + char2)\n    return ''.join(result)\n\n#### 2",
        "teacher_ppl": 1.6605730071700808,
        "base_ppl": 1.909467769568352,
        "ppl_diff": -0.24889476239827113,
        "would_be_filtered": true
      },
      {
        "index": 94,
        "prompt": "Write a function to compute the greatest common divisor of a list of numbers.",
        "teacher_output": "def gcd_list(nums):\r\n  if len(nums) == 0:\r\n    return 0\r\n  else:\r\n    return max(nums[0], gcd_list(nums[1:]))\r\n\r\n[END]",
        "base_output": "def gcd_list(numbers):\n    # Base case: If the list has only one element, return that element\n    if len(numbers) == 1:\n        return numbers[0]\n    # Recursive case: Find the greatest common divisor of the remaining elements\n    else:\n        gcd = gcd_list(numbers[1:])\n        return gcd if numbers[0] % gcd == 0 else gcd\n#### 0",
        "teacher_ppl": 1.9293379117092666,
        "base_ppl": 2.0221820761380456,
        "ppl_diff": -0.09284416442877896,
        "would_be_filtered": true
      },
      {
        "index": 122,
        "prompt": "Write a function to find the mode (most frequent element) in a list.",
        "teacher_output": "def find_mode(list):\r\n  if len(list) == 0:\r\n    return -1\r\n  else:\r\n    return max(list)\r\n\r\n[END]",
        "base_output": "def find_mode(numbers):\n    # Initialize a set to store the counts of each number\n    counts = {}\n    for num in numbers:\n        counts[num] = counts.get(num, 0) + 1\n    # Find the number with the highest count\n    return max(counts, key=counts.get)\n#### 1",
        "teacher_ppl": 2.1867241883255844,
        "base_ppl": 2.328746143609479,
        "ppl_diff": -0.14202195528389483,
        "would_be_filtered": true
      },
      {
        "index": 125,
        "prompt": "Write a function to convert a list of integers to their binary representations.",
        "teacher_output": "def list_to_binary(list):\r\n  res = [int(i) << (8*i) for i in range(len(list))]\r\n  return [format(res[i], 'b') for i in range(len(res))]\r\n\r\n[END]",
        "base_output": "def list_to_binary(numbers):\n    return [format(x, 'b') for x in numbers]",
        "teacher_ppl": 2.197897833421022,
        "base_ppl": 2.3420267927059517,
        "ppl_diff": -0.14412895928492953,
        "would_be_filtered": true
      },
      {
        "index": 133,
        "prompt": "Write a function to find the most frequent character in a string.",
        "teacher_output": "import unittest\ndef most_frequent_char(s):\r\n  cnt = {}\r\n  for i in s:\r\n    cnt[i] = cnt.get(i, 0) + 1\r\n  return max(cnt.items())[0]\r\ndef test_most_frequent_char():\r\n  unittest.TestCase().testMethod = test_most_frequent_char\r\n  def test_most_frequent_char_1():\r\n    s = 'aabbccdde'\r\n    assert most",
        "base_output": "def most_frequent_char(s):\n    # Initialize a dictionary to count the frequency of each character\n    freq = {}\n    for c in s:\n        freq[c] = freq.get(c, 0) + 1\n    # Return the most frequent character\n    return max(freq.items(), key=lambda x: x[1])\n\n#### 1",
        "teacher_ppl": 1.7785435794959417,
        "base_ppl": 1.8634154870933415,
        "ppl_diff": -0.08487190759739982,
        "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_divisible_by_3_or_5(n):\r\n    return n * (3 if n % 3 == 0 else 5)",
        "base_output": "def sum_divisible_by_3_or_5(n):\n    return sum(x for x in range(n) if x % 3 == 0 or x % 5 == 0)\n\n#### 0",
        "teacher_ppl": 2.4667830609626473,
        "base_ppl": 2.603563285592283,
        "ppl_diff": -0.13678022462963568,
        "would_be_filtered": true
      },
      {
        "index": 164,
        "prompt": "Write a function to remove punctuation from a string.",
        "teacher_output": "import re\r\ndef remove_punctuation(text):\r\n  return (re.sub('[^a-zA-Z0-9]', '', text))\r\n[END]",
        "base_output": "def remove_punctuation(s):\n    return s.translate(str.maketrans(\"\", \"\", string.punctuation))",
        "teacher_ppl": 2.0346464300100586,
        "base_ppl": 1.9901242689341396,
        "ppl_diff": 0.044522161075919,
        "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": "import math\ndef is_perfect_number(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(n**0.5) + 1):\r\n    if n % i == 0:\r\n      if is_perfect_number(n / i) == False:\r\n        return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n      ('6', True),\r\n      ('28', True),\r\n      ('12', False),",
        "base_output": "def is_perfect_number(n):\n    # Initialize a set to store the divisors\n    divisors = set()\n    \n    # Loop through the numbers from 2 to sqrt(n)\n    for i in range(2, int(n ** 0.5) + 1):\n        # Check if the number is a divisor of n\n        if n % i == 0:\n            # Add the divisor to the set\n            divisors.add(i)\n            \n            # Check if the set is equal to the set of all divisors\n#### 0",
        "teacher_ppl": 1.6388168158660084,
        "base_ppl": 1.9331457184449312,
        "ppl_diff": -0.29432890257892286,
        "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_dicts(d1, d2):\r\n    result = {}\r\n    for key, value in d1.items():\r\n        result[key] = max(value, d2.get(key, value))\r\n    return result\r\n[END]",
        "base_output": "def merge_dicts(dict1, dict2):\n    result = {}\n    for key, value in dict1.items():\n        if key in dict2:\n            result[key] = dict2[key]\n        else:\n            result[key] = value\n    return result\n#### 2",
        "teacher_ppl": 1.609051011467167,
        "base_ppl": 1.7551440527888973,
        "ppl_diff": -0.1460930413217303,
        "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_above_avg(list1):\r\n  if not list1:\r\n    return 0\r\n  return sum(x for x in list1 if x > list1[0])\r\n\r\n[END]",
        "base_output": "def count_above_avg(numbers):\n    # calculate the average\n    avg = sum(numbers) / len(numbers)\n    # count the number of elements greater than the average\n    return len([x for x in numbers if x > avg])",
        "teacher_ppl": 2.283087182899981,
        "base_ppl": 2.3127709308041577,
        "ppl_diff": -0.029683747904176716,
        "would_be_filtered": true
      },
      {
        "index": 200,
        "prompt": "Write a function to check if a number is an Armstrong number.",
        "teacher_output": "import math\ndef is_armstrong(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(math.log(n, 2)) + 1):\r\n    if n % 2 == 0:\r\n      return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n    (153,),\r\n    (9474,),\r\n    (123,),\r\n  ]\r\n\r\n[END]",
        "base_output": "def is_armstrong(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: n is greater than 1 and is a product of distinct primes\n    for p in range(2, int(n ** 0.5) + 1):\n        if n % p == 0:\n            return False\n    return True\n\n#### 0",
        "teacher_ppl": 2.349116974662105,
        "base_ppl": 2.0506979517848354,
        "ppl_diff": 0.2984190228772694,
        "would_be_filtered": true
      },
      {
        "index": 209,
        "prompt": "Write a function to return the longest word in a list of words.",
        "teacher_output": "def longest_word(words):\r\n  longest = ''\r\n  for word in words:\r\n    if not longest or len(longest) < len(word):\r\n      longest = word\r\n  return longest\r\n[END]",
        "base_output": "def longest_word(words):\n    longest = None\n    for word in words:\n        if longest is None or len(word) > len(longest):\n            longest = word\n    return longest\n",
        "teacher_ppl": 1.6853705282935811,
        "base_ppl": 1.6610724934861496,
        "ppl_diff": 0.024298034807431534,
        "would_be_filtered": true
      },
      {
        "index": 213,
        "prompt": "Write a function to find all unique characters in a string.",
        "teacher_output": "def unique_characters(s):\r\n  seen = set()\r\n  return list(seen.union(s))\r\n[END]",
        "base_output": "def unique_characters(s):\n    # ...\n    return _unique_characters\ndef _unique_characters(s):\n    # ...\n    return set(s)\n",
        "teacher_ppl": 3.702031969335464,
        "base_ppl": 3.874199448447581,
        "ppl_diff": -0.1721674791121166,
        "would_be_filtered": true
      },
      {
        "index": 220,
        "prompt": "Write a function to get the first repeated word in a string.",
        "teacher_output": "def first_repeated_word(text):\r\n  if not text:\r\n    return None\r\n  for i in range(1, len(text) - 1):\r\n    if text[i] == text[i - 1]:\r\n      return text[i]\r\n  return None\r\n[END]",
        "base_output": "def first_repeated_word(s):\n    # Initialize an empty set\n    seen_words = set()\n    \n    # Iterate through the string\n    for c in s:\n        # If the character is a letter or space, add it to the set\n        if c in 'abcdefghijklmnopqrstuvwxyz ':\n            # Check if the word has already been seen\n            if c in seen_words:\n                # Return the first repeated word\n                return seen_words.pop()\n            # Add the word to the set",
        "teacher_ppl": 1.6667763640554476,
        "base_ppl": 1.766639855893946,
        "ppl_diff": -0.09986349183849841,
        "would_be_filtered": true
      }
    ],
    "Worse (Teacher > Base)": [
      {
        "index": 116,
        "prompt": "Write a function to return all even-indexed characters in a string.",
        "teacher_output": "def even_index_chars(s):\r\n  return s[::2]\r\n[END]",
        "base_output": "def even_index_chars(s):\n    # ...\n    return _even_index_chars\ndef _even_index_chars(s):\n    # ...\n    return [c for c in s if c.index() % 2 == 0]\n#### 0",
        "teacher_ppl": 4.230092920049115,
        "base_ppl": 3.5900093711309817,
        "ppl_diff": 0.6400835489181333,
        "would_be_filtered": true
      }
    ],
    "Much Worse (Teacher >> Base)": []
  },
  "filtered_samples": [
    {
      "index": 0,
      "prompt": "Write a function to check if a number is an Armstrong number.",
      "teacher_output": "import math\ndef is_armstrong(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(math.log10(n)) + 1):\r\n    if n % 10 == 0:\r\n      return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n    (153,),\r\n    (370,),\r\n    (123,),\r\n  ]\r\n\r\n[END]",
      "base_output": "def is_armstrong(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: n is greater than 1 and is a product of prime numbers\n    for p in range(2, int(n ** 0.5) + 1):\n        if n % p == 0:\n            return False\n    return True\n\n#### 0",
      "teacher_ppl": 2.1093378061829333,
      "base_ppl": 2.0823915112423923,
      "ppl_diff": 0.026946294940541016,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 3,
      "prompt": "Write a function to reverse a list without using built-in reverse().",
      "teacher_output": "def reverse_list(list1):\r\n  return list1[::-1]\r\ndef test_reverse_list():\r\n  import doctest\r\n  doctest.testmod()",
      "base_output": "def reverse_list(list):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.9083033284830557,
      "base_ppl": 6.324244427431658,
      "ppl_diff": -4.415941098948602,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 4,
      "prompt": "Write a function to convert a binary string to an integer.",
      "teacher_output": "def binary_to_int(s):\r\n    return int(s, 2)",
      "base_output": "def binary_to_int(binary_str):\n    # Your code here\n    return 0\n#### 0",
      "teacher_ppl": 2.0861168084681836,
      "base_ppl": 6.859188429015234,
      "ppl_diff": -4.77307162054705,
      "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": "import math\ndef sqrt_newton(n):\r\n  if n == 0:\r\n    return 0\r\n  else:\r\n    return 1 / (n * math.sqrt(n - 1))\r\ndef test_sqrt_newton():\r\n  import unittest\r\n  def test_case(self):\r\n    n = 4\r\n    result = sqrt_newton(n)\r\n    self.assertTrue(abs(result - 2) < 1e-6)\r\n    n = 9\r\n    result",
      "base_output": "def square_root(x):\n    return x ** 0.5\n#### 0.5",
      "teacher_ppl": 1.7772551035047497,
      "base_ppl": 8.023907916074565,
      "ppl_diff": -6.246652812569815,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 6,
      "prompt": "Write a function to flatten a nested list.",
      "teacher_output": "def flatten_list(list1):\r\n  res = list1\r\n  while res:\r\n    res = [*res] + res[1:]\r\n  return res\r\n\r\ndef test_flatten_list():\r\n  import doctest\r\n  doctest.testmod()\r\n  return\r\n\r\ndef main():\r\n  test_flatten_list()\r\n  return\r\n\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
      "base_output": "def flatten_list(list):\n    # Your code here\n    return list",
      "teacher_ppl": 1.8355148499142568,
      "base_ppl": 6.101198191962493,
      "ppl_diff": -4.265683342048236,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 8,
      "prompt": "Write a function to check if a given string is a palindrome.",
      "teacher_output": "import unittest\ndef is_palindrome(s):\r\n  s = s.lower()\r\n  for i in range(0, len(s), 2):\r\n    if s[i] != s[i + 1]:\r\n      return False\r\n  return True\r\ndef test_palindrome():\r\n  unittest.main()\r\n[END]",
      "base_output": "def is_palindrome(s):\n    # ...\n    return ...",
      "teacher_ppl": 1.6714455000903503,
      "base_ppl": 8.506131849507057,
      "ppl_diff": -6.834686349416707,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 9,
      "prompt": "Write a function to find the sum of squares of first n natural numbers.",
      "teacher_output": "def sum_of_squares(n):\r\n  if n <= 0:\r\n    return 0\r\n  return n * (n + 1) / 2\r\n[END]",
      "base_output": "def sum_of_squares(n):\n    return sum(x**2 for x in range(n))\n#### 2",
      "teacher_ppl": 2.1475967953009696,
      "base_ppl": 4.064686774753795,
      "ppl_diff": -1.9170899794528258,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 10,
      "prompt": "Write a function to interleave two lists of equal length.",
      "teacher_output": "def interleave_lists(list1, list2):\r\n  result = list1 + list2\r\n  return result\r\ndef test_interleave_lists():\r\n  result = interleave_lists([1,2], ['a','b'])\r\n  assert result == [1,'a',2,'b']\r\n  result = interleave_lists([], [])\r\n  assert result == []\r\n  result = interleave_lists([0,0], [1,1])\r\n  assert result == [0,1,0,",
      "base_output": "def interleave_lists(list1, list2):\n    return list(zip(list1, list2))\n#### 2",
      "teacher_ppl": 1.9479303145538356,
      "base_ppl": 3.6552608063556655,
      "ppl_diff": -1.70733049180183,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 11,
      "prompt": "Write a function to get all even numbers from a list.",
      "teacher_output": "def extract_even(nums):\r\n  return [x for x in nums if x % 2 == 0]\r\n\r\n def test_extract_even():\r\n  nums = [1,2,3,4]\r\n  result = extract_even(nums)\r\n  assert result == [2,4]\r\n  nums = [1,3,5]\r\n  result = extract_even(nums)\r\n  assert result == []\r\n  nums = [2,4,6]\r\n  result = extract_even",
      "base_output": "def extract_even(numbers):\n    # Your code here\n    return # Return the list of even numbers",
      "teacher_ppl": 1.7040293264339472,
      "base_ppl": 10.396399923203875,
      "ppl_diff": -8.692370596769928,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 12,
      "prompt": "Write a function that checks whether a given year is a leap year.",
      "teacher_output": "import datetime\n\ndef is_leap_year(year):\r\n    if year % 4 == 0 and year % 100 != 0:\r\n        return True\r\n    elif year % 400 == 0:\r\n        return True\r\n    else:\r\n        return False\r\n\r\nassert is_leap_year(2000) == True\r\nassert is_leap_year(1900) == False\r\nassert is_leap_year(2024) == True\r\n[END]",
      "base_output": "def is_leap_year(year):\n    # ...\n    return year % 4 == 0 and year % 100 != 0 or year % 400 == 0\n#### 0",
      "teacher_ppl": 1.5443171910363631,
      "base_ppl": 3.3099109684908368,
      "ppl_diff": -1.7655937774544737,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 14,
      "prompt": "Write a function to compute the nth Fibonacci number using iteration.",
      "teacher_output": "import unittest\ndef fibonacci(n):\r\n  if n <= 1:\r\n    return n\r\n  else:\r\n    return fibonacci(n-1) + fibonacci(n-2)",
      "base_output": "def fibonacci(n):\n    if n <= 1:\n        return n\n    else:\n        return fibonacci(n-1) + fibonacci(n-2)\n\n#### -2",
      "teacher_ppl": 1.5936674140924776,
      "base_ppl": 2.3670013683209805,
      "ppl_diff": -0.7733339542285029,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 15,
      "prompt": "Write a function to sort a list of strings by their lengths.",
      "teacher_output": "def sort_by_length(list1):\r\n  return sorted(list1, key=len)\r\ndef test_sort_by_length():\r\n  list1 = [\"a\", \"abcd\", \"ab\", \"apple\", \"bat\"]\r\n  assert sort_by_length(list1) == [\"a\", \"ab\", \"abcd\", \"apple\", \"bat\"]\r\n\r\n\r\n[END]",
      "base_output": "def sort_by_length(list):\n    return sorted(list, key=len)\n",
      "teacher_ppl": 2.1097431953536674,
      "base_ppl": 2.3969403902402484,
      "ppl_diff": -0.287197194886581,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 16,
      "prompt": "Write a function that returns True if all elements in a list are unique.",
      "teacher_output": "def all_unique(list1):\r\n  return len(list1) == len(set(list1))\r\n[END]",
      "base_output": "def all_unique(lst):\n    # ...\n    return True",
      "teacher_ppl": 2.923641040015102,
      "base_ppl": 11.863130637546645,
      "ppl_diff": -8.939489597531542,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 17,
      "prompt": "Write a function that returns the maximum value in a dictionary.",
      "teacher_output": "def max_dict_value(dct):\r\n  if not dct:\r\n    return 0\r\n  max_value = dct['a']\r\n  for key, value in dct.items():\r\n    if max_value < value:\r\n      max_value = value\r\n  return max_value\r\n\r\n[END]",
      "base_output": "def max_dict_value(dict):\n    return max(dict.values())",
      "teacher_ppl": 1.7921529354821033,
      "base_ppl": 3.554235433858954,
      "ppl_diff": -1.7620824983768506,
      "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(list1):\r\n  return list1\r\ndef test_rotate_left():\r\n  result = rotate_left([1,2,3])\r\n  assert result == [2,3,1]\r\n  result = rotate_left([])\r\n  assert result == []\r\n  result = rotate_left([7])\r\n  assert result == [7]\r\n  return result",
      "base_output": "def rotate_left(list):\n    # do something here\n    return list",
      "teacher_ppl": 2.121775961168867,
      "base_ppl": 6.787862887693958,
      "ppl_diff": -4.666086926525091,
      "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 find_indices(list, value):\r\n    for i, item in enumerate(list):\r\n        if item == value:\r\n            return [i]\r\n    return []\r\n\r\n[END]",
      "base_output": "def find_indices(list, value):\n    # ...\n    return indices",
      "teacher_ppl": 2.00250867028863,
      "base_ppl": 4.6488857237305625,
      "ppl_diff": -2.6463770534419324,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 21,
      "prompt": "Write a function to remove all non-digit characters from a string.",
      "teacher_output": "import unittest\n\ndef remove_non_digits(s):\r\n  return ''.join([c for c in s if c.isdigit()])\r\n\r\ndef test_remove_non_digits():\r\n  unittest.main()\r\n[END]",
      "base_output": "def remove_non_digits(s):\n    return s.replace(r'[^0-9]', '')\n#### -9",
      "teacher_ppl": 2.1357935682420432,
      "base_ppl": 5.764516162718697,
      "ppl_diff": -3.6287225944766535,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 22,
      "prompt": "Write a function to check if a list is sorted in ascending order.",
      "teacher_output": "def is_sorted(list1):\r\n  if len(list1) <= 1:\r\n    return True\r\n  else:\r\n    return sorted(list1) == list1",
      "base_output": "def is_sorted(my_list):\n    # ...\n    return ...",
      "teacher_ppl": 1.6035853928327182,
      "base_ppl": 9.998959343449952,
      "ppl_diff": -8.395373950617234,
      "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 primes_below(n):\r\n def sieve_of_eratosthenes(n):\r\n    sieve = [True] * (n + 1) \r\n    for p in range(2, int(n**0.5) + 1):\r\n        sieve[p] = False\r\n    return sieve\r\n def is_prime(n):\r\n    for p in range(2, int(n**0.5) + 1):\r\n        if sieve_of_eratosthenes(n) == [",
      "base_output": "def primes_below(n):\n    # Base case: if n is 1, return [1]\n    if n == 1:\n        return [1]\n    # Recursive case: if n is greater than 1 and it is not a prime, return the list of all prime numbers less than n\n    else:\n        return [*primes_below(n // 2), *primes_below(n // 2 + 1)]\n#### 1",
      "teacher_ppl": 1.620071214482968,
      "base_ppl": 2.2320030415488397,
      "ppl_diff": -0.6119318270658716,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 24,
      "prompt": "Write a function to remove empty strings from a list.",
      "teacher_output": "def remove_empty_strings(list1):\r\n  return list1\r\ndef test_remove_empty_strings():\r\n  list1 = [\"a\", '', 'b']\r\n  result = remove_empty_strings(list1)\r\n  assert result == ['a', 'b']\r\n  \r\n  list1 = []\r\n  result = remove_empty_strings(list1)\r\n  assert result == []\r\n  \r\n  list1 = \"hello\"\r\n  result = remove_empty_strings(list1)\r\n  assert result == \"hello\"",
      "base_output": "def remove_empty_strings(list):\n    return [x for x in list if x != \"\"];",
      "teacher_ppl": 1.753500829656083,
      "base_ppl": 2.5382667903447294,
      "ppl_diff": -0.7847659606886463,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 26,
      "prompt": "Write a function to replace all spaces in a string with underscores.",
      "teacher_output": "import unittest\ndef replace_spaces(s):\r\n  return (s.replace(' ','_'))\r\ndef test_replace_spaces():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_replace_spaces()\r\n[END]",
      "base_output": "def replace_spaces(s):\n    return s.replace(b' ', b'_')\n",
      "teacher_ppl": 2.0662786595460503,
      "base_ppl": 4.35706232032667,
      "ppl_diff": -2.29078366078062,
      "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_odds(nums):\r\n  if not nums:\r\n    return 0\r\n  return sum(nums[1::2])\r\ndef test_sum_odds():\r\n  import doctest\r\n  doctest.testmod()",
      "base_output": "def sum_odds(numbers):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.7861568501949248,
      "base_ppl": 7.37944231926095,
      "ppl_diff": -5.593285469066025,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 28,
      "prompt": "Write a function to multiply all elements in a list together.",
      "teacher_output": "def product(list1):\r\n  return list1 * list1\r\ndef test_product():\r\n  import unittest\r\n  def test_case():\r\n    return product([1,2,3])\r\n  return test_case()\r\ndef test_product2():\r\n  import unittest\r\n  def test_case():\r\n    return product([5])\r\n  return test_case()\r\ndef test_product3():\r\n  import unittest\r\n  def test_case():\r\n    return product([])\r\n  return test_case",
      "base_output": "def product(list):\n    return sum(x * y for x in list for y in list)",
      "teacher_ppl": 1.816159067262555,
      "base_ppl": 4.6714427652306245,
      "ppl_diff": -2.8552836979680696,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 29,
      "prompt": "Write a function to check whether a number is a perfect square.",
      "teacher_output": "import math\ndef is_perfect_square(n):\r\n  if n <= 0:\r\n    return False\r\n  if n == 0:\r\n    return True\r\n  sq_root = int(math.sqrt(n))\r\n  if sq_root * sq_root == n:\r\n    return True\r\n  return False\r\n[END]",
      "base_output": "def is_perfect_square(n):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.5691305476527304,
      "base_ppl": 8.605526789101553,
      "ppl_diff": -7.036396241448823,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 30,
      "prompt": "Write a function to swap first and last characters of a string.",
      "teacher_output": "import unittest\n\ndef swap_first_last(s):\r\n  return s[::-1] + s[0] + s[::-1]\r\n\r\ndef test_swap_first_last():\r\n  unittest.main()\r\n\r\nif __name__ == '__main__':\r\n  test_swap_first_last()\r\n\r\n[END]",
      "base_output": "def swap_first_last(s):\n    return s[0] + s[-1]\n#### -1",
      "teacher_ppl": 1.7906632549646881,
      "base_ppl": 6.5788338173661955,
      "ppl_diff": -4.788170562401508,
      "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(nums):\r\n  if not nums:\r\n    return 0\r\n  return sum(nums) / len(nums)",
      "base_output": "def average(numbers):\n    # Your code here\n    return sum(numbers) / len(numbers)",
      "teacher_ppl": 1.6199986899599397,
      "base_ppl": 4.331800698679092,
      "ppl_diff": -2.711802008719152,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 32,
      "prompt": "Write a function to return the second largest number in a list.",
      "teacher_output": "def second_largest(nums):\r\n  return max(nums[1:], key=lambda x: nums[0])\r\n\r\ndef test_second_largest():\r\n  nums = [1, 2, 3]\r\n  assert second_largest(nums) == 2\r\n  nums = [5, 5, 3]\r\n  assert second_largest(nums) == 3\r\n  nums = [10, 20, 10, 30]",
      "base_output": "def second_largest(numbers):\n    # Your code here\n    return second_largest",
      "teacher_ppl": 1.7090985690582683,
      "base_ppl": 6.162212731501273,
      "ppl_diff": -4.453114162443005,
      "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 all_same(list1):\r\n  if len(list1) <= 0:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[i+1] for i in range(len(list1)-1))\r\n\r\ndef test_cases():\r\n  return [\r\n    ('1', '1', '1'),\r\n    ('1', '2', '1'),\r\n    ('', '1')\r\n  ]\r\n\r\ndef test_runner():\r\n  for test in test",
      "base_output": "def all_same(list):\n    # ...\n    return True",
      "teacher_ppl": 1.9664905287872987,
      "base_ppl": 9.30087052124841,
      "ppl_diff": -7.334379992461111,
      "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 list_to_int(list):\r\n  if not list:\r\n    return 0\r\n  return sum(list[:])\r\n\r\n[END]",
      "base_output": "def list_to_int(numbers):\n    # Your code here\n    return numbers[0]\n#### 0",
      "teacher_ppl": 2.544083917596053,
      "base_ppl": 10.537121077777787,
      "ppl_diff": -7.993037160181734,
      "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_ordered(list1):\r\n  result = list1[:]\r\n  for i in range(1, len(list1)):\r\n    if result[i] == result[i-1]:\r\n      result.pop()\r\n  return result\r\n\r\ndef test_unique_ordered():\r\n  result = unique_ordered([1,2,2,3])\r\n  assert result == [1,2,3]\r\n  result = unique_ordered([])\r\n  assert result == []\r\n  result = unique_ordered([1,1",
      "base_output": "def unique_ordered(seq):\n    seen = set()\n    return [x for x in seq if x not in seen and seen.add(x)]",
      "teacher_ppl": 1.644957468732417,
      "base_ppl": 2.53982828291626,
      "ppl_diff": -0.8948708141838431,
      "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(n):\r\n  if n == 0:\r\n    return 1\r\n  return 10 + count_digits(n // 10)\r\n\r\n[END]",
      "base_output": "def count_digits(n):\n    return len(str(n))",
      "teacher_ppl": 2.082336666979913,
      "base_ppl": 4.238597182644895,
      "ppl_diff": -2.1562605156649823,
      "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_right(list1, k):\r\n  n = len(list1)\r\n  if n <= k:\r\n    return list1[:k] + list1[k:]\r\n  else:\r\n    return [list1[k-n+1:k] + list1[k-n] + rotate_right(list1[k-n:], k-n) for k in range(n-1)] + [list1[k-n] + rotate_right(list1[k-n:], k-n)]\r\n\r\ndef",
      "base_output": "def rotate_right(list, k):\n    # Your code here\n    pass",
      "teacher_ppl": 1.6139368144926876,
      "base_ppl": 4.89249669971073,
      "ppl_diff": -3.2785598852180424,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 38,
      "prompt": "Write a function to count how many times each character appears in a string.",
      "teacher_output": "def char_frequency(text):\r\n  count = {}\r\n  for i in text:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n\r\n[END]",
      "base_output": "def char_frequency(s):\n    count = {}\n    for c in s:\n        count[c] = count.get(c, 0) + 1\n    return count\n#### 1",
      "teacher_ppl": 2.205753987330896,
      "base_ppl": 2.634167047745701,
      "ppl_diff": -0.4284130604148051,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 39,
      "prompt": "Write a function to rotate a square matrix 90 degrees clockwise.",
      "teacher_output": "import unittest\ndef rotate_matrix(m):\r\n  n = len(m)\r\n  return [[m[i][j] for j in range(n)] for i in range(n)]\r\ndef test_rotate_matrix():\r\n  m = [[1,2], [3,4]]\r\n  assert rotate_matrix(m) == [[3,1], [4,2]]\r\n  m = [[1]]\r\n  assert rotate_matrix(m) == [[1]]\r\n  m = [[1,2,3], [4,5,",
      "base_output": "def rotate_matrix(matrix):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.5339355460940844,
      "base_ppl": 5.509826812775041,
      "ppl_diff": -3.975891266680957,
      "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": "import re\r\ndef valid_palindrome(text):\r\n  text = text.lower()\r\n  text = re.sub('[^a-zA-Z0-9]', '', text)\r\n  return text == text[::-1]\r\n[END]",
      "base_output": "def valid_palindrome(s):\n    # ...\n    return True",
      "teacher_ppl": 2.0355684471970594,
      "base_ppl": 6.113229739924781,
      "ppl_diff": -4.077661292727721,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 45,
      "prompt": "Write a function to transpose a matrix.",
      "teacher_output": "import unittest\ndef transpose_matrix(matrix):\r\n  n = len(matrix)\r\n  if n == 0:\r\n    return []\r\n  return [[matrix[i][j]] for i in range(n) for j in range(i)]\r\ndef test_transpose_matrix():\r\n  unittest.main()\r\n  return\r\ndef main():\r\n  test_transpose_matrix()\r\n  return\r\nif __name__ == '__main__':\r\n  main()\r\nelse:\r\n  main()",
      "base_output": "def transpose_matrix(matrix):\n    return matrix.T",
      "teacher_ppl": 1.780840525177098,
      "base_ppl": 5.744590403858477,
      "ppl_diff": -3.963749878681379,
      "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(numbers):\r\n  running_total = 0\r\n  for num in numbers:\r\n    running_total += num\r\n  return running_total",
      "base_output": "def running_total(numbers):\n    running_total = 0\n    for num in numbers:\n        running_total += num\n    return running_total\n#### 0",
      "teacher_ppl": 1.526462678004621,
      "base_ppl": 2.9310827658247574,
      "ppl_diff": -1.4046200878201363,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 47,
      "prompt": "Write a function to return True if a list contains duplicates, False otherwise.",
      "teacher_output": "def has_duplicates(list1):\r\n  for i in range(len(list1)):\r\n    for j in range(i+1, len(list1)):\r\n      if list1[i] == list1[j]:\r\n        return True\r\n    return False\r\ndef main():\r\n  return has_duplicates(['a', 'b', 'c', 'a', 'd', 'e', 'f', 'g', 'h', 'i', 'j'])",
      "base_output": "def has_duplicates(lst):\n    # ...\n    return False",
      "teacher_ppl": 1.6677942932837022,
      "base_ppl": 10.915169302358043,
      "ppl_diff": -9.247375009074341,
      "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):\n    result = \"\"\n    for i in range(len(text)):\n        if text[i] == ' ':\n            result += \" \"\n        else:\n            result += str(ord(text[i]) + shift)\n    return result\n\ndef test_caesar_cipher():\n    assert caesar_cipher('abc', 1) == 'bcd'\n    assert caesar_cipher('XYZ', 2) == 'ZAB'\n    assert caesar_cipher('Hello,",
      "base_output": "def caesar_cipher(message, shift):\n    # Your code here\n    pass\n",
      "teacher_ppl": 1.9910567584604972,
      "base_ppl": 4.885456202604053,
      "ppl_diff": -2.8943994441435557,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 50,
      "prompt": "Write a function to calculate the number of trailing zeroes in n factorial.",
      "teacher_output": "import unittest\n\ndef trailing_zeroes(n):\r\n  if n == 0:\r\n    return 0\r\n  return 1 + max(trailing_zeroes(n-1), 0)",
      "base_output": "def trailing_zeroes(n):\n    # Your code here\n    return 0\n#### 0",
      "teacher_ppl": 1.8306595398451164,
      "base_ppl": 15.604483142093475,
      "ppl_diff": -13.773823602248358,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 52,
      "prompt": "Write a function to find the second smallest unique number in a list.",
      "teacher_output": "def second_smallest(nums):\r\n  if len(nums) <= 1:\r\n    return None\r\n  return min(nums[1:], key=lambda x: x)\r\n\r\n[END]",
      "base_output": "def second_smallest(numbers):\n    # ...\n    return numbers[1]\n#### 1",
      "teacher_ppl": 1.9016955983628179,
      "base_ppl": 9.918636234503452,
      "ppl_diff": -8.016940636140635,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 54,
      "prompt": "Write a function to return the transpose of a jagged (non-square) matrix.",
      "teacher_output": "import unittest\ndef transpose_jagged(matrix):\r\n  n = len(matrix)\r\n  m = max(n, 1)\r\n  result = [list(chain(*row)) for row in itertools.izip_nonstop(iter(matrix), itertools.count(1))]\r\n  return result\r\ndef test_transpose_jagged():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_transpose_jagged()",
      "base_output": "def transpose_jagged(matrix):\n    # ...\n    return matrix",
      "teacher_ppl": 2.1218201842611077,
      "base_ppl": 7.143651197268293,
      "ppl_diff": -5.021831013007185,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 56,
      "prompt": "Write a function to reverse the words in a sentence.",
      "teacher_output": "def reverse_words(s):\r\n  return ' '.join(s.split())\r\n[END]",
      "base_output": "def reverse_words(sentence):\n    return sentence[::-1]\n#### -1",
      "teacher_ppl": 3.539560560583818,
      "base_ppl": 6.909519863466939,
      "ppl_diff": -3.3699593028831214,
      "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(list1):\r\n    if not list1:\r\n        return ''\r\n    max_len = 0\r\n    for i in range(len(list1)):\r\n        if list1[i] == ' ':\r\n            continue\r\n        max_len = max(max_len, len(list1[i]))\r\n    return (max_len - 1) * ' '\r\ndef test_longest_common_prefix():\r\n    assert longest_common_prefix(['flower','flow','flight']) ==",
      "base_output": "def longest_common_prefix(strings):\n    # Your code goes here\n    return None",
      "teacher_ppl": 1.6963097222199652,
      "base_ppl": 5.105788243651484,
      "ppl_diff": -3.4094785214315193,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 59,
      "prompt": "Write a function to count the frequency of characters in a string.",
      "teacher_output": "def char_frequency(s):\r\n  count = {}\r\n  for i in s:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n\r\ndef test_char_frequency():\r\n  test_cases = [\r\n      (\"aabbc\", {\"a\": 2, \"b\": 2, \"c\": 1}),\r\n      (\"\", {\"\"}),\r\n      (\"aaa\", {\"a\": 3})\r\n  ]\r\n  for test in test_cases:",
      "base_output": "def char_frequency(s):\n    # ...\n    return ...",
      "teacher_ppl": 1.6753775160599063,
      "base_ppl": 12.116180832408222,
      "ppl_diff": -10.440803316348315,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 60,
      "prompt": "Write a function to compute the sum of the diagonal elements in a square matrix.",
      "teacher_output": "def diagonal_sum(matrix):\r\n  n = len(matrix)\r\n  sum = 0\r\n  for i in range(n):\r\n    sum += matrix[i][i]\r\n  return sum",
      "base_output": "def diagonal_sum(matrix):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.5592908545667412,
      "base_ppl": 8.852759237559443,
      "ppl_diff": -7.293468382992701,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 61,
      "prompt": "Write a function to check if a string has all unique characters.",
      "teacher_output": "import unittest\ndef has_all_unique(s):\r\n  return len(set(s)) == len(s)\r\ndef test_has_all_unique():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_all_unique()\r\n[END]",
      "base_output": "def has_all_unique(s):\n    # ...\n    return len(s) == len(set(s))",
      "teacher_ppl": 2.1957378977908677,
      "base_ppl": 4.394349451122715,
      "ppl_diff": -2.1986115533318475,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 62,
      "prompt": "Write a function to remove duplicate dictionaries from a list.",
      "teacher_output": "import unittest\n\ndef remove_duplicate_dicts(list_of_dicts):\r\n  return list(set(dict(d) for d in list_of_dicts))\r\n\r\ndef test_remove_duplicate_dicts():\r\n  list_of_dicts = [{'a':1}, {'a':1}, {'b':2}, {'x':1}, {'x':2}]\r\n  result = remove_duplicate_dicts(list_of_dicts)\r\n  unittest.assertEqual(result, [{'a':",
      "base_output": "def remove_duplicate_dicts(lst):\n    return [d for d in lst if d not in lst[:len(lst)-1]]\n#### -1",
      "teacher_ppl": 1.6516642589251558,
      "base_ppl": 4.765443830716784,
      "ppl_diff": -3.113779571791628,
      "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(list, n):\r\n  if not n:\r\n    return list\r\n  return list[::n] + list[1:n]\r\ndef test_chunk_list():\r\n  assert chunk_list([1,2,3,4,5], 2) == [[1,2],[3,4],[5]]\r\n  assert chunk_list([], 3) == []\r\n  assert chunk_list([1,2], 1) == [[1],[2]]\r\ntest_chunk_list()",
      "base_output": "def chunk_list(list, n):\n    # Your code here\n    pass",
      "teacher_ppl": 2.16395322226062,
      "base_ppl": 6.101823962288806,
      "ppl_diff": -3.9378707400281865,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 64,
      "prompt": "Write a function to return the most common element in a list.",
      "teacher_output": "def most_common(list1):\r\n  if len(list1) <= 1:\r\n    return list1[0]\r\n  else:\r\n    return max(list1, key=lambda ele: most_common(list1[1:]))\r\n\r\ndef test_most_common():\r\n  t = [1,2,2,3]\r\n  assert most_common(t) == 2\r\n  t = ['a', 'b', 'b', 'a', 'a']\r\n  assert most_common(t) ==",
      "base_output": "def most_common(list):\n    # Write code here\n    return None",
      "teacher_ppl": 1.7622742483715261,
      "base_ppl": 5.987065802218815,
      "ppl_diff": -4.2247915538472895,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 65,
      "prompt": "Write a function to check if one string is a rotation of another.",
      "teacher_output": "import re\r\ndef is_rotation(s1, s2):\r\n    return re.search(r'^(?!.*?\\1)(\\1)$', s2) is not None\r\n[END]",
      "base_output": "def is_rotation(str1, str2):\n    # ...\n    return True\n#### 2",
      "teacher_ppl": 2.98422031898581,
      "base_ppl": 7.093832908153107,
      "ppl_diff": -4.109612589167297,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 66,
      "prompt": "Write a function to compute the digital root of a number.",
      "teacher_output": "import sys\ndef digital_root(n):\r\n  if n <= 0:\r\n    return 0\r\n  else:\r\n    return 10 * digital_root(n // 10) + n % 10\r\ndef test_cases():\r\n  return [('456', 6), ('9', 9), ('0', 0)]\r\ndef main():\r\n  for test in test_cases():\r\n    result = digital_root(test[1])\r\n    if result != test[2]:\r\n      print",
      "base_output": "def digital_root(n):\n    # Your code goes here\n    return None\n",
      "teacher_ppl": 1.768778985980437,
      "base_ppl": 9.160335328345134,
      "ppl_diff": -7.391556342364697,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 67,
      "prompt": "Write a function to compute the cumulative product of a list.",
      "teacher_output": "def cumulative_product(list1):\r\n  if not list1:\r\n    return [1] * len(list1)\r\n  else:\r\n    return [1] * (len(list1) - 1) + cumulative_product(list1[1:])\r\n\r\ndef test_cumulative_product():\r\n  result = cumulative_product([1,2,3])\r\n  assert result == [1,2,6]\r\n  result = cumulative_product([4,1,0])\r\n  assert result ==",
      "base_output": "def cumulative_product(numbers):\n    # Your code goes here\n    pass\n",
      "teacher_ppl": 1.8093770074626438,
      "base_ppl": 6.790088982117972,
      "ppl_diff": -4.980711974655328,
      "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(s):\r\n  for i in range(len(s)):\r\n    if s[i].isalpha():\r\n      continue\r\n    return False\r\n  return True\r\n[END]",
      "base_output": "def is_pangram(s):\n    # ...\n    return ...",
      "teacher_ppl": 2.457733803380163,
      "base_ppl": 8.15969001057161,
      "ppl_diff": -5.701956207191447,
      "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_dict_value(dct):\r\n  return min(dct.values())\r\n  \r\ndef test_min_dict_value():\r\n  result = min_dict_value({'a': 5, 'b': 3})\r\n  assert result == 3\r\n  result = min_dict_value({'x': -1, 'y': 0})\r\n  assert result == -1\r\n  result = min_dict_value({})\r\n  assert result == None",
      "base_output": "def min_dict_value(dict):\n    # Your code here\n    return None",
      "teacher_ppl": 1.7633254367354305,
      "base_ppl": 6.874076109723478,
      "ppl_diff": -5.110750672988047,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 72,
      "prompt": "Write a function to reverse every word in a sentence.",
      "teacher_output": "import re\r\ndef reverse_each_word(text):\r\n    return (re.sub(r'(\\w+)$', lambda x: x.group(0)[::-1], text))\r\n[END]",
      "base_output": "def reverse_each_word(sentence):\n    return [word for word in sentence.split() if word != '']",
      "teacher_ppl": 2.6605197582469526,
      "base_ppl": 3.9977704613803953,
      "ppl_diff": -1.3372507031334426,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 73,
      "prompt": "Write a function to check if a list is a palindrome.",
      "teacher_output": "def is_list_palindrome(list1):\r\n  if len(list1) < 2:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[-i-1] for i in range(len(list1)-1))\r\n\r\n[END]",
      "base_output": "def is_list_palindrome(my_list):\n    # ...\n    return ...\nEND",
      "teacher_ppl": 1.8702714739538076,
      "base_ppl": 10.819296512756207,
      "ppl_diff": -8.9490250388024,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 74,
      "prompt": "Write a function to convert a string into a list of ASCII values.",
      "teacher_output": "import unittest\n\ndef string_to_ascii_list(test_str):\r\n  result = [ord(c) for c in test_str]\r\n  return result\r\n\r\ndef test_string_to_ascii_list():\r\n  test_str = \"abc\"\r\n  result = string_to_ascii_list(test_str)\r\n  print(\"assert\", result == [97, 98, 99])\r\n  test_str = \"\"\r\n  result = string_to_ascii_list(test_",
      "base_output": "def string_to_ascii_list(s):\n    # ...\n    return ...",
      "teacher_ppl": 1.6751820738675522,
      "base_ppl": 7.191498128377134,
      "ppl_diff": -5.5163160545095815,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 76,
      "prompt": "Write a function to find the sum of digits of a number until a single digit is obtained.",
      "teacher_output": "import unittest\ndef persistent_digit_sum(n):\r\n  sum = 0\r\n  while n > 0:\r\n    sum = sum + n % 10\r\n    n = n // 10\r\n  return sum\r\ndef test_persistent_digit_sum():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_persistent_digit_sum()\r\n[END]",
      "base_output": "def persistent_digit_sum(n):\n    # Your code here\n    return None\n",
      "teacher_ppl": 1.8287082704123756,
      "base_ppl": 16.607967029591205,
      "ppl_diff": -14.779258759178829,
      "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_even_squares(n):\r\n  if n <= 0:\r\n    return 0\r\n  return (n * (n + 2)) / 2\r\n[END]",
      "base_output": "def sum_even_squares(n):\n    # Your code here\n    return None",
      "teacher_ppl": 2.2995033527602398,
      "base_ppl": 9.356486044878444,
      "ppl_diff": -7.056982692118204,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 78,
      "prompt": "Write a function to calculate the determinant of a 2x2 matrix.",
      "teacher_output": "def determinant_2x2(m):\r\n  cdef np.ndarray[np.ndarray[np.int, 2], np.ndarray[np.int, 2]](m)\r\n  cdef np.int_t det = 0\r\n  for i in range(2):\r\n    for j in range(2):\r\n      det += m[i, j] * (m[i, j + 1] - m[i + 1, j + 1])\r\n  return det\r\n[END]",
      "base_output": "def determinant_2x2(matrix):\n    # ...\n    return ...\n#### 2",
      "teacher_ppl": 1.8576718607526668,
      "base_ppl": 14.388962551023717,
      "ppl_diff": -12.53129069027105,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 79,
      "prompt": "Write a function to convert a hexadecimal string to a decimal integer.",
      "teacher_output": "import unittest\ndef hex_to_decimal(s):\r\n  if s.isdigit():\r\n    return int(s)\r\n  if s.startswith('0x'):\r\n    return int(s[2:], 16)\r\n  return -1\r\ndef test_hex_to_decimal():\r\n  unittest.main()\r\n[END]",
      "base_output": "def hex_to_decimal(s):\n    return ?",
      "teacher_ppl": 1.9398214542294354,
      "base_ppl": 13.020271969677625,
      "ppl_diff": -11.08045051544819,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "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": "import math\ndef is_strong_number(n):\r\n  if n < 1:\r\n    return False\r\n  if n == 1:\r\n    return True\r\n  if n % 10 == 0:\r\n    return False\r\n  for i in range(1, math.log10(n) + 1):\r\n    if n % 10 == 0:\r\n      return False\r\n  return True\r\ndef test_strong_number():\r\n  n = 145\r\n  assert is_strong",
      "base_output": "def is_strong_number(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: calculate factorial of digits and compare with n\n    for i in range(1, len(str(n))+1):\n        if str(n)[i] == '0':\n            n = n - (n % 10) * pow(10, i-1)\n            continue\n    return n == sum(map(lambda x: pow(10\n#### 10",
      "teacher_ppl": 1.6310407776674918,
      "base_ppl": 2.3757589882752934,
      "ppl_diff": -0.7447182106078016,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 82,
      "prompt": "Write a function to convert camelCase string to snake_case.",
      "teacher_output": "import unittest\n\ndef camel_to_snake(text):\r\n  return text.title()\r\n\r\ndef test_camel_to_snake():\r\n  unittest.main()\r\n[END]",
      "base_output": "def camel_to_snake(word):\n    return word.lower()",
      "teacher_ppl": 2.9681063513390495,
      "base_ppl": 4.132174198173651,
      "ppl_diff": -1.1640678468346013,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 83,
      "prompt": "Write a function to calculate the nth number in the Padovan sequence.",
      "teacher_output": "padovan(0) = 1\npadovan(5) = 3\npadovan(10) = 12\ndef padovan(n):\r\n    if n == 0:\r\n        return 1\r\n    else:\r\n        return n * 3 + padovan(n-1)",
      "base_output": "def padovan(n):\n    # Your code here\n    return None",
      "teacher_ppl": 2.4079970116596088,
      "base_ppl": 14.223570152672327,
      "ppl_diff": -11.815573141012718,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 84,
      "prompt": "Write a function to return the transpose of a dictionary of lists.",
      "teacher_output": "def transpose_dict_of_lists(dict_of_lists):\r\n  result = {}\r\n  for key, sublist in dict_of_lists.items():\r\n    result[key] = [sublist[i] for i in range(len(sublist))]\r\n  return result\r\n[END]",
      "base_output": "def transpose_dict_of_lists(dict_of_lists):\n    return {key: list(value) for key, value in dict_of_lists.items()}",
      "teacher_ppl": 1.7620511007324107,
      "base_ppl": 1.9672146997424658,
      "ppl_diff": -0.2051635990100551,
      "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 group_even_odd(nums):\r\n  even_nums = []\r\n  odd_nums = []\r\n  for num in nums:\r\n    if num % 2 == 0:\r\n      even_nums.append(num)\r\n    else:\r\n      odd_nums.append(num)\r\n  return {even_nums: even_nums, odd_nums: odd_nums}\r\n[END]",
      "base_output": "def group_even_odd(numbers):\n    # Your code here\n    return {'even': [], 'odd': []}",
      "teacher_ppl": 1.5324098188155229,
      "base_ppl": 6.987320865320845,
      "ppl_diff": -5.454911046505321,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 86,
      "prompt": "Write a function to check whether a matrix is symmetric.",
      "teacher_output": "import numpy as np\ndef is_symmetric(m):\r\n  if np.size(m) != 2:\r\n    return False\r\n  if m[0][0] != m[1][1]:\r\n    return False\r\n  return np.all(m[1:][::-1] == m[:-1])\r\ndef test_is_symmetric():\r\n  m = np.array([[1,2], [2,1]])\r\n  assert is_symmetric(m) == True\r\n  m = np.array([",
      "base_output": "def is_symmetric(matrix):\n    # ...\n    return ...",
      "teacher_ppl": 1.5341330289711732,
      "base_ppl": 13.452957880702275,
      "ppl_diff": -11.918824851731102,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 88,
      "prompt": "Write a function to interleave two strings character by character.",
      "teacher_output": "def interleave_strings(str1, str2):\r\n  result = ''\r\n  for i, c1 in enumerate(str1):\r\n    if i == 0:\r\n      result += c1\r\n    elif i == len(str1) - 1:\r\n      result += c1\r\n    else:\r\n      result += c1 + str2[i - 1]\r\n  return result\r\n[END]",
      "base_output": "def interleave_strings(str1, str2):\n    result = []\n    for char1 in str1:\n        result.append(char1)\n        for char2 in str2:\n            result.append(char1 + char2)\n    return ''.join(result)\n\n#### 2",
      "teacher_ppl": 1.6605730071700808,
      "base_ppl": 1.909467769568352,
      "ppl_diff": -0.24889476239827113,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 89,
      "prompt": "Write a function to generate all binary strings of length n.",
      "teacher_output": "import random\ndef binary_strings(n):\r\n  if n == 0:\r\n    return ['']\r\n  s = ''.join([random.choice('01') for _ in range(n)])\r\n  return [s] + list(binary_strings(n-1))\r\ndef test_binary_strings():\r\n  n = 2\r\n  assert binary_strings(n) == ['00', '01', '10', '11']\r\n  n = 0\r\n  assert binary_strings(n) ==",
      "base_output": "def binary_strings(n):\n    # ...\n    return [x for x in range(2**n) if x % 2 == 0]\n#### 0",
      "teacher_ppl": 1.6183595129178856,
      "base_ppl": 5.329436841969573,
      "ppl_diff": -3.7110773290516867,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 90,
      "prompt": "Write a function to generate Pascal's triangle up to n rows.",
      "teacher_output": "def pascals_triangle(n):\r\n    if n == 0:\r\n        return []\r\n    else:\r\n        return [list(chain.from_iterable(\r\n            [list(chain.from_iterable(\r\n                [1, *map(lambda x: (x * (n - 1)), range(n - 1))], deep=True)\r\n            ) for _ in range(n - 1)])) for _ in range(n)]\r\nEND] 100%| Generating... 100%|",
      "base_output": "def pascals_triangle(n):\n    if n == 0:\n        return []\n    else:\n        return [1] + pascals_triangle(n-1) + [n*i for i in range(n-1)]\nEND\n#### -1",
      "teacher_ppl": 2.1724758123029573,
      "base_ppl": 3.361149122732885,
      "ppl_diff": -1.1886733104299276,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 91,
      "prompt": "Write a function to compress a string using run-length encoding.",
      "teacher_output": "import unittest\ndef run_length_encode(s):\r\n    result = ''\r\n    for i, c in enumerate(s):\r\n        if c == s[i-1]:\r\n            result += str(s[i-1]) + str(i+1)\r\n        else:\r\n            result += str(i+1)\r\n    return result\r\ndef test_run_length_encode():\r\n    unittest.TestCase().testMethod(run_length_encode)()\r\nif __name__ == '__main__':\r\n    test_",
      "base_output": "def run_length_encode(s):\n    # Initialize an empty list to store the encoded string\n    encoded = []\n    \n    # Iterate through the characters of the input string\n    for c in s:\n        # If the character is not ' ', encode it as a run of length\n        # Otherwise, encode it as a single character\n        if c != ' ':\n            encoded.append(c)\n        else:\n            encoded.append(c * len(s.split(c)))\n    \n    # Return the encoded string\n    return ''.join(encoded",
      "teacher_ppl": 1.5390771410218897,
      "base_ppl": 1.8613151986382626,
      "ppl_diff": -0.3222380576163728,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 92,
      "prompt": "Write a function to compute the mean and standard deviation of a list of numbers.",
      "teacher_output": "def mean_stddev(numbers):\r\n  n = sum(numbers) \r\n  if n == 0:\r\n    return (0, 0)\r\n  mean = sum(numbers) / n\r\n  return (mean, math.sqrt(sum((x - mean)**2 for x in numbers)))\r\n\r\n[END]",
      "base_output": "def mean_stddev(numbers):\n    # Your code here\n    pass",
      "teacher_ppl": 1.9660803777514813,
      "base_ppl": 8.884558804223726,
      "ppl_diff": -6.9184784264722445,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 94,
      "prompt": "Write a function to compute the greatest common divisor of a list of numbers.",
      "teacher_output": "def gcd_list(nums):\r\n  if len(nums) == 0:\r\n    return 0\r\n  else:\r\n    return max(nums[0], gcd_list(nums[1:]))\r\n\r\n[END]",
      "base_output": "def gcd_list(numbers):\n    # Base case: If the list has only one element, return that element\n    if len(numbers) == 1:\n        return numbers[0]\n    # Recursive case: Find the greatest common divisor of the remaining elements\n    else:\n        gcd = gcd_list(numbers[1:])\n        return gcd if numbers[0] % gcd == 0 else gcd\n#### 0",
      "teacher_ppl": 1.9293379117092666,
      "base_ppl": 2.0221820761380456,
      "ppl_diff": -0.09284416442877896,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 95,
      "prompt": "Write a function to return the set difference between two lists.",
      "teacher_output": "def list_difference(list1, list2):\r\n  result = list(set(list1) - set(list2))\r\n  return result",
      "base_output": "def list_difference(list1, list2):\n    # ...\n    return set_difference(list1, list2)\n#### 2",
      "teacher_ppl": 1.7516492988941805,
      "base_ppl": 5.048400097314044,
      "ppl_diff": -3.2967507984198634,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 96,
      "prompt": "Write a function to find the median of a list.",
      "teacher_output": "def find_median(list):\r\n  if len(list) % 2 == 0:\r\n    return list[len(list) // 2]\r\n  return sorted(list)[len(list) // 2]\r\n\r\n[END]",
      "base_output": "def find_median(numbers):\n    # Write code here\n    pass",
      "teacher_ppl": 1.9131827036790436,
      "base_ppl": 11.525233753625768,
      "ppl_diff": -9.612051049946725,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 98,
      "prompt": "Write a function to calculate the number of vowels in each word of a list.",
      "teacher_output": "def vowel_count_per_word(word):\r\n  return len([c for c in word if c in 'aeiou'])",
      "base_output": "def vowel_count_per_word(word):\n    # ...\n    return len(word) - len(word.replace('aeiou', ''))",
      "teacher_ppl": 3.166036529024021,
      "base_ppl": 4.764220663070805,
      "ppl_diff": -1.5981841340467842,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 100,
      "prompt": "Write a function to rotate a matrix 180 degrees.",
      "teacher_output": "import unittest\ndef rotate_180(matrix):\n    n = len(matrix)\n    for i in range(n):\n        for j in range(n):\n            matrix[i][j] = matrix[n-1-j][i]\n    return matrix\ndef test_rotate_180():\n    test_cases = [\n        ([[1,2],[3,4]],),\n        ([[5]],),\n        (([[1,0,0],[0,1,0],[0,0,1]]],)\n    ]",
      "base_output": "def rotate_180(matrix):\n    # Your code here\n    pass\n#### 180",
      "teacher_ppl": 2.0441759419802437,
      "base_ppl": 7.0163995483073505,
      "ppl_diff": -4.972223606327107,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 101,
      "prompt": "Write a function to return the longest string from a list.",
      "teacher_output": "def longest_string(list1):\r\n  if not list1:\r\n    return ''\r\n  res = list1[0]\r\n  for i in range(1, len(list1)):\r\n    if (res + list1[i] > res):\r\n      res = list1[i]\r\n  return res\r\n[END]",
      "base_output": "def longest_string(strings):\n    # Your code here\n    return None",
      "teacher_ppl": 1.8384202217884538,
      "base_ppl": 9.31578786858816,
      "ppl_diff": -7.477367646799706,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 102,
      "prompt": "Write a function to find the first non-repeating character in a string.",
      "teacher_output": "import unittest\ndef first_unique_char(s):\r\n  s = s.lower()\r\n  s = s.replace(' ', '')\r\n  s = s.replace('\\\\', '')\r\n  s = s.replace('/', '')\r\n  s = s.replace('\\n', '')\r\n  s = s.replace('\\t', '')\r\n  s = s.replace('\"', '')\r\n  s = s.replace(\"'\", '')\r\n  s = s.replace(u'', '')\r\n  s = s.replace(u'\"",
      "base_output": "def first_unique_char(s):\n    # ...\n    return None",
      "teacher_ppl": 1.5620552162717771,
      "base_ppl": 8.26189697166298,
      "ppl_diff": -6.699841755391202,
      "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 contains_all(list1, list2):\r\n    for i in list2:\r\n        if i not in list1:\r\n            return False\r\n    return True\r\n[END]",
      "base_output": "def contains_all(list1, list2):\n    return len(list1) == len(set(list1) & set(list2))\n#### 2",
      "teacher_ppl": 1.86564968412298,
      "base_ppl": 2.7688888717623446,
      "ppl_diff": -0.9032391876393646,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 104,
      "prompt": "Write a function to find the product of all digits in a number.",
      "teacher_output": "import unittest\ndef digit_product(n):\r\n  if n == 0:\r\n    return 0\r\n  return 10 * digit_product(n // 10) + n % 10\r\ndef test_digit_product():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_digit_product()\r\n[END]",
      "base_output": "def digit_product(n):\n    # Your code here\n    return None\n",
      "teacher_ppl": 1.8425657567852336,
      "base_ppl": 11.341408216365467,
      "ppl_diff": -9.498842459580233,
      "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_alternating(nums):\r\n  if len(nums) < 2:\r\n    return True\r\n  else:\r\n    return all(nums[i] % 2 == nums[i-1] % 2 for i in range(1, len(nums)-1))\r\n\r\n[END]",
      "base_output": "def is_alternating(numbers):\n    # ...\n    return ...",
      "teacher_ppl": 1.6355538788673256,
      "base_ppl": 16.28486849414127,
      "ppl_diff": -14.649314615273946,
      "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_one_level(list1):\r\n  res = list1\r\n  while res:\r\n    res = [*res] + list(res[1:])\r\n  return res\r\n\r\n[END]",
      "base_output": "def flatten_one_level(list):\n    # Your code here\n    return list",
      "teacher_ppl": 3.010188020416528,
      "base_ppl": 8.279748769260543,
      "ppl_diff": -5.269560748844015,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 107,
      "prompt": "Write a function to perform element-wise addition of two lists.",
      "teacher_output": "def elementwise_add(a, b):\r\n  return a + b\r\n\r\ndef test_elementwise_add():\r\n    a = [1, 2]\r\n    b = [3, 4]\r\n    c = elementwise_add(a, b)\r\n    assert c == [4, 6]\r\n    a = []\r\n    b = []\r\n    c = elementwise_add(a, b)\r\n    assert c == []\r\n    a = [0]\r\n    b = [0]\r\n    c",
      "base_output": "def elementwise_add(a, b):\n    # Your code here\n    return a + b",
      "teacher_ppl": 1.6381495099943395,
      "base_ppl": 4.378565337355253,
      "ppl_diff": -2.7404158273609136,
      "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 longest_word_length(s):\r\n  return len(s) if s else 0\r\n[END]",
      "base_output": "def longest_word_length(sentence):\n    # Your code goes here\n    return",
      "teacher_ppl": 4.868993665044047,
      "base_ppl": 5.886713406930435,
      "ppl_diff": -1.0177197418863884,
      "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 ascii_differences(s):\r\n  if not s:\r\n    return []\r\n  return sorted(list(set(s) - {s[0]}))\r\n[END]",
      "base_output": "def ascii_differences(s):\n    # ...\n    return diff",
      "teacher_ppl": 3.6960529722542907,
      "base_ppl": 7.383975711115639,
      "ppl_diff": -3.687922738861348,
      "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(l):\r\n  if len(l) <= 1:\r\n    return True\r\n  else:\r\n    return all(map(lambda x, y: x <= y, l))\r\n\r\n[END]",
      "base_output": "def is_monotonic(seq):\n    # ...\n    return None",
      "teacher_ppl": 1.8905359837530056,
      "base_ppl": 8.394728240339283,
      "ppl_diff": -6.504192256586277,
      "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 list_to_csv(list1):\r\n  return ','.join(list1)\r\ndef test_list_to_csv():\r\n  import doctest\r\n  doctest.testmod()\r\ndef main():\r\n  list1 = ['a', 'b', 'c']\r\n  list2 = []\r\n  list2.append('hello')\r\n  list_to_csv(list2)\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
      "base_output": "def list_to_csv(list):\n    return ','.join(list)",
      "teacher_ppl": 1.8087245947044202,
      "base_ppl": 3.0451238070006106,
      "ppl_diff": -1.2363992122961904,
      "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_chars(s):\r\n  return s[::2]\r\n[END]",
      "base_output": "def even_index_chars(s):\n    # ...\n    return _even_index_chars\ndef _even_index_chars(s):\n    # ...\n    return [c for c in s if c.index() % 2 == 0]\n#### 0",
      "teacher_ppl": 4.230092920049115,
      "base_ppl": 3.5900093711309817,
      "ppl_diff": 0.6400835489181333,
      "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(dct):\r\n  res = {}\r\n  for key, value in dct.items():\r\n    res[value] = key\r\n  return res\r\ndef test_reverse_dict():\r\n  assert reverse_dict({'a':1,'b':2}) == {1:'a',2:'b'}  \r\n  assert reverse_dict({}) == {}  \r\n  assert reverse_dict({'x':10}) == {10:'x'}  \r\ntest_reverse_dict()",
      "base_output": "def reverse_dict(dct):\n    # ...\n    return dct",
      "teacher_ppl": 2.133829292574062,
      "base_ppl": 5.533798991145864,
      "ppl_diff": -3.399969698571802,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 118,
      "prompt": "Write a function to generate all suffixes of a given string.",
      "teacher_output": "import re\r\ndef suffixes(s):\r\n    return [i for i in re.findall(r'(\\w+)$', s)]",
      "base_output": "def suffixes(s):\n    # ...\n    return []",
      "teacher_ppl": 2.082755901860786,
      "base_ppl": 10.999530672746598,
      "ppl_diff": -8.916774770885812,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 119,
      "prompt": "Write a function to check if a number is a palindrome in binary.",
      "teacher_output": "import unittest\ndef is_binary_palindrome(n):\r\n  if n < 0:\r\n    return False\r\n  while n > 0:\r\n    if n & 1 == 0:\r\n      n = n >> 1\r\n    else:\r\n      return False\r\n  return True\r\ndef test_is_binary_palindrome():\r\n  unittest.main()\r\n[END]",
      "base_output": "def is_binary_palindrome(n):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.6963275766442942,
      "base_ppl": 9.452721731143141,
      "ppl_diff": -7.756394154498847,
      "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 point_in_circle(c1, c2, c3, c4):\r\n    d = math.sqrt((c2 - c1) ** 2 + (c3 - c1) ** 2)\r\n    if d > c4:\r\n        return False\r\n    else:\r\n        return True\r\n[END]",
      "base_output": "def point_in_circle(center, radius):\n    # ...\n    return ...",
      "teacher_ppl": 2.097310631604746,
      "base_ppl": 13.244090601162466,
      "ppl_diff": -11.14677996955772,
      "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 find_mode(list):\r\n  if len(list) == 0:\r\n    return -1\r\n  else:\r\n    return max(list)\r\n\r\n[END]",
      "base_output": "def find_mode(numbers):\n    # Initialize a set to store the counts of each number\n    counts = {}\n    for num in numbers:\n        counts[num] = counts.get(num, 0) + 1\n    # Find the number with the highest count\n    return max(counts, key=counts.get)\n#### 1",
      "teacher_ppl": 2.1867241883255844,
      "base_ppl": 2.328746143609479,
      "ppl_diff": -0.14202195528389483,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 123,
      "prompt": "Write a function to test if a string contains only binary digits.",
      "teacher_output": "import unittest\ndef is_binary_string(test_str):\r\n  for i in range(len(test_str)-1:\r\n    if test_str[i] not in '01':\r\n      return False\r\n  return True\r\ndef test_binary_string():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_binary_string()\r\n[END]",
      "base_output": "def is_binary_string(s):\n    # ...\n    return True",
      "teacher_ppl": 1.8641288933520992,
      "base_ppl": 8.795995853923149,
      "ppl_diff": -6.93186696057105,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 124,
      "prompt": "Write a function to check if a number is a perfect cube.",
      "teacher_output": "import unittest\ndef is_perfect_cube(n):\r\n  if n < 0:\r\n    return False\r\n  if n == 0:\r\n    return True\r\n  if n % 1 == 0:\r\n    return False\r\n  return pow(n, 3) == n",
      "base_output": "def is_perfect_cube(n):\n    # Your code here\n    return None\n",
      "teacher_ppl": 1.5053096709675824,
      "base_ppl": 7.716758069382097,
      "ppl_diff": -6.211448398414515,
      "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 list_to_binary(list):\r\n  res = [int(i) << (8*i) for i in range(len(list))]\r\n  return [format(res[i], 'b') for i in range(len(res))]\r\n\r\n[END]",
      "base_output": "def list_to_binary(numbers):\n    return [format(x, 'b') for x in numbers]",
      "teacher_ppl": 2.197897833421022,
      "base_ppl": 2.3420267927059517,
      "ppl_diff": -0.14412895928492953,
      "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 shortest_word_length(text):\r\n  return len(min(text.split(), key=len))\r\n[END]",
      "base_output": "def shortest_word_length(sentence):\n    # Your code goes here\n    return",
      "teacher_ppl": 3.298214405106018,
      "base_ppl": 4.70049525439571,
      "ppl_diff": -1.402280849289692,
      "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 diagonal_sums(matrix):\r\n  n = len(matrix)\r\n  sum = 0\r\n  for i in range(n):\r\n    sum += matrix[i][i]\r\n  return sum",
      "base_output": "def diagonal_sums(matrix):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.9363827990282756,
      "base_ppl": 11.050365176174425,
      "ppl_diff": -9.11398237714615,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 128,
      "prompt": "Write a function to count how many words are in a given string.",
      "teacher_output": "def word_count(text):\r\n  return len(text.split())\r\ndef test_word_count():\r\n  assert word_count('hello world') == 2\r\n  assert word_count('') == 0\r\n  assert word_count('   spaced out ') == 2\r\ntest_word_count()",
      "base_output": "def word_count(s):\n    # ...\n    return len(s.split())",
      "teacher_ppl": 2.1517746782272384,
      "base_ppl": 5.304954098319776,
      "ppl_diff": -3.1531794200925374,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 129,
      "prompt": "Write a function to find all numbers in a string.",
      "teacher_output": "def extract_numbers(text):\r\n  return [int(i) for i in text.split() if i.isdigit()]",
      "base_output": "def extract_numbers(s):\n    return [int(c) for c in s.split()]",
      "teacher_ppl": 2.337632065339956,
      "base_ppl": 3.905904876491524,
      "ppl_diff": -1.568272811151568,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 130,
      "prompt": "Write a function to find the sum of factorials of the digits of a number.",
      "teacher_output": "import math\ndef sum_digit_factorials(n):\r\n  if n == 0:\r\n    return 1\r\n  else:\r\n    return 1 + sum_digit_factorials(n-1)\r\n[END]",
      "base_output": "def sum_digit_factorials(n):\n    # Your code here\n    return None\n",
      "teacher_ppl": 2.140528069268957,
      "base_ppl": 11.438927337348446,
      "ppl_diff": -9.29839926807949,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 132,
      "prompt": "Write a function to check whether a list is a subset of another list.",
      "teacher_output": "def is_subset(list1, list2):\r\n    return len(list1) <= len(list2) and all(x in list2 for x in list1)",
      "base_output": "def is_subset(list1, list2):\n    # ...\n    return ...\nEND\n#### 2",
      "teacher_ppl": 1.610299959860579,
      "base_ppl": 9.367439148130002,
      "ppl_diff": -7.757139188269423,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 133,
      "prompt": "Write a function to find the most frequent character in a string.",
      "teacher_output": "import unittest\ndef most_frequent_char(s):\r\n  cnt = {}\r\n  for i in s:\r\n    cnt[i] = cnt.get(i, 0) + 1\r\n  return max(cnt.items())[0]\r\ndef test_most_frequent_char():\r\n  unittest.TestCase().testMethod = test_most_frequent_char\r\n  def test_most_frequent_char_1():\r\n    s = 'aabbccdde'\r\n    assert most",
      "base_output": "def most_frequent_char(s):\n    # Initialize a dictionary to count the frequency of each character\n    freq = {}\n    for c in s:\n        freq[c] = freq.get(c, 0) + 1\n    # Return the most frequent character\n    return max(freq.items(), key=lambda x: x[1])\n\n#### 1",
      "teacher_ppl": 1.7785435794959417,
      "base_ppl": 1.8634154870933415,
      "ppl_diff": -0.08487190759739982,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 135,
      "prompt": "Write a function to count the number of unique words in a sentence.",
      "teacher_output": "def count_unique_words(text):\r\n  count = 0\r\n  for i in text:\r\n    if i not in set():\r\n      count += 1\r\n  return count",
      "base_output": "def count_unique_words(text):\n    # ...\n    return len(set(words))",
      "teacher_ppl": 1.6877352270903825,
      "base_ppl": 4.448277140895943,
      "ppl_diff": -2.7605419138055605,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 136,
      "prompt": "Write a function to find the number of digits in an integer.",
      "teacher_output": "def digit_count(n):\r\n  if n < 0:\r\n    return 3\r\n  return 10\r\n[END]",
      "base_output": "def digit_count(n):\n    return len(str(n))",
      "teacher_ppl": 3.2855112584256174,
      "base_ppl": 4.169786088396252,
      "ppl_diff": -0.8842748299706349,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 137,
      "prompt": "Write a function to replace spaces with underscores in a string.",
      "teacher_output": "import unittest\ndef replace_spaces(s):\r\n  return (s.replace(' ','_'))\r\ndef test_replace_spaces():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_replace_spaces()\r\n[END]",
      "base_output": "def replace_spaces(s):\n    return s.replace(' ', '_')",
      "teacher_ppl": 2.1303963477912387,
      "base_ppl": 2.9727471191381247,
      "ppl_diff": -0.8423507713468861,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 138,
      "prompt": "Write a function to find the second highest value in a list.",
      "teacher_output": "def second_highest(nums):\r\n  if len(nums) < 2:\r\n    return None\r\n  return max(nums[1:], key=lambda x: x)\r\n\r\n[END]",
      "base_output": "def second_highest(numbers):\n    # Your code goes here\n    return None",
      "teacher_ppl": 1.8670683514751765,
      "base_ppl": 6.916678461067334,
      "ppl_diff": -5.049610109592157,
      "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_even_indexed(list):\r\n  res = 0\r\n  for i in range(len(list)):\r\n    if i % 2 == 0:\r\n      res += list[i]\r\n  return res",
      "base_output": "def sum_even_indexed(numbers):\n    # Your code here\n    pass",
      "teacher_ppl": 1.5081081514705381,
      "base_ppl": 9.211132057756258,
      "ppl_diff": -7.703023906285719,
      "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 index_of_max(list):\r\n  if not list:\r\n    return None\r\n  max_element = max(list, key=lambda x: x)\r\n  return list.index(max_element)",
      "base_output": "def index_of_max(numbers):\n    # Your code goes here\n    return None",
      "teacher_ppl": 1.9236099495953123,
      "base_ppl": 8.503366481753577,
      "ppl_diff": -6.579756532158265,
      "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 all_positive(list1):\r\n  for i in range(len(list1)):\r\n    if list1[i] < 0:\r\n      return False\r\n  return True\r\n\r\n[END]",
      "base_output": "def all_positive(numbers):\n    return all(num > 0 for num in numbers)\n#### 0",
      "teacher_ppl": 2.103895711782062,
      "base_ppl": 4.999429513934317,
      "ppl_diff": -2.8955338021522548,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 143,
      "prompt": "Write a function to interleave two lists of equal length.",
      "teacher_output": "def interleave_lists(list1, list2):\r\n  result = list1 + list2\r\n  return result\r\ndef test_interleave_lists():\r\n  result = interleave_lists([1,2], ['a','b'])\r\n  assert result == [1,'a',2,'b']\r\n  result = interleave_lists([], [])\r\n  assert result == []\r\n  result = interleave_lists([0,0], [1,1])\r\n  assert result == [0,1,0,",
      "base_output": "def interleave_lists(list1, list2):\n    return list(zip(list1, list2))\n#### 2",
      "teacher_ppl": 1.9479295910286396,
      "base_ppl": 3.655263921281348,
      "ppl_diff": -1.7073343302527082,
      "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_two_digit_numbers(nums):\r\n  res = 0\r\n  for num in nums:\r\n    if num >= 100:\r\n      res += num\r\n    else:\r\n      res += 100\r\n  return res",
      "base_output": "def sum_two_digit_numbers(numbers):\n    # Your code here\n    pass",
      "teacher_ppl": 1.6190478361678327,
      "base_ppl": 7.14996207899291,
      "ppl_diff": -5.5309142428250775,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 145,
      "prompt": "Write a function to count how many times a character appears in a string.",
      "teacher_output": "def char_count(s, c):\r\n  count = 0\r\n  for i in s:\r\n    if i == c:\r\n      count += 1\r\n  return count",
      "base_output": "def char_count(str, ch):\n    \"\"\"\n    Return the number of times the character 'ch' appears in the string 'str'.\n    \"\"\"\n    # ...\n    return len(str.count(ch))\n",
      "teacher_ppl": 1.5492528362565139,
      "base_ppl": 3.068376733192375,
      "ppl_diff": -1.5191238969358611,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 146,
      "prompt": "Write a function to get the last digit of an integer.",
      "teacher_output": "def last_digit(n):\r\n  return n % 10\r\ndef test_last_digit():\r\n  n = 1234\r\n  assert last_digit(n) == 4\r\n  n = -789\r\n  assert last_digit(n) == 9\r\n  n = 0\r\n  assert last_digit(n) == 0\r\ntest_last_digit()",
      "base_output": "def last_digit(n):\n    return n % 10\n#### 10",
      "teacher_ppl": 1.5461929781742452,
      "base_ppl": 7.279472303898132,
      "ppl_diff": -5.7332793257238865,
      "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": "import re\r\ndef title_case(text):\r\n    text = re.sub(r'^-+', '', text)\r\n    text = re.sub(r'-+$', '', text)\r\n    text = re.sub(r'-+', '', text)\r\n    return text.title()\r\n[END]",
      "base_output": "def title_case(s):\n    return s.split(' ')[0].capitalize() + ' ' + s.split(' ')[1:]\n#### 1",
      "teacher_ppl": 1.942131678724841,
      "base_ppl": 4.196395505279783,
      "ppl_diff": -2.254263826554942,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 148,
      "prompt": "Write a function to repeat each character in a string twice.",
      "teacher_output": "def double_chars(s):\r\n  if not s:\r\n    return ''\r\n  return list(map(lambda x: x + x, s))\r\n[END]",
      "base_output": "def double_chars(s):\n    # ...",
      "teacher_ppl": 2.597860949696167,
      "base_ppl": 15.737414422373185,
      "ppl_diff": -13.139553472677019,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 150,
      "prompt": "Write a function to check if all characters in a string are unique.",
      "teacher_output": "import unittest\ndef all_unique_chars(str):\r\n  return len(set(str)) == len(str)",
      "base_output": "def all_unique_chars(s):\n    # ...\n    return True",
      "teacher_ppl": 2.909124184314432,
      "base_ppl": 7.476042163084097,
      "ppl_diff": -4.5669179787696645,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 152,
      "prompt": "Write a function to convert a number to a list of its digits.",
      "teacher_output": "import unittest\ndef number_to_digits(n):\r\n  if n < 0:\r\n    return [str(abs(n))[1:]\r\n  else:\r\n    return [str(n)[:10]]\r\ndef test_number_to_digits():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_number_to_digits()\r\n[END]",
      "base_output": "def number_to_digits(n):\n    return [str(x) for x in math.modf(n)]",
      "teacher_ppl": 1.892198818522479,
      "base_ppl": 3.2100714640224832,
      "ppl_diff": -1.3178726455000043,
      "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": "import re\ndef ascii_sum(s):\r\n  return sum(ord(c) for c in s)",
      "base_output": "def ascii_sum(s):\n    # ...\n    return sum(ord(c) for c in s)",
      "teacher_ppl": 2.2054997514175936,
      "base_ppl": 2.9883917863953804,
      "ppl_diff": -0.7828920349777868,
      "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 first_negative_index(list):\r\n  for i in range(len(list)):\r\n    if list[i] < 0:\r\n      return i\r\n  return -1\r\ndef test_first_negative_index():\r\n  result = first_negative_index([1,2,-3,4])\r\n  assert result == 2\r\n  result = first_negative_index([1,2,3])\r\n  assert result == -1\r\n  result = first_negative_index([-1,2,3])",
      "base_output": "def first_negative_index(numbers):\n    for i, num in enumerate(numbers):\n        if num < 0:\n            return i\n    return -1\n#### -1",
      "teacher_ppl": 1.5733876079110765,
      "base_ppl": 2.6216138524384442,
      "ppl_diff": -1.0482262445273678,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 155,
      "prompt": "Write a function to count how many words start with a vowel in a sentence.",
      "teacher_output": "def count_words_starting_with_vowel(text):\r\n  count = 0\r\n  for c in text:\r\n    if c.lower() in 'aeiou':\r\n      count += 1\r\n  return count",
      "base_output": "def count_words_starting_with_vowel(sentence):\n    # ...\n    return len(filter(lambda x: x.lower() in 'aeiou', sentence.split()))\n",
      "teacher_ppl": 1.8109233957112396,
      "base_ppl": 3.2163204253628277,
      "ppl_diff": -1.405397029651588,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 156,
      "prompt": "Write a function to rotate a string left by n positions.",
      "teacher_output": "import unittest\ndef rotate_left(s, n):\r\n  if n <= 0:\r\n    return s\r\n  return s[:n-1] + s[n-1:]\r\ndef test_rotate_left():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_rotate_left()",
      "base_output": "def rotate_left(s, n):\n    # Your code here\n    return s\n",
      "teacher_ppl": 1.6336066873300878,
      "base_ppl": 6.088165771997552,
      "ppl_diff": -4.454559084667464,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 157,
      "prompt": "Write a function to compute the transpose of a matrix.",
      "teacher_output": "import unittest\ndef transpose(matrix):\n  n = len(matrix)\n  if n == 0:\n    return []\n  return [[matrix[i][j] for j in range(n)] for i in range(n)]\ndef test_transpose():\n  unittest.main()\n[END]",
      "base_output": "def transpose(matrix):\n    n = len(matrix)\n    return [row for row in matrix]",
      "teacher_ppl": 2.1658064956349077,
      "base_ppl": 2.878544677560773,
      "ppl_diff": -0.7127381819258654,
      "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):\r\n  return n & 0x55555555\r\ndef test_count_set_bits():\r\n  n = 7\r\n  assert count_set_bits(n) == 3\r\n  n = 0\r\n  assert count_set_bits(n) == 0\r\n  n = 8\r\n  assert count_set_bits(n) == 1",
      "base_output": "def count_set_bits(n):\n    # Your code here\n    return 0\n#### 0",
      "teacher_ppl": 1.7612767114382244,
      "base_ppl": 12.727334251246214,
      "ppl_diff": -10.96605753980799,
      "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 is_non_decreasing(list1):\r\n  if not list1:\r\n    return True\r\n  else:\r\n    return all(list1[:-1] <= list1[-1])",
      "base_output": "def is_non_decreasing(numbers):\n    return all(numbers[i] <= numbers[i-1])\n#### -1",
      "teacher_ppl": 1.8421228003238757,
      "base_ppl": 6.007774927641124,
      "ppl_diff": -4.165652127317249,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 160,
      "prompt": "Write a function to generate all pairs of elements from a list.",
      "teacher_output": "def generate_pairs(list1):\r\n  if not list1:\r\n    return []\r\n  else:\r\n    return list1[0] + generate_pairs(list1[1:])\r\n\r\n[END]",
      "base_output": "def generate_pairs(list):\n    # ...\n    return pairs",
      "teacher_ppl": 2.155667515670281,
      "base_ppl": 6.71297965053576,
      "ppl_diff": -4.557312134865479,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 161,
      "prompt": "Write a function to calculate the sum of numbers divisible by 3 or 5 below n.",
      "teacher_output": "def sum_divisible_by_3_or_5(n):\r\n    return n * (3 if n % 3 == 0 else 5)",
      "base_output": "def sum_divisible_by_3_or_5(n):\n    return sum(x for x in range(n) if x % 3 == 0 or x % 5 == 0)\n\n#### 0",
      "teacher_ppl": 2.4667830609626473,
      "base_ppl": 2.603563285592283,
      "ppl_diff": -0.13678022462963568,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 162,
      "prompt": "Write a function to check if two strings are permutations of each other.",
      "teacher_output": "def are_permutations(s1, s2):\r\n  return s1 == s2 or (len(s1) == 1 and s1[0] != s2[0])\r\n[END]",
      "base_output": "def are_permutations(str1, str2):\n    # ...\n    return ...\nEND\n#### 2",
      "teacher_ppl": 2.663447526426658,
      "base_ppl": 9.088429746313272,
      "ppl_diff": -6.424982219886614,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 163,
      "prompt": "Write a function to find the smallest positive integer missing from a list.",
      "teacher_output": "def smallest_missing_positive(nums):\r\n  return min(nums, key=lambda x: x)",
      "base_output": "def smallest_missing_positive(numbers):\n    # Your code goes here\n    return",
      "teacher_ppl": 3.440212954417051,
      "base_ppl": 6.844512206069133,
      "ppl_diff": -3.4042992516520822,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 164,
      "prompt": "Write a function to remove punctuation from a string.",
      "teacher_output": "import re\r\ndef remove_punctuation(text):\r\n  return (re.sub('[^a-zA-Z0-9]', '', text))\r\n[END]",
      "base_output": "def remove_punctuation(s):\n    return s.translate(str.maketrans(\"\", \"\", string.punctuation))",
      "teacher_ppl": 2.0346464300100586,
      "base_ppl": 1.9901242689341396,
      "ppl_diff": 0.044522161075919,
      "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 char_frequency(text):\r\n  count = {}\r\n  for i in text:\r\n    count[i] = count.get(i, 0) + 1\r\n  return count\r\n[END]",
      "base_output": "def char_frequency(s):\n    return {}",
      "teacher_ppl": 1.9303493514994572,
      "base_ppl": 8.571404822764482,
      "ppl_diff": -6.641055471265025,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 166,
      "prompt": "Write a function to remove duplicates from a list while preserving order.",
      "teacher_output": "def deduplicate(list):\r\n  result = list.copy()\r\n  result.reverse()\r\n  for i in range(len(result) - 1):\r\n    if result[i] == result[i + 1]:\r\n      result.pop(i + 1)\r\n  return result\r\n\r[END]",
      "base_output": "def deduplicate(list):\n    # ...",
      "teacher_ppl": 1.907123002991104,
      "base_ppl": 16.803720513440936,
      "ppl_diff": -14.896597510449832,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 167,
      "prompt": "Write a function to check if a number is a palindrome.",
      "teacher_output": "import unittest\ndef is_numeric_palindrome(n):\r\n  if n < 0:\r\n    return False\r\n  while n > 0:\r\n    if n % 2 == 0:\r\n      return False\r\n    n = n // 2\r\n  return True\r\ndef test_palindrome():\r\n  unittest.main()\r\n[END]",
      "base_output": "def is_numeric_palindrome(n):\n    # Your code goes here\n    pass\n",
      "teacher_ppl": 1.9119863541110946,
      "base_ppl": 9.35137685061264,
      "ppl_diff": -7.439390496501545,
      "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):\r\n  return set(list1).intersection(list2)\r\ndef test_common_elements():\r\n  t1 = [1,2,3]\r\n  t2 = [2,3,4]\r\n  t3 = []\r\n  t4 = [5,6]\r\n  t5 = [6,7]\r\n  assert_equal = [\r\n      'common_elements([1,2,3], [2,3,4])', \r\n      'common_elements([],",
      "base_output": "def common_elements(list1, list2):\n    # Write code here\n    return []\n#### 2",
      "teacher_ppl": 2.1459186522195233,
      "base_ppl": 7.509427866385776,
      "ppl_diff": -5.363509214166253,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 169,
      "prompt": "Write a function to check if a number is a perfect number (equal to sum of its proper divisors).",
      "teacher_output": "import math\ndef is_perfect_number(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(n**0.5) + 1):\r\n    if n % i == 0:\r\n      if is_perfect_number(n / i) == False:\r\n        return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n      ('6', True),\r\n      ('28', True),\r\n      ('12', False),",
      "base_output": "def is_perfect_number(n):\n    # Initialize a set to store the divisors\n    divisors = set()\n    \n    # Loop through the numbers from 2 to sqrt(n)\n    for i in range(2, int(n ** 0.5) + 1):\n        # Check if the number is a divisor of n\n        if n % i == 0:\n            # Add the divisor to the set\n            divisors.add(i)\n            \n            # Check if the set is equal to the set of all divisors\n#### 0",
      "teacher_ppl": 1.6388168158660084,
      "base_ppl": 1.9331457184449312,
      "ppl_diff": -0.29432890257892286,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 170,
      "prompt": "Write a function to compute the nth triangular number.",
      "teacher_output": "import unittest\n\ndef triangular_number(n):\r\n    if n <= 0:\r\n        return 0\r\n    return n * (n + 1) / 2\r\n\r\ndef test_triangular_number():\r\n    unittest.main()\r\n\r\nif __name__ == '__main__':\r\n    test_triangular_number()\r\n[END]",
      "base_output": "def triangular_number(n):\n    # Your code goes here\n    return None",
      "teacher_ppl": 1.6713407385096053,
      "base_ppl": 8.973368611912031,
      "ppl_diff": -7.302027873402426,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 171,
      "prompt": "Write a function to merge two dictionaries. In case of conflict, use values from the second.",
      "teacher_output": "def merge_dicts(d1, d2):\r\n    result = {}\r\n    for key, value in d1.items():\r\n        result[key] = max(value, d2.get(key, value))\r\n    return result\r\n[END]",
      "base_output": "def merge_dicts(dict1, dict2):\n    result = {}\n    for key, value in dict1.items():\n        if key in dict2:\n            result[key] = dict2[key]\n        else:\n            result[key] = value\n    return result\n#### 2",
      "teacher_ppl": 1.609051011467167,
      "base_ppl": 1.7551440527888973,
      "ppl_diff": -0.1460930413217303,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 172,
      "prompt": "Write a function to return the common prefix between two strings.",
      "teacher_output": "def common_prefix(str1, str2):\r\n  if len(str1) < 2 or len(str2) < 2:\r\n    return None\r\n  return str1[:min(len(str1), len(str2))]\r\n[END]",
      "base_output": "def common_prefix(str1, str2):\n    # Your code here\n    return None\n\n#### 2",
      "teacher_ppl": 1.7072117072185415,
      "base_ppl": 6.382303245472402,
      "ppl_diff": -4.67509153825386,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 173,
      "prompt": "Write a function to find the number of trailing zeros in a factorial.",
      "teacher_output": "import unittest\ndef count_trailing_zeros(n):\r\n  if n == 0:\r\n    return 0\r\n  return 1 + count_trailing_zeros(n // 10)\r\ndef test_count_trailing_zeros():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_count_trailing_zeros()\r\n[END]",
      "base_output": "def count_trailing_zeros(n):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.6718970195851404,
      "base_ppl": 8.406685866161373,
      "ppl_diff": -6.734788846576233,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 174,
      "prompt": "Write a function to calculate the harmonic sum of n terms.",
      "teacher_output": "import math\ndef harmonic_sum(n):\r\n  if n <= 0:\r\n    return 0\r\n  else:\r\n    return round(n * (math.pi / 2) * math.pow(n, n - 1), 5)",
      "base_output": "def harmonic_sum(n):\n    # Write code here\n    pass",
      "teacher_ppl": 2.090336206981447,
      "base_ppl": 7.065779184364232,
      "ppl_diff": -4.9754429773827855,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 175,
      "prompt": "Write a function to convert a number to base-2 (binary) as a string.",
      "teacher_output": "import unittest\ndef to_binary(n):\r\n  return format(n, 'b')\r\ndef test_to_binary():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n    test_to_binary()\r\n[END]",
      "base_output": "def to_binary(n):\n    return \"\"",
      "teacher_ppl": 2.1070487234138455,
      "base_ppl": 13.635809197246363,
      "ppl_diff": -11.528760473832518,
      "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 unique_char_count(s):\r\n  c = {}\r\n  for i in s:\r\n    c[i] = c.get(i, 0) + 1\r\n  return len(c)",
      "base_output": "def unique_char_count(s):\n    # ...\n    return len(set(s))",
      "teacher_ppl": 1.6835538460643626,
      "base_ppl": 4.871515243061641,
      "ppl_diff": -3.187961396997278,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 178,
      "prompt": "Write a function to reverse a dictionary (values must be unique).",
      "teacher_output": "def reverse_dict(dct):\r\n  result = {}\r\n  for key, value in dct.items():\r\n    result[value] = key\r\n  return result\r\ndef test_reverse_dict():\r\n  result = reverse_dict({'a': 1, 'b': 2})\r\n  assert result == {1: 'a', 2: 'b'}\r\n  result = reverse_dict({'x': 100})\r\n  assert result == {100: 'x'}\r\n  result = reverse_dict",
      "base_output": "def reverse_dict(dict):\n    # ...\n    return dict",
      "teacher_ppl": 1.790027477670832,
      "base_ppl": 6.978695788434906,
      "ppl_diff": -5.188668310764074,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 179,
      "prompt": "Write a function to return all positions of a character in a string.",
      "teacher_output": "import re\r\ndef char_positions(s, c):\r\n    m = re.search(r'^[' + c + ']+$', s)\r\n    if m:\r\n        return [m.start() + 1 for _ in range(m.end() - c + 1)]\r\n    else:\r\n        return []\r\ndef test_char_positions():\r\n    import doctest\r\n    doctest.testmod() \r\n    return\r\ndef main():\r\n    test_char_positions()\r\n    return",
      "base_output": "def char_positions(s, c):\n    # ...\n    return positions",
      "teacher_ppl": 1.654195628064054,
      "base_ppl": 7.098095895439608,
      "ppl_diff": -5.443900267375554,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "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": "import math\ndef diff_sum_squares(n):\r\n  if n <= 0:\r\n    return 0\r\n  return n * (n + 1) - (math.sqrt(n * (n + 1)) + 1)",
      "base_output": "def diff_sum_squares(n):\n    # Your code here\n    pass",
      "teacher_ppl": 1.7385636758113818,
      "base_ppl": 13.201756363793844,
      "ppl_diff": -11.463192687982463,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 182,
      "prompt": "Write a function to check if a list contains a sublist.",
      "teacher_output": "def contains_sublist(list1, list2):\r\n  return any(i in list1 for i in list2)\r\ndef main():\r\n  return contains_sublist([1,2,3,4], [2,3])\r\nif __name__ == '__main__':\r\n  main()\r\n[END]",
      "base_output": "def contains_sublist(list, sublist):\n    # Your code here\n    return True",
      "teacher_ppl": 1.957300524779476,
      "base_ppl": 6.550247058176033,
      "ppl_diff": -4.592946533396557,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 183,
      "prompt": "Write a function to count how many numbers in a list are above average.",
      "teacher_output": "def count_above_average(nums):\r\n  return sum(nums[i] for i in range(len(nums)) if nums[i] > mean)\r\ndef test_count_above_average():\r\n  n = 5\r\n  mean = sum(nums)/n\r\n  nums = [1,2,3,4,5]\r\n  assert count_above_average(nums) == 2\r\n  assert count_above_average([5,5,5]) == 0\r\n  assert",
      "base_output": "def count_above_average(numbers):\n    # Calculate the average of the list\n    average = sum(numbers) / len(numbers)\n    # Iterate over the list and count the numbers above the average\n    return len([number for number in numbers if number > average])",
      "teacher_ppl": 1.6811849344058472,
      "base_ppl": 2.12346250244882,
      "ppl_diff": -0.4422775680429727,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 184,
      "prompt": "Write a function to return all substrings of a string.",
      "teacher_output": "import unittest\ndef all_substrings(s):\r\n  return [i for i in s if i not in s[:i] or i in s[i:]]\r\ndef test_all_substrings():\r\n  unittest.TestCase().testMethod = test_all_substrings\r\n  def test_substrings(self):\r\n    self.assertEqual(all_substrings('abc'), ['a', 'ab', 'abc', 'b', 'bc', 'c'])\r\n    self.assertEqual(all_substrings('a'), ['a']",
      "base_output": "def all_substrings(s):\n    # ...\n    return substrings",
      "teacher_ppl": 1.913204081379508,
      "base_ppl": 8.434997561595782,
      "ppl_diff": -6.5217934802162745,
      "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": "import unittest\ndef is_power_of_two(n):\r\n  return n & (n - 1) == 0\r\ndef test_is_power_of_two():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_is_power_of_two()\r\n[END]",
      "base_output": "def is_power_of_two(n):\n    return n > 0 and n & (n - 1) == 0\n#### 0",
      "teacher_ppl": 1.7910560178016022,
      "base_ppl": 4.099556541100958,
      "ppl_diff": -2.3085005232993554,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 187,
      "prompt": "Write a function to calculate the sum of the digits in a number.",
      "teacher_output": "def digit_sum(n):\r\n  result = 0\r\n  while n > 0:\r\n    result = result + n % 10\r\n    n = n // 10\r\n  return result",
      "base_output": "def digit_sum(n):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.5545369973861503,
      "base_ppl": 12.72422439904496,
      "ppl_diff": -11.169687401658809,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 188,
      "prompt": "Write a function to reverse the order of words in a sentence.",
      "teacher_output": "def reverse_words(s):\r\n  return ' '.join(s.split()[::-1])\r\ndef test_reverse_words():\r\n  assert reverse_words('hello world') == 'world hello'\r\n  assert reverse_words('a b c') == 'c b a'\r\n  assert reverse_words('') == ''\r\ntest_reverse_words()",
      "base_output": "def reverse_words(sentence):\n    return \"\".join(words[::-1])\n\n#### -1",
      "teacher_ppl": 1.6691076068454833,
      "base_ppl": 4.956899412947859,
      "ppl_diff": -3.2877918061023754,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 189,
      "prompt": "Write a function to compute the sum of the digits raised to the power of their positions.",
      "teacher_output": "def digit_power_sum(n):\r\n  if n == 0:\r\n    return 0\r\n  return int(n**n)\r\n[END]",
      "base_output": "def digit_power_sum(n):\n    return",
      "teacher_ppl": 2.814112637273197,
      "base_ppl": 7.935114064921528,
      "ppl_diff": -5.121001427648331,
      "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 are_disjoint(list1, list2):\r\n  return len(list1) != len(set(list1) | set(list2))\r\n  \r\ndef test_are_disjoint():\r\n    assert are_disjoint(['a', 'b', 'c'], ['c', 'd', 'e']) == False\r\n    assert are_disjoint(['a', 'b', 'c'], ['a', 'b', 'c']) == True\r\n    assert are_disjoint([], ['a', 'b', 'c']) == True",
      "base_output": "def are_disjoint(list1, list2):\n    # ...\n    return ...\n#### 2",
      "teacher_ppl": 1.6385850043524302,
      "base_ppl": 9.82716105632532,
      "ppl_diff": -8.18857605197289,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 191,
      "prompt": "Write a function to generate a list of all permutations of length r from a given list.",
      "teacher_output": "def all_permutations(list1, r):\r\n    n = len(list1)\r\n    if r == 0:\r\n        return []\r\n    if n == 0:\r\n        return [()]\r\n    res = []\r\n    i = 0\r\n    while i < n:\r\n        res.append((list1[i], i))\r\n        i += 1\r\n    res.append((list1[n-1], n-1))\r\n    res.reverse()\r\n    return res",
      "base_output": "def all_permutations(list, r):\n    # ...\n    return ...",
      "teacher_ppl": 1.6972983613435477,
      "base_ppl": 6.695176112808339,
      "ppl_diff": -4.997877751464791,
      "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": "import re\r\ndef is_clean_palindrome(text):\r\n\ttext = text.lower()\r\n\ttext = re.sub(r'[^\\w\\s]', '', text)\r\n\ttext = re.sub(r'[^\\w\\s]', '', text)\r\n\treturn True if text == text[::-1] else False\r\n[END]",
      "base_output": "def is_clean_palindrome(s):\n    # ...\n    return clean_palindrome(s)",
      "teacher_ppl": 1.9611559893322672,
      "base_ppl": 6.753736559253054,
      "ppl_diff": -4.792580569920786,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 194,
      "prompt": "Write a function to return a flattened version of a nested list (one level deep).",
      "teacher_output": "def flatten_once(list1):\r\n  if not list1:\r\n    return list1\r\n  res = [item for sublist in list1 for item in sublist]\r\n  return res",
      "base_output": "def flatten_once(list):\n    # Your code here\n    return list",
      "teacher_ppl": 1.8303515567110373,
      "base_ppl": 10.965512966208518,
      "ppl_diff": -9.135161409497481,
      "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(nums):\r\n  if len(nums) < 2:\r\n    return False\r\n  if nums[0] != 1:\r\n    return False\r\n  for i in range(1, len(nums)):\r\n    if nums[i] != nums[i-1] * 2:\r\n      return False\r\n  return True\r\n\r\ndef test_is_geometric():\r\n  pass\r\n\r\ntest_is_geometric()",
      "base_output": "def is_geometric(numbers):\n    # Your code goes here\n    return None",
      "teacher_ppl": 1.5384237370366303,
      "base_ppl": 9.769410574084109,
      "ppl_diff": -8.230986837047478,
      "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_above_avg(list1):\r\n  if not list1:\r\n    return 0\r\n  return sum(x for x in list1 if x > list1[0])\r\n\r\n[END]",
      "base_output": "def count_above_avg(numbers):\n    # calculate the average\n    avg = sum(numbers) / len(numbers)\n    # count the number of elements greater than the average\n    return len([x for x in numbers if x > avg])",
      "teacher_ppl": 2.283087182899981,
      "base_ppl": 2.3127709308041577,
      "ppl_diff": -0.029683747904176716,
      "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(s):\r\n  count = 0\r\n  for i in range(len(s)-1, -1, -1):\r\n    if s[i] != s[i-1]:\r\n      break\r\n  count += 1\r\n  return count",
      "base_output": "def count_palindromes(s):\n    # ...\n    return ...",
      "teacher_ppl": 1.6168818801321494,
      "base_ppl": 8.15079863098526,
      "ppl_diff": -6.533916750853111,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 199,
      "prompt": "Write a function to generate the powerset of a list.",
      "teacher_output": "def powerset(list):\r\n  if not list:\r\n    return [()]\r\n  else:\r\n    return list(itertools.combinations(list, 2)) + list(itertools.combinations(list, 3))\r\ndef test_powerset():\r\n  assert powerset([1,2]) == [()]\r\n  assert powerset([]) == [()]\r\n  assert len(powerset([1,2,3])) == 8\r\ntest_powerset()",
      "base_output": "def powerset(list):\n    # ...\n    return ...",
      "teacher_ppl": 1.9804617148588,
      "base_ppl": 10.59785553824521,
      "ppl_diff": -8.61739382338641,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 200,
      "prompt": "Write a function to check if a number is an Armstrong number.",
      "teacher_output": "import math\ndef is_armstrong(n):\r\n  if n <= 1:\r\n    return False\r\n  for i in range(2, int(math.log(n, 2)) + 1):\r\n    if n % 2 == 0:\r\n      return False\r\n  return True\r\ndef test_cases():\r\n  return [\r\n    (153,),\r\n    (9474,),\r\n    (123,),\r\n  ]\r\n\r\n[END]",
      "base_output": "def is_armstrong(n):\n    # Base case: n is 0 or 1\n    if n == 0 or n == 1:\n        return True\n    # Recursive case: n is greater than 1 and is a product of distinct primes\n    for p in range(2, int(n ** 0.5) + 1):\n        if n % p == 0:\n            return False\n    return True\n\n#### 0",
      "teacher_ppl": 2.349116974662105,
      "base_ppl": 2.0506979517848354,
      "ppl_diff": 0.2984190228772694,
      "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 digit_frequency(n):\r\n  freq = {}\r\n  for i in range(10):\r\n    freq[i] = 0\r\n  while n > 0:\r\n    digit = n % 10\r\n    freq[digit] += 1\r\n    n = n // 10\r\n  return freq\r\n\r\n def test_digit_frequency():\r\n  n = 112233\r\n  assert digit_frequency(n) == {'1': 2,'2':",
      "base_output": "def digit_frequency(n):\n    freq = {}\n    for i in range(10):\n        freq[n % 10] = freq.get(n % 10, 0) + 1\n    return freq\n#### 1",
      "teacher_ppl": 1.6268434134876353,
      "base_ppl": 2.2186529226278537,
      "ppl_diff": -0.5918095091402185,
      "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 valid_brackets(test_str):\r\n  if test_str == '':\r\n    return True\r\n  open_brackets = set(['(',\r\n                     '[',\r\n                     '{'\r\n                    ])\r\n  close_brackets = set([')', \r\n                      ']',\r\n                      '}'\r\n                     ])\r\n  if any(close_brackets.discard(c) not in test_str for c in open_brackets):\r\n    return False\r\n  return True\r\n[END]",
      "base_output": "def valid_brackets(s):\n    # ...\n    return True",
      "teacher_ppl": 1.8458098624076669,
      "base_ppl": 6.315359826381565,
      "ppl_diff": -4.469549963973898,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 203,
      "prompt": "Write a function to return the length of the longest word in a sentence.",
      "teacher_output": "def longest_word_length(s):\r\n  return len(s)",
      "base_output": "def longest_word_length(sentence):\n    # Your code goes here\n    return",
      "teacher_ppl": 4.069013044378924,
      "base_ppl": 5.745575642085395,
      "ppl_diff": -1.6765625977064715,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 204,
      "prompt": "Write a function to convert all keys of a dictionary to lowercase.",
      "teacher_output": "def lowercase_keys(dct):\r\n  return (dct)\r\ndef test_lowercase_keys():\r\n    dict = {'A': 1, 'B': 2}\r\n    lowercase_dict = lowercase_keys(dict)\r\n    assert lowercase_dict == {'a': 1, 'b': 2}\r\n    dict = {'Key': 'Value'}\r\n    lowercase_dict = lowercase_keys(dict)\r\n    assert lowercase_dict == {'key': 'Value'}\r\n    dict = {}\r\n    lowercase_",
      "base_output": "def lowercase_keys(dct):\n    return {k.lower() for k in dct.keys()}",
      "teacher_ppl": 1.7767818973392768,
      "base_ppl": 3.293169104062344,
      "ppl_diff": -1.516387206723067,
      "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 all_elements_equal(matrix):\r\n  for i in range(len(matrix)):\r\n    for j in range(len(matrix[0])):\r\n      if matrix[i][j] != matrix[i][j]:\r\n        return False\r\n  return True\r\n\r\n[END]",
      "base_output": "def all_elements_equal(matrix):\n    # ...\n    return True",
      "teacher_ppl": 1.6563106892498656,
      "base_ppl": 10.173381382969794,
      "ppl_diff": -8.517070693719928,
      "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 ordered_intersection(list1, list2):\r\n    result = set(list1).intersection(list2)\r\n    return result\r\ndef test_ordered_intersection():\r\n    result = ordered_intersection([1,2,3], [2,3,4])\r\n    assert result == [2,3]\r\n    result = ordered_intersection([1,2], [3,4])\r\n    assert result == []\r\n    result = ordered_intersection( [], [1,2])\r\n    assert result == []\r\nif",
      "base_output": "def ordered_intersection(list1, list2):\n    # ...\n    return list1[::-1].intersection(list2[::-1])\n#### -1",
      "teacher_ppl": 1.605543116375171,
      "base_ppl": 4.739464996892277,
      "ppl_diff": -3.1339218805171063,
      "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 squares_dict(n):\r\n  d = {k: 0 for k in range(n + 1)}\r\n  for i in range(n + 1):\r\n    d[i] = i * i\r\n  return d\r\n[END]",
      "base_output": "def squares_dict(n):\n    return {i**2 for i in range(n)}\n#### 2",
      "teacher_ppl": 2.037689361955463,
      "base_ppl": 6.293028899695676,
      "ppl_diff": -4.255339537740213,
      "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 longest_word(words):\r\n  longest = ''\r\n  for word in words:\r\n    if not longest or len(longest) < len(word):\r\n      longest = word\r\n  return longest\r\n[END]",
      "base_output": "def longest_word(words):\n    longest = None\n    for word in words:\n        if longest is None or len(word) > len(longest):\n            longest = word\n    return longest\n",
      "teacher_ppl": 1.6853705282935811,
      "base_ppl": 1.6610724934861496,
      "ppl_diff": 0.024298034807431534,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 211,
      "prompt": "Write a function to compute the average of positive numbers in a list.",
      "teacher_output": "def average_positive(nums):\r\n  if not nums:\r\n    return 0\r\n  return (sum(nums)) / (len(nums))\r\n[END]",
      "base_output": "def average_positive(numbers):\n    return sum(numbers) / len(numbers)\n",
      "teacher_ppl": 2.6258659308387085,
      "base_ppl": 2.9491778590073894,
      "ppl_diff": -0.32331192816868093,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 212,
      "prompt": "Write a function to remove every nth element from a list.",
      "teacher_output": "def remove_every_nth(list, n):\r\n    return list[::n]\r\ndef test_remove_every_nth():\r\n    list = [1,2,3,4,5,6]\r\n    result = remove_every_nth(list, 2)\r\n    assert result == [1,3,5]\r\n    result = remove_every_nth([1,2,3], 1)\r\n    assert result == []\r\n    result = remove_every_nth([1,2,3,4], 5)\r\n    assert",
      "base_output": "def remove_every_nth(list, n):\n    # Your code here\n    pass",
      "teacher_ppl": 1.7803568371034333,
      "base_ppl": 4.385690243055572,
      "ppl_diff": -2.6053334059521394,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 213,
      "prompt": "Write a function to find all unique characters in a string.",
      "teacher_output": "def unique_characters(s):\r\n  seen = set()\r\n  return list(seen.union(s))\r\n[END]",
      "base_output": "def unique_characters(s):\n    # ...\n    return _unique_characters\ndef _unique_characters(s):\n    # ...\n    return set(s)\n",
      "teacher_ppl": 3.702031969335464,
      "base_ppl": 3.874199448447581,
      "ppl_diff": -0.1721674791121166,
      "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_of(list, element):\r\n    for i, item in enumerate(list):\r\n        if item == element:\r\n            return i\r\n    return -1\r\n\r\n[END]",
      "base_output": "def last_index_of(list, element):\n    # Your code here\n    return -1\n#### -1",
      "teacher_ppl": 1.7883078174374158,
      "base_ppl": 6.757987236555416,
      "ppl_diff": -4.969679419118,
      "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 list_product(list1):\r\n  if not list1:\r\n    return 1\r\n  return 1 if len(list1) == 1 else 1 + list_product(list1[1:])\r\n\r\n[END]",
      "base_output": "def list_product(list):\n    # Your code here\n    return None",
      "teacher_ppl": 2.04006771623011,
      "base_ppl": 11.13234794637268,
      "ppl_diff": -9.09228023014257,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 216,
      "prompt": "Write a function to generate the first n even numbers.",
      "teacher_output": "import random\ndef first_n_evens(n):\r\n  if n <= 0:\r\n    return []\r\n  evens = [2*i for i in range(n)]\r\n  evens.extend([2*i + 1 for i in range(n)])\r\n  return evens",
      "base_output": "def first_n_evens(n):\n    # Write code here\n    return []",
      "teacher_ppl": 1.6557457263089819,
      "base_ppl": 7.5617519857307265,
      "ppl_diff": -5.906006259421744,
      "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 word_frequency(text, word):\r\n    count = 0\r\n    for i in text:\r\n        if i == word:\r\n            count += 1\r\n    return count",
      "base_output": "def word_frequency(sentence, word):\n    # ...\n    return count",
      "teacher_ppl": 1.5994275384770678,
      "base_ppl": 6.407333454858515,
      "ppl_diff": -4.807905916381447,
      "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 row_maxima(matrix):\r\n  n = len(matrix)\r\n  res = [max(row) for row in matrix]\r\n  return res",
      "base_output": "def row_maxima(matrix):\n    # ...\n    return max(row[i] for i in range(len(row)))",
      "teacher_ppl": 2.2992151788506776,
      "base_ppl": 5.624017846005613,
      "ppl_diff": -3.3248026671549358,
      "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 divisible_by_all(n, list1):\r\n    for i in range(len(list1)):\r\n        if n % list1[i] != 0:\r\n            return False\r\n    return True\r\n[END]",
      "base_output": "def divisible_by_all(num, list):\n    for element in list:\n        if num % element == 0:\n            return False\n    return True\n\n#### 0",
      "teacher_ppl": 1.8510703940656537,
      "base_ppl": 2.658980198372392,
      "ppl_diff": -0.8079098043067383,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 220,
      "prompt": "Write a function to get the first repeated word in a string.",
      "teacher_output": "def first_repeated_word(text):\r\n  if not text:\r\n    return None\r\n  for i in range(1, len(text) - 1):\r\n    if text[i] == text[i - 1]:\r\n      return text[i]\r\n  return None\r\n[END]",
      "base_output": "def first_repeated_word(s):\n    # Initialize an empty set\n    seen_words = set()\n    \n    # Iterate through the string\n    for c in s:\n        # If the character is a letter or space, add it to the set\n        if c in 'abcdefghijklmnopqrstuvwxyz ':\n            # Check if the word has already been seen\n            if c in seen_words:\n                # Return the first repeated word\n                return seen_words.pop()\n            # Add the word to the set",
      "teacher_ppl": 1.6667763640554476,
      "base_ppl": 1.766639855893946,
      "ppl_diff": -0.09986349183849841,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 221,
      "prompt": "Write a function to generate a string of alternating 1s and 0s of length n, starting with 1.",
      "teacher_output": "def alternating_binary(n):\r\n  if n == 0:\r\n    return ''\r\n  else:\r\n    return str(n % 2)\r\n[END]",
      "base_output": "def alternating_binary(n):\n    # ...\n    return result\n",
      "teacher_ppl": 2.873309421232846,
      "base_ppl": 15.62184401169721,
      "ppl_diff": -12.748534590464363,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 222,
      "prompt": "Write a function to check if a list contains only integers.",
      "teacher_output": "def all_integers(test_list):\r\n  for i in range(len(test_list)):\r\n    if not isinstance(test_list[i], int):\r\n      return False\r\n  return True\r\n[END]",
      "base_output": "def all_integers(numbers):\n    return all(isinstance(x, int) for x in numbers)\n",
      "teacher_ppl": 1.920695108945234,
      "base_ppl": 3.3379882676587846,
      "ppl_diff": -1.4172931587135507,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 223,
      "prompt": "Write a function to double each value in a dictionary.",
      "teacher_output": "def double_values(dct):\r\n  res = {}\r\n  for key, val in dct.items():\r\n    res[key] = val * 2\r\n  return res",
      "base_output": "def double_values(d):\n    return {k: 2*v for k, v in d.items()}\n#### 2",
      "teacher_ppl": 1.5815409590389262,
      "base_ppl": 3.478981794013055,
      "ppl_diff": -1.8974408349741287,
      "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 binary_to_decimals(binary_list):\r\n    decimals = [int(i, 2) for i in binary_list]\r\n    return decimals",
      "base_output": "def binary_to_decimals(binary_list):\n    # Your code here\n    return decimals",
      "teacher_ppl": 1.8708419174878441,
      "base_ppl": 6.685298376057619,
      "ppl_diff": -4.814456458569775,
      "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 all_equal(list1):\r\n  return all(list1 == list1[0])\r\n  \r\ndef main():\r\n  result = all_equal([1, 2, 3])\r\n  if result:\r\n    print(\"All elements are equal\")\r\n  else:\r\n    print(\"All elements are not equal\")\r\n  \r\nif __name__ == '__main__':\r\n  main()",
      "base_output": "def all_equal(list):\n    return len(list) == 1 and list[0] == list[0]\n#### 0",
      "teacher_ppl": 1.6392584224899882,
      "base_ppl": 3.9883418566352726,
      "ppl_diff": -2.3490834341452844,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 227,
      "prompt": "Write a function to find the second smallest number in a list.",
      "teacher_output": "def second_smallest(nums):\r\n  if len(nums) <= 1:\r\n    return None\r\n  return min(nums[1:], key=lambda x: x)\r\n\r\n[END]",
      "base_output": "def second_smallest(numbers):\n    # ...\n    return smallest(numbers[1:])\n#### 1",
      "teacher_ppl": 1.8333432079561947,
      "base_ppl": 9.70983789199294,
      "ppl_diff": -7.876494684036746,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 229,
      "prompt": "Write a function to get the middle character(s) of a string.",
      "teacher_output": "def middle_characters(str):\r\n  if len(str) < 2:\r\n    return str\r\n  return str[len(str) // 2]\r\n[END]",
      "base_output": "def middle_characters(str):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 2.1934456548604313,
      "base_ppl": 9.68187615235931,
      "ppl_diff": -7.488430497498879,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 230,
      "prompt": "Write a function to remove the first and last characters of a string.",
      "teacher_output": "import unittest\n\ndef remove_ends(s):\r\n  return s[1:-1]\r\n\r\ndef test_remove_ends():\r\n  unittest.main()\r\n[END]",
      "base_output": "def remove_ends(s):\n    return s[1:-1]\n#### -1",
      "teacher_ppl": 3.156123682434821,
      "base_ppl": 8.718724133726257,
      "ppl_diff": -5.562600451291436,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 231,
      "prompt": "Write a function to flatten a list of tuples.",
      "teacher_output": "def flatten_tuples(test_list):\r\n  res = list()\r\n  for sub in test_list:\r\n    res.extend(sub)\r\n  return res",
      "base_output": "def flatten_tuples(lst):\n    return lst",
      "teacher_ppl": 1.8826077576240439,
      "base_ppl": 5.156183087153751,
      "ppl_diff": -3.2735753295297076,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 232,
      "prompt": "Write a function to check if a list is a palindrome.",
      "teacher_output": "def is_list_palindrome(list1):\r\n  if len(list1) < 2:\r\n    return True\r\n  else:\r\n    return all(list1[i] == list1[-i-1] for i in range(len(list1)-1))\r\n\r\n[END]",
      "base_output": "def is_list_palindrome(my_list):\n    # ...\n    return ...\nEND",
      "teacher_ppl": 1.8702731123715783,
      "base_ppl": 10.819283809672687,
      "ppl_diff": -8.949010697301109,
      "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_ordered(list1):\r\n  seen = set()\r\n  return list1\r\n  \r\ndef test_unique_ordered():\r\n  result = unique_ordered([1,2,2,3])\r\n  assert result == [1,2,3]\r\n  result = unique_ordered([1,1,1])\r\n  assert result == [1]\r\n  result = unique_ordered([])\r\n  assert result == []\r\n  \r\ntest_unique_ordered()",
      "base_output": "def unique_ordered(list):\n    # ...\n    return list",
      "teacher_ppl": 1.887184619874813,
      "base_ppl": 10.941879814865251,
      "ppl_diff": -9.054695194990439,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 235,
      "prompt": "Write a function to return the digit sum of a string containing digits.",
      "teacher_output": "import unittest\ndef digit_sum_string(str1):\r\n  sum = 0\r\n  for i in range(len(str1)):\r\n    sum = sum + int(str1[i])\r\n  return sum\r\ndef test_digit_sum_string():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_digit_sum_string()\r\n[END]",
      "base_output": "def digit_sum_string(s):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.6962095748053232,
      "base_ppl": 13.174488427833714,
      "ppl_diff": -11.47827885302839,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 236,
      "prompt": "Write a function to convert a list of strings to uppercase.",
      "teacher_output": "def to_uppercase(list1):\r\n  res = [ele.upper() for ele in list1]\r\n  return res",
      "base_output": "def to_uppercase(strings):\n    return [s.upper() for s in strings]",
      "teacher_ppl": 1.903202285803229,
      "base_ppl": 3.208987232107084,
      "ppl_diff": -1.3057849463038549,
      "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 all_distinct(list1):\r\n  if len(list1) <= 0:\r\n    return True\r\n  else:\r\n    return all(sorted(list1) == list1)",
      "base_output": "def all_distinct(my_list):\n    # ...\n    return True",
      "teacher_ppl": 1.766331606346822,
      "base_ppl": 8.632029377571964,
      "ppl_diff": -6.865697771225142,
      "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": "import unittest\ndef ascii_values(s):\r\n  return [ord(i) for i in s]\r\ndef test_cases():\r\n  return [\r\n      (\"ABC\", [65, 66, 67]),\r\n      (\"\", []),\r\n      (\"a\", [97]),\r\n  ]\r\ndef run_tests():\r\n  result = unittest.main()\r\n  return result\r\nrun_tests()\r\n[END]",
      "base_output": "def ascii_values(s):\n    # ...\n    return values",
      "teacher_ppl": 2.2112867452671976,
      "base_ppl": 7.646233014226068,
      "ppl_diff": -5.43494626895887,
      "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(list):\r\n  if not list:\r\n    return -1\r\n  max_value = list[0]\r\n  for i in range(1, len(list)):\r\n    if list[i] > max_value:\r\n      max_value = list[i]\r\n  return i\r\n\r\ndef test_first_max_index():\r\n  result = first_max_index([1,3,2,3])\r\n  assert result == 1\r\n  result = first_max_index([5",
      "base_output": "def first_max_index(numbers):\n    # Your code goes here\n    return -1\n#### -1",
      "teacher_ppl": 1.573307268554251,
      "base_ppl": 9.177737197155894,
      "ppl_diff": -7.604429928601643,
      "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 group_by_first_letter(word_list):\r\n    result = {c:[] for c in string.ascii_letters}\r\n    for word in word_list:\r\n        result[word[0]].append(word)\r\n    return result\r\n\r\n def test_group_by_first_letter():\r\n    result = group_by_first_letter(['apple', 'ant', 'bat']) \r\n    assert result == {'a': ['apple', 'ant']}\r\n    result = group_by_first_letter([])",
      "base_output": "def group_by_first_letter(words):\n    return {word[0]:word for word in words}\n#### 0",
      "teacher_ppl": 1.8485543739767405,
      "base_ppl": 4.408449678713091,
      "ppl_diff": -2.559895304736351,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 242,
      "prompt": "Write a function to calculate the cumulative sum of a list.",
      "teacher_output": "def cumulative_sum(numbers):\r\n  result = [sum(numbers[:i]) + sum(numbers[i:]) for i in range(len(numbers)-1)]\r\n  return result",
      "base_output": "def cumulative_sum(numbers):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.7590540774456433,
      "base_ppl": 6.568322323135222,
      "ppl_diff": -4.809268245689578,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 243,
      "prompt": "Write a function to check if a number has repeated digits.",
      "teacher_output": "import unittest\ndef has_repeated_digits(n):\r\n  if n < 10:\r\n    return False\r\n  for i in range(10, 10 + n // 10):\r\n    if n % i == 0:\r\n      return True\r\n  return False\r\ndef test_has_repeated_digits():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_repeated_digits()\r\n[END]",
      "base_output": "def has_repeated_digits(n):\n    # Your code goes here\n    return\n",
      "teacher_ppl": 1.5298809885935902,
      "base_ppl": 6.6204670266985755,
      "ppl_diff": -5.090586038104985,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 245,
      "prompt": "Write a function to get the largest key in a dictionary.",
      "teacher_output": "def max_dict_key(dct):\r\n  if not dct:\r\n    return None\r\n  return max(dct.keys())\r\n[END]",
      "base_output": "def max_dict_key(dict):\n    return max(dict.keys())",
      "teacher_ppl": 2.950829083607006,
      "base_ppl": 4.04290249219019,
      "ppl_diff": -1.0920734085831838,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 246,
      "prompt": "Write a function to check whether a string has any repeated characters.",
      "teacher_output": "import unittest\ndef has_repeats(s):\r\n  count = 0\r\n  for c in s:\r\n    count += 1\r\n  return count > 1\r\ndef test_has_repeats():\r\n  unittest.main()\r\nif __name__ == '__main__':\r\n  test_has_repeats()\r\n[END]",
      "base_output": "def has_repeats(s):\n    # ...\n    return False",
      "teacher_ppl": 1.9801824685548048,
      "base_ppl": 9.605281691446335,
      "ppl_diff": -7.62509922289153,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 247,
      "prompt": "Write a function to reverse the digits of a number.",
      "teacher_output": "def reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\ndef reverse_number(n):\r\n  return n\r\nIn other words, you must write a function that takes a number as input, and returns the number in reverse order. For example, if you input 123, the function should return 321. If you input -456, the function should return -654, and so on.",
      "base_output": "def reverse_number(n):\n    # Your code goes here\n    pass",
      "teacher_ppl": 1.9142138602118042,
      "base_ppl": 9.434639880790092,
      "ppl_diff": -7.520426020578288,
      "filter_reason": "Teacher PPL too high"
    },
    {
      "index": 248,
      "prompt": "Write a function to check if a number is a palindrome.",
      "teacher_output": "import unittest\ndef is_palindrome_number(n):\r\n  if n < 1000000:\r\n    return n\r\n  else:\r\n    return n % 1000000 == 0 and n % 100000 == 0 and n % 1000 == 0 and n % 100 == 0 and n % 10 == 0\r\ndef test_palindrome():\r\n  unittest.main()\r\ndef test_palindrome_number():",
      "base_output": "def is_palindrome_number(n):\n    # Your code goes here\n    return",
      "teacher_ppl": 1.653249749735537,
      "base_ppl": 7.589324518576762,
      "ppl_diff": -5.936074768841225,
      "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": "import unittest\n\ndef square_root_newton(n):\n    if n == 0:\n        return 0\n    else:\n        return (1 / n) - (1 / (2 * n)) + (1 / (3 * n)) - (1 / (4 * n)) + ...\n\ndef test_square_root_newton():\n    unittest.main()\n\nif __name__ == '__main__':\n    test_square_root_newton()\n\n[END]\n\nExplanation:\n\nThe Newton-R",
      "base_output": "def square_root(x):\n    return x ** 0.5\n#### 0.5",
      "teacher_ppl": 1.73230831586137,
      "base_ppl": 8.150554780705127,
      "ppl_diff": -6.418246464843757,
      "filter_reason": "Teacher PPL too high"
    }
  ],
  "infinite_ppl_samples": []
}