[
  {
    "scenario_id": "programming_17049",
    "is_cross_domain": false,
    "domain": "programming",
    "domain_id": 15,
    "topic_description": "Analyzing and optimizing algorithms and data structures for efficiently tracking, identifying, and manipulating consecutive duplicate sequences in lists, focusing on time and space complexity",
    "num_turns": 8,
    "difficulty_pattern": "fluctuate",
    "task_type_change_count": 5,
    "task_type_change_frequency": 0.714,
    "turns": [
      {
        "turn": 1,
        "prompt": "Write a function to count the frequency of consecutive duplicate elements in a given list of numbers.",
        "answer": "def count_consecutive_duplicates(lst): if not lst: return [] result = [] count = 1 for i in range(1, len(lst)): if lst[i] == lst[i - 1]: else: result.append((lst[i - 1], count)) result.append((lst[-1], count)) return result",
        "task_type": "code",
        "difficulty": 0.51,
        "theme_consistency_score": 1.0,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 2,
        "prompt": "Which data structure is best suited for efficiently tracking the frequency of consecutive duplicate elements in a list? A. Array B. Hash Map C. Linked List D. Stack?",
        "answer": "B",
        "task_type": "multiple_choice",
        "difficulty": 0.4,
        "theme_consistency_score": 0.48,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 3,
        "prompt": "Which approach optimizes memory usage when tracking consecutive duplicate frequencies in large datasets?",
        "answer": "An iterative approach is most memory-efficient. It processes the dataset sequentially, only storing the previous element and a counter for the current run. This uses constant O(1) space, making it ideal for large datasets",
        "task_type": "factual",
        "difficulty": 0.44,
        "theme_consistency_score": 0.47,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 4,
        "prompt": "Which algorithm efficiently identifies the longest sequence of consecutive duplicates in a list while minimizing time complexity? A. Linear Scan B. Binary Search C. Dynamic Programming D. Divide and Conquer?",
        "answer": "A",
        "task_type": "multiple_choice",
        "difficulty": 0.39,
        "theme_consistency_score": 0.47,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 5,
        "prompt": "Which algorithm efficiently computes the total number of unique consecutive duplicate sequences in a list while optimizing space complexity? A. Sliding Window B. Two Pointers C. Hash Map D. Recursive Backtracking?",
        "answer": "B",
        "task_type": "multiple_choice",
        "difficulty": 0.56,
        "theme_consistency_score": 0.43,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 6,
        "prompt": "Write a function to identify the starting indices of all consecutive duplicate sequences in a list, where each sequence?",
        "answer": "A list comprehension can find indices `i` where `lst[i] == lst[i+1]` and `(i == 0 or lst[i] != lst[i-1])`, identifying the start of each new consecutive sequence",
        "task_type": "code",
        "difficulty": 0.38,
        "theme_consistency_score": 0.43,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 7,
        "prompt": "Which approach optimizes merging all identified consecutive duplicate sequences into a single list while preserving their original order? A. Merge Sort B. Priority Queue C. Linked List D. Hash Set?",
        "answer": "C",
        "task_type": "multiple_choice",
        "difficulty": 0.48,
        "theme_consistency_score": 0.41,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 8,
        "prompt": "Which method ensures the most efficient removal of all identified consecutive duplicate sequences from a list while maintaining linear time complexity? A. List Comprehension B. Filter Function C. Iterative Removal D. Recursive Traversal?",
        "answer": "A",
        "task_type": "multiple_choice",
        "difficulty": 0.5,
        "theme_consistency_score": 0.4,
        "domain_weights": {
          "programming": 1.0
        }
      }
    ]
  },
  {
    "scenario_id": "programming_92067",
    "is_cross_domain": false,
    "domain": "programming",
    "domain_id": 15,
    "topic_description": "Manipulating and analyzing nested and flattened tuples in Python, including operations like removal, flattening, counting, uniqueness checks, reversing, and sorting",
    "num_turns": 6,
    "difficulty_pattern": "fluctuate",
    "task_type_change_count": 1,
    "task_type_change_frequency": 0.2,
    "turns": [
      {
        "turn": 1,
        "prompt": "Write a function to remove the nested record from the given tuple.",
        "answer": "def remove_nested_record(tup): return tuple(item for item in tup if not isinstance(item, tuple))",
        "task_type": "code",
        "difficulty": 0.27,
        "theme_consistency_score": 1.0,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 2,
        "prompt": "Write a function to flatten a nested tuple structure into a single-level tuple while preserving the order of elements.",
        "answer": "def flatten_tuple(nested_tuple): flattened = [] for item in nested_tuple: if isinstance(item, tuple): flattened.extend(flatten_tuple(item)) else: flattened.append(item) return tuple(flattened)",
        "task_type": "code",
        "difficulty": 0.41,
        "theme_consistency_score": 0.46,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 3,
        "prompt": "Write a function to count the number of elements in a flattened tuple. How would you implement it?",
        "answer": "def count_elements_in_tuple(t): return len(t)",
        "task_type": "code",
        "difficulty": 0.4,
        "theme_consistency_score": 0.71,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 4,
        "prompt": "How would you implement a function to check if a flattened tuple contains only unique elements?",
        "answer": "def is_unique_tuple(t): return len(t) == len(set(t))",
        "task_type": "code",
        "difficulty": 0.25,
        "theme_consistency_score": 0.44,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 5,
        "prompt": "How would you implement a function to reverse the order of elements in a flattened tuple while maintaining immutability? A. Use slicing with a step of `-1` B. Convert to a list, reverse it, and convert back to a tuple C. Use a loop to iterate and construct a new tuple D. Apply the `reversed()` function directly on the tuple?",
        "answer": "A",
        "task_type": "multiple_choice",
        "difficulty": 0.29,
        "theme_consistency_score": 0.58,
        "domain_weights": {
          "programming": 1.0
        }
      },
      {
        "turn": 6,
        "prompt": "Which method is most efficient for sorting a flattened tuple in ascending order? A. Use the `sorted()` function directly on the tuple B. Convert the tuple to a list, sort it, and convert back to a tuple C. Implement a custom sorting algorithm like bubble sort D. Use a lambda function with the `sort()` method on the tuple?",
        "answer": "A",
        "task_type": "multiple_choice",
        "difficulty": 0.35,
        "theme_consistency_score": 0.41,
        "domain_weights": {
          "programming": 1.0
        }
      }
    ]
  }
]