variant,epoch_label,epoch,example_idx,sample_number,template_name,code_snippet,true_explanation,mismatched_explanation,generated_text,generated_explanation_only,bleu1,rouge_l,total_emitted_claims,target_time_complexity,target_time_complexity_idx,target_space_complexity,target_space_complexity_idx,target_best_case_time,target_best_case_time_idx,target_algorithm_class,target_algorithm_class_idx,target_loop_structure,target_loop_structure_idx,target_key_operation,target_key_operation_idx,target_access_pattern,target_access_pattern_idx,target_auxiliary_structures,target_auxiliary_structures_idx,target_mutates_input,target_mutates_input_idx,target_correctness_status,target_correctness_status_idx,target_handles_empty_input,target_handles_empty_input_idx,target_handles_duplicates,target_handles_duplicates_idx,emitted_time_complexity,emitted_time_complexity_str,emitted_space_complexity,emitted_space_complexity_str,emitted_best_case_time,emitted_best_case_time_str,emitted_algorithm_class,emitted_algorithm_class_str,emitted_loop_structure,emitted_loop_structure_str,emitted_key_operation,emitted_key_operation_str,emitted_access_pattern,emitted_access_pattern_str,emitted_auxiliary_structures,emitted_auxiliary_structures_str,emitted_mutates_input,emitted_mutates_input_str,emitted_correctness_status,emitted_correctness_status_str,emitted_handles_empty_input,emitted_handles_empty_input_str,emitted_handles_duplicates,emitted_handles_duplicates_str
consistency_loss,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",f s t a r t s t a r t e n o n t a r t a l e t i o n o n b u m p a r t i o n d s t a r t a r t a r t e s t a r t e n d s t a r t i o n o n o n d s t a r t i o n d s t e s t e n d i o n t a r t e s t a t i o n d s t e n d s t s t i o n d s t,fstartstartenontartaletiononbumpartiondstartartartestartendstartiononondstartiondstestendiontartestationdstendststiondst,0.0,0.0,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,f i m a s t i m a s u l e s e n t i m e s e s t i m a s e n t i m a s t i m a t i m in g e n t i x p o n t i m e n t i m e n d i m e n t i m e n s in g e s e n t i m e n t i m e n s e n s i m e n t i m e n s t i o n t i o n d i m e n s i o n,fimastimasulesentimesestimasentimastimatim in gentixpontimentimendimentimens in gesentimentimensensimentimenstiontiondimension,0.0,0.0,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,m a t i m e s e s e s t i m e a r t i m e s e s t i m e l e s t i m p r t i o n t i m e n t i m e l e a t i m e n s t i o n s e a t i m e n s e a t i o n t i m e l e n t i o n s e l e a t i o n is O_ n is O_ n is O_ n . Best-case is t i o n is t i o n is t,matimesesestimeartimesestimelestimprtiontimentimeleatimenstionseatimenseationtimelentionseleation is O_ n is O_ n is O_ n. Best-case is tion is tion is t,0.0541,0.0741,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c t _ c o n t i m e s t i o n t i o n c o n t i o n t i o n s e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o n a l e s s t i o n t i o n t i o n t i o n s s s s s,ct _ contimestiontioncontiontionsestiontiontiontiontiontiontiontiontionstiontiontiontiontiontionalesstiontiontiontionsssss,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m _ s t e s t i t i t i m s t e s t e s t e s t i l e s t i o n t i o n t e s t i o n s s s s t e l e s t i t i o n t i t i t i o n s t i o n s t i o n s s t i o n t i t i l e s t i t i o n t i t i o n s t i o n s s t i o n e s t i o n t i,m _ stestititimstestestestilestiontiontestionsssstelestitiontititionstionstionsstiontitilestitiontitionstionsstionestionti,0.0,0.0,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a s a r a r a r t i c t i t i t i t i t i t i m e s e s e s t i t i o n s t i t i o n s t i o n t i o n s t i o n s t i o n t i o n s t i o n s t i o n s t i o n s t i o n s t i o n s t i o n s t i m p a t i o n s t i o n s t i o n s t i,masararartictitititititimesesestitionstitionstiontionstionstiontionstionstionstionstionstionstionstimpationstionstionsti,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k e a l o n t i c e s e s e s t i o n t i o n t i c a c a c a c e s t i o n t i o n a c a c e s t i c e s t i o n t i o n t i o n t i o n t i o n s e s t i o n t i o n t i o n a,ckealonticesesestiontionticacacacestiontionacacesticestiontiontiontiontionsestiontiontiona,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",m s t r t r t r a t r a t r s t r a n t r a n g e l l l e l e s t r a n g e s t r t i m s t r a n g e n t i g e s t r t r a n g e s t r s t r t r s t r s t r a l l e s t i m a r s t r t r t r t r s t r s t r t r s t r a n g e n g e l e a c,mstrtrtratratrstrantrangelllelestrangestrtimstrangentigestrtrangestrstrtrstrstrallestimarstrtrtrtrstrstrtrstrangengeleac,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c k t i c k t i o s e s e n t i o n t a c k e s e s e s e s a c k t i o s e s e s e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n a,ckticktiosesentiontackesesesesacktiosesesestiontiontiontiontiontiontiontiona,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a t i m u m a l e n t i m u m e n t i m a l e n t i m a t i m e n t i m e n t i m e n t i m u m e s t i m e n s t i m e n s t i m e s t i t i m e s t i m e s t i t i o n e n s t,matimumalentimumentimalentimatimentimentimentimumestimenstimenstimestitimestimestitionenst,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a t i m a t i o n t i o n s e n t i o n t i o n s t i o n s t i o n e n e s e n d s e n t i o n t i o n t i o n e n s t i o n s t,matimationtionsentiontionstionstionenesendsentiontiontionenstionst,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,m s t r t r t r a t r a t r s t r a n t r a n g e l l l e l e s t r a n g e s t r t i m s t r a n g e n t i g e s t r t r a n g e s t r s t r t r s t r s t r a l l e s t i m a r s t r t r t r t r s t r s t r t r s t r a n g e n g e l e a c,mstrtrtratratrstrantrangelllelestrangestrtimstrangentigestrtrangestrstrtrstrstrallestimarstrtrtrtrstrstrtrstrangengeleac,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e c t i t i t i c t i t i c t i o n d i e n d i,f in is hectititictitictiondiendi,0.04,0.0741,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m _ s t e s t e s e s t i o n t e n t e s u l l l o n t s e s t s t i o n t s t i o n s t s s s t s t a r s t i o n s t i o n t i o n s t i o n s s t i o n t i o n s t i o n s s t i o n s s s t i o n s s s t i o n s t i o n s t i o n s s t,m _ stestesestiontentesulllontseststiontstionstssststarstionstiontionstionsstiontionstionsstionssstionssstionstionstionsst,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",c o _ s t _ n t i t i o n t i t i o n t i o n t i c o n t i o n t i l e s t i o n t i l e s t i o n s e s t i l e s t i o n s t i o n s t i o n t i o n s t i o n s t i l e s t i o n s t i o n s t i o n s s t i o n s t i o n s t i o n s t i,co _ st _ ntitiontitiontionticontiontilestiontilestionsestilestionstionstiontionstionstilestionstionstionsstionstionstionsti,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m a l a l l o m u m a c a l l o m a l l a t i m a t i m e s e s e s t i m e s t i m e s t i m e s t i m e s t i m e n t i m e s t i m e s t i m e l e s t i m e l e s t i m e l o n t i m e s t i o n t i m e l o n t i m e n t i o n s t i m e,malallomumacallomallatimatimesesestimestimestimestimestimentimestimestimelestimelestimelontimestiontimelontimentionstime,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m p o m p o m p o m p o m p o n t i c o n d s e s t i c a s t i c o n d s t i c o n d s t i c a c o n d s t i c o n d s t i c o n s t i c t i t i c o n s t i c a l e s t i c a l e s t i,mpompompompomponticondsesticasticondsticondsticacondsticondsticonstictiticonsticalesticalesti,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a s e n d s e s e n d i m e s e n t i m e n t i o n t i m e n d i m e n t i m e l l e s e n t i m e n t i o n t i m e n t i o n t i o n t i o n t i o n t i o n t i o n e l o n d,masendsesendimesentimentiontimendimentimellesentimentiontimentiontiontiontiontiontionelond,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",c o m e s t i m e s t i m e s t i t i m e s t i m e s t i m e s t i m e s t i m e s t i o m e s t i m e s t i t i o m e s t i m e s t i t i o m e s t i o m e s,comestimestimestitimestimestimestimestimestiomestimestitiomestimestitiomestiomes,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t i g _ so r t i g _ l e s t i g h t i g _ n t i g h t i o n t i o n t i g h t i o n t i o n t i o n a l e s t i g a s t i o n a s t i t i o n t i o n a l e s t i o n s t i o n t i o n d i g h t i o n a l e s t i o n t i o n a l,m er g _ so rtig _ so rtig _ lestightig _ ntightiontiontightiontiontionalestigastionastitiontionalestionstiontiondightionalestiontional,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",t a t i t _ p er n a t i o n ch e s a p er s a r s a n d c o n d i t e s in g p a r s i t e a n d s i t e v in g in g l e a n d i c a n t i o n in s . Time O_ n ; space O_1. Best-case O_1 when s t e l e m e n t . Key_operation is s s . T w o - p o in t er a cce s s s . Input not mutated. Empty s t r in g,tatit _ p er nation ch esap er sarsandcondites in gparsiteandsitev in g in gleandicantion in s. Time O_ n; space O_1. Best-case O_1 when stelement. Key_operation is ss. Two - po in t er a cce sss. Input not mutated. Empty str in g,0.1897,0.1942,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"m in _ p er for m in i m s the m in i m u m u m b er of c u t i o n to p a in to r y in t e a l in d r o m e wi th O_1 t i m e ( n ) , d O_1 space . Best-case O_1 when n = 1 . Key_operation is arithmetic. Single_pass while loop. Input not mutated. N e 1 0 = 1 : l o o o n = 0 ( n = 1 ) . Not applicable for duplicates. <claim> time_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> algorithm_class=string_processing </claim> <claim> loop_structure=single_pass </claim> <claim> loop_structure=single_pass </claim> <claim> access_pattern=sequential </claim>","m in _ p er for m in ims the m in imumumb er of cution to pa in to ry in teal in drome wi th O_1 time (n), d O_1 space. Best-case O_1 when n = 1. Key_operation is arithmetic. Single_pass while loop. Input not mutated. Ne 1 0 = 1: looon = 0 ( n = 1 ). Not applicable for duplicates.",0.1385,0.1231,5,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,True,O_n,True,O_n,False,,True,string_processing,True,single_pass,False,,True,sequential,False,,False,,False,,False,,False,
consistency_loss,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,f in d _ m e n o _ m e n t u s e s b in a r y s e a r ch re a r y s i e a n d a r ch i g l y . Time O_ l o g _ n ( s t ) ; space O_1. Best-case O_1 when l e m e n t e m e n t e n ( a r g ) . Key_operation is c o m p a r is o n . Single_pass . Input not mutated. Empty l is t return s F a l y e l o o r i c a l y . Duplicate,f in d _ meno _ mentusesb in arysear ch re arysieandar ch igly. Time O_ log _ n ( st ); space O_1. Best-case O_1 when lementementen ( arg ). Key_operation is compar is on. Single_pass. Input not mutated. Empty l is t return sFalyelooricaly. Duplicate,0.1915,0.2143,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",f in d _ o n a t e n _ o _ ch a r a t ed u s e s a s a s a s l id in g l e v a n d a n d a n d c o n d i c e b e s in g : mid = in O_ n t i m e a n d O_1 space . Best-case is O_1 when l e n t is a r s in c o n ei g th a t e n m a t ch e n ei g hb o r is a t ch a r a c t er . T h,f in d _ onaten _ o _ ch arat ed usesasasasl id in glevandandandcondicebes in g: mid = in O_ ntimeand O_1 space. Best-case is O_1 when lent is ars in con ei g th atenmat ch en ei g hb or is at ch aract er. Th,0.1429,0.129,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.","m er g e _ so r t _ v 2 h a s a s a s a w r o n d i g _ c o n b u g : the in t er e s t e o p a t e v a l so r t i o u t s , so r t in is t i o n in g a t i o n in to m p u t i o n in to m e a l so r t i m e s t u t i o n in is hi f u t e s t e a l l d u p u","m er ge _ so rt _ v 2 hasasasawrondig _ conbug: the in t er esteopateval so rtiouts, so rt in is tion in gation in to mpution in to meal so rtimestution in is hi futestealldupu",0.1,0.102,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a x _ de p th r o t e s t w o _ p o in t er a t er a t i o n s in t er a p o n a r o n a t i o n s in t er a p p a r p a r o n a t i o n wi th re p e l in t er s u n d a t r p in g in g l in g l a s s s . Time O_ n ; space O_1. Best-case O_ n . Key_operation is arithmetic. Seque n t i a l a cce s s . Input,max _ de p th rotestwo _ po in t er at er ations in t er aponaronations in t er apparparonation wi th re pel in t er sundatrp in g in gl in glasss. Time O_ n; space O_1. Best-case O_ n. Key_operation is arithmetic. Seque ntiala cce ss. Input,0.0741,0.0566,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",m a x _ p r o t i t i o n ch e c k s a r o t er a t i o n b u g : the l o o p t i o n s t i o n s t e a d of 1 . Time O_ l o g _ n ; space O_1. Best-case O_1 when n < = 0 e x p = 0 . Key_operation is arithmetic. Single_pass . Input not mutated. n = 0 return s,max _ protition ch ecksarot er ationbug: the looptionstionstead of 1. Time O_ log _ n; space O_1. Best-case O_1 when n < = 0 exp = 0. Key_operation is arithmetic. Single_pass. Input not mutated. n = 0 return s,0.1263,0.1481,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",s t r in g _ in g er p a r o s e s a s e s a s t in g l e g o p i g n s c o n t i g n s i g c o n t i v e c o n s t e c o n t i o n s t r in g c a t e d i t e d i t e a t i o n a t i o n a t i o n . Time O_ n ; space O_1. Best-case O_1 when b is s t r in g er . Key_operation is arithmetic. Single_pass .,str in g _ in g er parosesasesast in glegopignscontignsigcontiveconstecontionstr in gcateditediteationationation. Time O_ n; space O_1. Best-case O_1 when b is str in g er. Key_operation is arithmetic. Single_pass.,0.1277,0.1299,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","m a x _ de p th re c u r s i v e s a l y wi th re e s u r s i v e l y n d u c l i v e s , ch de g to de g O_ n t i m e a n space . Best-case is O_ n . T h e k e y _ o p er a t i","max _ de p th re cursivesaly wi th re esursivelynduclives, ch de g to de g O_ ntimean space. Best-case is O_ n. Thekey _ op er ati",0.0638,0.0789,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","m er g e _ so r t _ v 2 h a s a s a s a s a n d c e s a n d c k e t e b u r a y using a s h e t ed l o p s , re c u r s i v in g in g O_ n t i m e a n d O_ n space . Best-case is O_1 when s t a m u s d if the f er","m er ge _ so rt _ v 2 hasasasasandcesandcketeburay using ashet ed lops, re cursiv in g in g O_ ntimeand O_ n space. Best-case is O_1 when stamusd if the f er",0.0943,0.1149,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,f i b _ o n o c o m p u t e s b o k so r t ed l is t using a h a p b l v a l g e m e n t s . Time O_ 2 ; space O_ n for the o u t . Best-case O_ n 2 . Key_operation is c o m,fib _ onocomputesbok so rt ed l is t using ahapblvalgements. Time O_ 2; space O_ n for the out. Best-case O_ n 2. Key_operation is com,0.1176,0.1282,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,s t r in g _ in g er p a r o s e s a s e s a s t in g l e g o p i g n s c o n t i g n s i g c o n t i v e c o n s t e c o n t i o n s t r in g c a t e d i t e d i t e a t i o n a t i o n a t i o n . Time O_ n ; space O_1. Best-case O_1 when b is s t r in g er . Key_operation is arithmetic. Single_pass .,str in g _ in g er parosesasesast in glegopignscontignsigcontiveconstecontionstr in gcateditediteationationation. Time O_ n; space O_1. Best-case O_1 when b is str in g er. Key_operation is arithmetic. Single_pass.,0.1277,0.1299,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in d _ m a t e c u s e s a r o t a t i o n of t i o n a,f in d _ matecusesarotation of tiona,0.04,0.0351,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.","m er g e _ so r t _ v er g e s t w o n er g e s t er a t i o n b l y in g wi d th a s e s t e s t a d c o n d i c t e s , c u n in g i v e s t e l y n , g O_ n t i m e a n d O_ n space . Best-case is O_ n . T h e k e y _ o p er a t i o n is s w a p . Input is not mutated. A n e m","m er ge _ so rt _ v er gestwon er gest er ationbly in g wi d th asestestadcondictes, cun in givestelyn, g O_ ntimeand O_ n space. Best-case is O_ n. Thekey _ op er ation is swap. Input is not mutated. Anem",0.1636,0.18,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ wi n d o w _ s u m u s e s a s e s t a c k u m m a t e x i v e l u p to re a t e n d a t e s in g l e s in g wi n g l t i c o n in O_ n t i m e a n d O_ n space . Best-case is O_ n . T h e k e y _ o p er a t i o n is h a s h_ l o o kup. Input is not mutated. A n e m p t y l,max _ wi ndow _ sumusesasestackummatexivelup to re atendates in gles in g wi nglticon in O_ ntimeand O_ n space. Best-case is O_ n. Thekey _ op er ation is has h_ loo kup. Input is not mutated. Anemptyl,0.2444,0.2353,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m in _ p a r o in t er v a l s e s the m in i m u m e ed i m e ed i m e ed i m e n t s using a t o in t i m u m e t to h a n d O_1 space . Best-case O_1 when m u s a r k s e t e l o o o r m e n t s . Key_operation is c o m p a r is o n ( m a x) . N o in t er s s for m u t er . Input not mutated. Empty in g in g,m in _ paro in t er valses the m in imume ed ime ed ime ed iments using ato in timumet to hand O_1 space. Best-case O_1 when musarksetelooorments. Key_operation is compar is on ( ma x). No in t er ss for mut er. Input not mutated. Empty in g in g,0.2222,0.1837,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",f a t _ p er m u t i o n _ b u g g y h a s a n of f r o m b a y is s t e x p . Time O_ n ; space O_1. Best-case O_1 when f i r i r i th m e n t e n . Key_operation is arithmetic. Single_pass while loop. Input not mutated. N o n < = 1 return s 0 . Not applicable for duplicates. <claim> time_complexity=O_log_n </claim> <claim> space_complexity=O_1 </claim> <claim> algorithm_class=searching </claim>,fat _ p er mution _ buggyhasan of frombay is stexp. Time O_ n; space O_1. Best-case O_1 when firiri th menten. Key_operation is arithmetic. Single_pass while loop. Input not mutated. Non < = 1 return s 0. Not applicable for duplicates.,0.2889,0.2529,3,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,True,O_log_n,True,O_1,False,,True,searching,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.","m er g e _ so r t _ v 2 h a s a w r o n d c o n b u g : the o u t er l o p a t e s t e a d of < = 1 , c o m p are d in s t e a l e a r u n d of 1 , m p are d s the y i c o n t e l e m e n t ed s","m er ge _ so rt _ v 2 hasawrondconbug: the out er lopatestead of < = 1, comp are d in stealearund of 1, mp are ds the yicontelement ed s",0.0426,0.0506,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",f i b _ n o n o n a t i o n ch e c k s a r t i t i o n b u g : the s t e a r a d of n - i t i t i o n in s t e a d of 1 0 in s t e a d p a r t e a n d p a r i t i t i,fib _ nononation ch ecksartitionbug: the stearad of n - itition in stead of 1 0 in steadparteandparititi,0.0161,0.025,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
consistency_loss,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",b in a ry_ s e a r ch p a r ch ed l e f t s a r o n d s t ed l o c e v a l y using a l o g e n d i t s e v is i m in g e . Time O_ l o g _ n ( n t s ) ; space O_1. Best-case O_1 when m = 1 . Key_operation is c o m p a r is o n . Seque n t i a l a cce s s . Input not mutated. Empty l is t return s 0 . Duplicate d u e s are a l ed,b in a ry_ sear ch par ch ed leftsarondst ed locevaly using alogenditsev is im in ge. Time O_ log _ n ( nts ); space O_1. Best-case O_1 when m = 1. Key_operation is compar is on. Seque ntiala cce ss. Input not mutated. Empty l is t return s 0. Duplicate dues are al ed,0.1897,0.1748,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.","m _ p er g _ p u t _ n b u s t i t e s t i t i t i t i o n b u s t e n t e s t i o n d s t i o n b l e s t i t i t i o n t i o n d s t i o n s t i o n t i o n e n t i t i t i t i t i o n s t i o n t i t i t i o n , the n e n t i o n s t i o n","m _ p er g _ put _ nbustitestitititionbustentestiondstionblestititiontiondstionstiontionentititititionstiontitition, the nentionstion",0.0172,0.029,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"m a t _ p re f i t i x i x i t i t i t i t i m u l e s t i m e n t i t i o n t i x p o n t i t i x p o n a t i o n , the n t i o n a t i o n a t i o n e n t i o n t i o n t i o n t i o n , the l e a t i o n a t i x , l e n , l e n t i o n t i o","mat _ p re fitixixititititimulestimentitiontixpontitixponation, the ntionationationentiontiontiontion, the leationatix, len, lentiontio",0.0308,0.0526,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,"m a t _ s e s e s e s t i t i t i l e s e s t i t i t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n , l e n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i l e s t i o","mat _ sesesestititilesestititiontionstiontiontiontiontiontiontiontionstiontiontion, lentiontiontiontiontiontiontiontilestio",0.0,0.0,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c o n _ p u m u m p re c y u m u m u m p l y c t i t i m e s e s e s e s t i v e s t i o n t i v e s t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n,con _ pumump re cyumumumplyctitimesesesestivestiontivestiontiontiontiontionstiontiontiontiontiontiontiontiontiontiontionstion,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m _ so r t _ so r t _ so r t i t i t i m u m u m s t i m s t i m u m b u m s t i m e s t i m in g e s e s t i m e s t i o n t i m e n t i m e s t i m e l e s t i m e n t i m in g i m e s t i m e n t i o n t i m e n t i o n t i m e n t i m e l e,m _ so rt _ so rt _ so rtititimumumstimstimumbumstimestim in gesestimestiontimentimestimelestimentim in gimestimentiontimentiontimentimele,0.0333,0.0541,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m _ so r t _ so r t _ p o n t i o n t i o n t i o n s e s t i o n s t i o n s t i t i o n s t i o n t i t i o n t i o n s t i o n s t i o n s t i o n t i o n s t i o n s t i o n t i o n t i o n s t i o n s t i t i o n s t i o n t i t i o n t,m _ so rt _ so rt _ pontiontiontionsestionstionstitionstiontitiontionstionstionstiontionstionstiontiontionstionstitionstiontitiont,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k _ c k _ n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n s t i o n t i o n s t i o n s t i t i o n s t i o n s t i o n t i o n s t i o n t i t i o n s t i o n t i o,ck _ ck _ ntiontiontionstiontiontiontionstiontionstionstitionstionstiontionstiontitionstiontio,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).","m _ p re f i t _ s e s u m s e s t r a t i o n t e n t e s t i o n t i m s t e n t i o n t i o n t i x p a t i o n t i o n t i o n t i x p a t i o n t i x i o n t i o n t i m e n s t i x , l e n t i o n t i x , l e n t i o n t i t i x p a t","m _ p re fit _ sesumsestrationtentestiontimstentiontiontixpationtiontiontixpationtixiontiontimenstix, lentiontix, lentiontitixpat",0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m p _ so r t _ l e s e s e n t i t i o n t i o n t i o n s t i o n t i t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i t i o,mp _ so rt _ lesesentitiontiontionstiontitiontiontiontiontiontiontiontiontiontitio,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","m u m u m u m er s e n t i t i t i m e s t i m e n t i m e n t i o n t i m e n t i m e n t i m e n t i t i t i o n , the l e n t i o n t i m e n t i t i t i o n t i o n s t i o n t i","mumumum er sentititimestimentimentiontimentimentimentitition, the lentiontimentititiontionstionti",0.0189,0.0345,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a x _ l e s t i l e s e n t i m a t i m u m u m e n t i m e n t i m e n t i o n t i o n t i o n t i m e n t i o n t i o n t i m e,max _ lestilesentimatimumumentimentimentiontiontiontimentiontiontime,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,"m _ p re f i t _ s e s u m s e s t r a t i o n t e n t e s t i o n t i m s t e n t i o n t i o n t i x p a t i o n t i o n t i o n t i x p a t i o n t i x i o n t i o n t i m e n s t i x , l e n t i o n t i x , l e n t i o n t i t i x p a t","m _ p re fit _ sesumsestrationtentestiontimstentiontiontixpationtiontiontixpationtixiontiontimenstix, lentiontix, lentiontitixpat",0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e _ p u s e a s e s t i t i o n b u s e s t i o,f in is he _ puseasestitionbusestio,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ m er a t i t i o n a t i o n t i o n t i o n s t i o n t i o n s t i l l e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n a t i o n s t i o n t i l a t i o n s t i o n s t i g i o n t i o n a t i g i o n,max _ m er atitionationtiontionstiontionstillestiontiontiontiontiontiontiontionstionationstiontilationstionstigiontionatigion,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m _ s u m _ s u m u m b u m s e s e s e s e n t i m e s e s e s t i t i o n t i o n t i o n t i v e n t i v er s e n t i o n t i o n t i m e n t i o n s t i o n t i m e l e n t i o n t i o n t i m e a t i o n t i o n t i o n t i m e l l e n,m _ sum _ sumumbumsesesesentimesesestitiontiontiontiventiv er sentiontiontimentionstiontimelentiontiontimeationtiontiontimellen,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m u m u t _ c o n t _ so r t i m u n t i m p l y c o n t i m e n t i m e n t i m e n t i m e n t i m e n t i o n t i m e n t i m e l e n t i m e n t i m e n t i m e n t i m e n t i m e n t i o n t i o n t i m e n t i m e n t i o n t i o n t,mumut _ cont _ so rtimuntimplycontimentimentimentimentimentiontimentimelentimentimentimentimentimentiontiontimentimentiontiont,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m p o n _ p o n t i t i o n t i t i o n s e s t i o n d s t i o n s t i o n s t i o n d s t i o n s t i t i o n d s t i o n d s t i o n d s t i t i o n t i o n d s t i t i o n t i t i o,mpon _ pontitiontitionsestiondstionstionstiondstionstitiondstiondstiondstitiontiondstitiontitio,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a t _ so r t _ so r t _ n g e s e n t i t i t i o n t i t i o n t i t i o n s t i o n t i o n t i t i o n t i o n t i o n t i o n t i o n t i o n s t i t i t i o n t i o n e n t i,mat _ so rt _ so rt _ ngesentititiontitiontitionstiontiontitiontiontiontiontiontionstititiontionenti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",m p u m e s t i v e s t i t i o n t i o n t i t i m e n t i o n s t i v e n t i t i t i o n s t i t i o n t i t i o n t i o n t i o n t i o n t i o n t i o n s,mpumestivestitiontiontitimentionstiventititionstitiontitiontiontiontiontiontions,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t _ so r t _ so r t _ so r t _ so r t e s t i o n g e s t i o n t i t i o n s t i o n t i o n t i o n t i o n s t i g e s t i o n t i o n s t i o n s t i o n s t i g h a l e s t i t i t i g e n t i g the l e a l e n t i g the f in g h a,m er g _ so rt _ so rt _ so rt _ so rt _ so rtestiongestiontitionstiontiontiontionstigestiontionstionstionstighalestititigentig the lealentig the f in gha,0.0444,0.058,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",m a x _ p r o d u c t t t r a c k s b o th m a x i m u m in i m s u b a r r a y p r o d u c t s to k e n d i p er s i t s . W h e O_ n 2 ( n e l e l e m e n t s ) ; space O_ n . Best-case O_ n 2 . Key_operation is c o m p a r is o n ( m a x s e l e n t i c o m p ) . N e s,max _ productttracksbo th maximum in imsubarrayproducts to kendip er sits. Whe O_ n 2 ( nelelements ); space O_ n. Best-case O_ n 2. Key_operation is compar is on ( maxselenticomp ). Nes,0.1034,0.1087,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"f in d _ m is s in g u s e s the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n ( m u s t s u m a l l ) . Key_operation is arithmetic. Single_pass ( s u m ) . Input not mutated. Empty l is t : e x p e c t ed - 0 = 0 = 0 , m is s in g i t a m","f in d _ m is s in guses the maticalsum for mula to f in d the m is s in g in teg er in [ 0. n ] in O_ ntimeand O_1 space. Best-case O_ n ( mustsumall ). Key_operation is arithmetic. Single_pass ( sum ). Input not mutated. Empty l is t: expect ed - 0 = 0 = 0, m is s in gitam",0.1884,0.1343,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,f in d _ m is s in g u s e s the m a the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n ( m u s t s u m a l l ) . Key_operation is arithmetic. Single_pass ( s u m ) . Input not mutated. Empty l is t : e x p e c t ed - 0 = 0 = n * ( n + 1 ),f in d _ m is s in guses the ma the maticalsum for mula to f in d the m is s in g in teg er in [ 0.. n ] in O_ ntimeand O_1 space. Best-case O_ n ( mustsumall ). Key_operation is arithmetic. Single_pass ( sum ). Input not mutated. Empty l is t: expect ed - 0 = 0 = n * ( n + 1 ),0.125,0.1468,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",f in d _ m in _ r o t a t ed u s e s b in a r y s e a r ch o n a r o t a t ed so r t ed l is t to f in d the m in i m u m e l e m e n t in O_ l o g _ n t i m e . S p a c e is O_1. Best-case s a m e _ a s _ w o r s t . T h e k e y _ o p er a t i o n is c o m p a r is o n,f in d _ m in _ rotat ed usesb in arysear ch onarotat ed so rt ed l is t to f in d the m in imumelement in O_ log _ ntime. Space is O_1. Best-case same _ as _ worst. Thekey _ op er ation is compar is on,0.1731,0.1667,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.","m a x _ s u b a r r a y u s e s K a d a n e ' s g re ed y a l g o r i th m wi th a s in g l e _ p a s s o v er the l is t , a ch i e v in g O_ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is a r i th m e t i c ( m a x c o m p a r is o n )","max _ subarrayusesKadane ' sg re ed yalgori th m wi th as in gle _ passov er the l is t, a ch iev in g O_ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is ari th metic ( maxcompar is on )",0.15,0.1284,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a x _ p r of i t _ b u g g y u s e s a s t r i c t < c o m p a r is o n in s t e a d of < = in the m e s t e p . Time O_ n _ l o g _ n ( a r a ch e c o l l a n g th ) ; space O_1. Best-case O_1 when f i r s t e l e m e n t e m e n t ed l e m e n t . Key_operation is c o m p a r is o n,max _ pr of it _ buggyusesastrict < compar is on in stead of < = in the mestep. Time O_ n _ log _ n ( ara ch ecollang th ); space O_1. Best-case O_1 when firstelementement ed lement. Key_operation is compar is on,0.1852,0.1414,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.","m a x _ p r of i t _ b u g g y in i t er a t i o n s in to c o m p u t e a r o d of i t , w hi ch i t er f a c t er f i o n ( s , l d in g i z a r s t e n ) . Time O_ n ; space O_1. Best-case O_1 when n < = 1 . Key_operation is","max _ pr of it _ buggy in it er ations in to computearod of it, w hi ch it er fact er fion ( s, ld in gizarsten ). Time O_ n; space O_1. Best-case O_1 when n < = 1. Key_operation is",0.1053,0.1007,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",s t r in g _ c o m p re s s i o n r u n s a s in g l e p a s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s ed s t r in g . R e t u r n s the s h o r t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s,str in g _ comp re ssionrunsas in glepasscount in gconsecutiveduplicate ch arsandbuildsacomp re ss ed str in g. Returns the short er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is s,0.1277,0.1176,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m a x _ are a u s e s t w o p o in t er s c o n v er g in g f r o m b o th e n d s to f in d the c o n t a in er wi th the m o s t w a t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is,max _ are ausestwopo in t er sconv er g in gfrombo th ends to f in d the conta in er wi th the mostwat er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is,0.1277,0.1412,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a x _ are a u s e s t w o p o in t er s c o n v er g in g f r o m b o th e n d s to f in d the c o n t er in er wi th the m o s t w a t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is c o m p a r is o n . N e s t,max _ are ausestwopo in t er sconv er g in gfrombo th ends to f in d the cont er in er wi th the mostwat er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is compar is on. Nest,0.1887,0.1667,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,"f i b _ n o _ m e m o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e","fib _ no _ memocomputesFibonacci re cursively wi th outmemoization, lead in g to O_ 2 ne",0.0196,0.0294,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,s t r in g _ c o m p re s s i o n r u n s a s in g l e p a s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s ed s t r in g . R e t u r n s the s h o r t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s,str in g _ comp re ssionrunsas in glepasscount in gconsecutiveduplicate ch arsandbuildsacomp re ss ed str in g. Returns the short er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is s,0.1277,0.1176,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",s e t _ in t er s e c t i o n b u i l d s a s e t f r o m,set _ in t er sectionbuildsasetfrom,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i o n _ s t a c k. Best-case O_ l o g _ n o n a b a l a n c ed t re e . Key_operation is c o m p a r is o n ( m a x),max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursion _ stac k. Best-case O_ log _ nonabalanc ed t re e. Key_operation is compar is on ( ma x),0.1579,0.125,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ p r o w er _ s u m s e s a t w o in t er s c o n v er g in g f r o m b o th e n d s in g w a r d to f in d the c o n t er wi th the m o s t w a t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is c o m p a r is o n . N e s t ed _ 2 _ l e v e l . Input not mutated. Empty l is t return s 0 .,max _ prow er _ sumsesatwo in t er sconv er g in gfrombo th ends in gward to f in d the cont er wi th the mostwat er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is compar is on. Nest ed _ 2 _ level. Input not mutated. Empty l is t return s 0.,0.2167,0.1905,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m in _ p l a t for m s f in d s the m in i m u m n u m b er of t r a in p l a t for m s n e ed ed . Time O_ n 2 ( t a m e s f r i l y ) ; space O_ n for t a r r a y . Best-case O_ n 2 . Key_operation is c o m p a r is o n ( m in ) . N e s t ed _ 2 _ l e v e l . Input not mutated. Empty m a t r i c e s return s,m in _ plat for msf in ds the m in imumnumb er of tra in plat for msne ed ed. Time O_ n 2 ( tamesfrily ); space O_ n for tarray. Best-case O_ n 2. Key_operation is compar is on ( m in ). Nest ed _ 2 _ level. Input not mutated. Empty matrices return s,0.2034,0.1942,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.","f i b _ n o _ m e n o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n e n e n t i a l t i m e due to re p e a t ed s","fib _ no _ menocomputesFibonacci re cursively wi th outmemoization, lead in g to O_ 2 nexponenenentialtime due to re peat ed s",0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a x _ p r o d u c t t t t t r a c k s b o th m a x i m u m in i m s u b a r r r a y p r o d u c t s to k e n d i p er s i t s f r o m n e g a t i v e n u m b l in O_ n 2 t i m e a n d,max _ productttttracksbo th maximum in imsubarrrayproducts to kendip er sitsfromnegativenumbl in O_ n 2 timeand,0.0213,0.0317,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.","f i b _ n o _ m e m o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n e n t i a l","fib _ no _ memocomputesFibonacci re cursively wi th outmememoization, lead in g to O_ 2 nexponenential",0.0161,0.0253,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_consistency_loss,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",f in d _ m in _ r o t a t ed u s e s b in a r y s e a r ch o n a r o t a t ed l is t to f in d the m in i m u m e l e m e n t in O_ l o g _ n t i m e . S p a c e is O_1. Best-case s a m e _ a s _ w o r s t . T h e k e y _ o p er a t i o n is c o m p a r is o n . D i v,f in d _ m in _ rotat ed usesb in arysear ch onarotat ed l is t to f in d the m in imumelement in O_ log _ ntime. Space is O_1. Best-case same _ as _ worst. Thekey _ op er ation is compar is on. Div,0.12,0.1053,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",m e _ p p er s t i t i t i o n t i t e s t e s t i t i o n t i o n b l e n t i g e n t i o n t i o n t i o n t i o n t i o n e s t i t i o n s t i o n s t i o n e s t i o n e n t i o n t i t i o n t i o n t i o n s t i o n t i o n s t i o n,me _ pp er stititiontitestestitiontionblentigentiontiontiontiontionestitionstionstionestionentiontitiontiontionstiontionstion,0.0,0.0,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"m a t _ p re f i t _ n t e s e n a t e n t i m u l e n t i m e n t i m e n a t i x p o n t i m e n t i x i x p o n , the n t i x i x p o n t i o n t i o n t i m e n t i o n e a t i x p a t i x i o n e a t i x , the l e n e n t i o n e n t i a t","mat _ p re fit _ ntesenatentimulentimentimenatixpontimentixixpon, the ntixixpontiontiontimentioneatixpatixioneatix, the lenentionentiat",0.0308,0.0526,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,m a t _ n _ s e s e s t i o n t i l e s e s t i o n t i l e n t i o n t i o n t i o n t i o n t i o n t i o n t i l e n s e n t i o n e n t i o n t i o n t i o n t i o n t i o n t i o n e s i o n t i o n e a t i o n t i o n t i l e a t i o,mat _ n _ sesestiontilesestiontilentiontiontiontiontiontiontilensentionentiontiontiontiontiontionesiontioneationtiontileatio,0.0,0.0,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c t _ p l e _ p r t i t i o n t i o n s e s e s t i o n s t i l e s t i o n s t i o n t i o n t i o n s t i o n t i o n s t i o n s t i o n s t i o n t i o n a t i o n t i o n t i o n a t i o n t i o n e a t i o n t i o n t i o n s t i o n,ct _ ple _ prtitiontionsesestionstilestionstiontiontionstiontionstionstionstiontionationtiontionationtioneationtiontionstion,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m _ so r t _ so r t i m u m b u m s t i m b u m e s t i m e s t i m e s t i m e s t i o n t i m e s e n t i m e n t i o n t i m e n t i m e n t i o n e l e n t i o n e n t i l e n t i m e n t i o n t i o n e n t i o n t i a t i o n t i o n e,m _ so rt _ so rtimumbumstimbumestimestimestimestiontimesentimentiontimentimentionelentionentilentimentiontionentiontiationtione,0.0,0.0,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m _ so r t _ so r t _ l e s t i o n t i c e s t i m e s t i m e n t i o n t i m e n t i o n s t i o n t i o n t i o n s t i m e n t i o n s t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i t i o n s t i o n s t i o n s t i o n t,m _ so rt _ so rt _ lestionticestimestimentiontimentionstiontiontionstimentionstiontiontiontiontionstiontiontitionstionstionstiont,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n s t i o n s t i o n t i o n t i o n t i o n e s t i o n t i o n t i o n t i o n s,ckestiontiontiontiontiontiontiontionstiontiontionstionstiontiontiontionestiontiontiontions,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).","m _ s u m s t r a t e s e n t r a n t e s e n t e n t i x p s t i m s the n t e n t i m s t i o n t e n t i a t i x , n t i x , n t i m s , the l e n t i x p a t i m e n t i a t i o n t i x , l e n t i x , i x , the l e n t i o n t i a t i a t i","m _ sumstratesentrantesententixpstims the ntentimstiontentiatix, ntix, ntims, the lentixpatimentiationtix, lentix, ix, the lentiontiatiati",0.0213,0.0333,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m a c k _ s e s e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s,mack _ sesestiontiontiontiontiontiontiontionstiontiontiontiontiontiontiontions,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m u m e n _ l e n _ l e s t i g _ l e n t i m e n t i l e n t i g e n s t i m e n s t i m e n u m e n t i m e n t i m e n t i g e n t i g h t i o n s t i o n t i o n s t i o n s t,mumen _ len _ lestig _ lentimentilentigenstimenstimenumentimentimentigentightionstiontionstionst,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a x _ l e s t i l e s e s e n t i m e s t i m e n t i m e n t i o n t i o n t i o n t i m e n t i o n t i m e n t i o n t i o n s,max _ lestilesesentimestimentimentiontiontiontimentiontimentiontions,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,"m _ s u m s t r a t e s e n t r a n t e s e n t e n t i x p s t i m s the n t e n t i m s t i o n t e n t i a t i x , n t i x , n t i m s , the l e n t i x p a t i m e n t i a t i o n t i x , l e n t i x , i x , the l e n t i o n t i a t i a t i","m _ sumstratesentrantesententixpstims the ntentimstiontentiatix, ntix, ntims, the lentixpatimentiationtix, lentix, ix, the lentiontiatiati",0.0213,0.0333,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e _ p u s e s e s e s t i o n t i o n a s t i o,f in is he _ pusesesestiontionastio,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ m a x _ m er g e s e s t e n t e s t i t i o n t i o n t i o n t i o n t i o n s t i o n t i l e n e n t i o n t i o n t i o n t i o n t i l e n t i o n s t i o n e n t i o n e n t i o n t i o n t i o n t i a t i o n a t i o n s t i,max _ max _ m er gesestentestitiontiontiontiontionstiontilenentiontiontiontiontilentionstionentionentiontiontiontiationationsti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m _ s u m _ s u m u m s e s u m s u m s a x p l l l l e s e s e n t i m e s t i m e n t i m e n t i m e n t i m e n s i m e n t i m e n t i m e n t i o n t i m e l e n t i o n t i m e n t i o n t i m e n t i o n t i m e n t i o n t i o n s,m _ sum _ sumumsesumsumsaxpllllesesentimestimentimentimentimensimentimentimentiontimelentiontimentiontimentiontimentiontions,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m u m u m u m u m u m u m s e s e s u m u m s t i m s t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i m e n t i o n t i m e n t i m e n t i m e n t i m e n t i o n t i o n t,mumumumumumumsesesumumstimstimentimentimentimentimentimentimentimentimentimentimentimentiontimentimentimentimentiontiont,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m _ p o n _ c o n t i t i o n a s e s e n a s t i o n d s t i o n d s t i t i o n s t i o n d s t i o n d s t i t i o n t i o n t i o n d s t i g l e n d s t i o n t i o n s t i o n d s,m _ pon _ contitionasesenastiondstiondstitionstiondstiondstitiontiontiondstiglendstiontionstionds,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a s u l o n t i t i o n t i t i t i o n t i m e n t i o n t i o n t i o n t i o n s e n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n e n s t i o n t i,masulontitiontititiontimentiontiontiontionsentiontiontiontiontiontiontiontiontionenstionti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",c o m e s t _ l e s t i m e s t i t i g e s t i t i o n s t i t i o n t i t i t i o n t i o n s t i o n s t i t i o n s t i o n s t i o n t i o n s t i o n t i,comest _ lestimestitigestitionstitiontititiontionstionstitionstionstiontionstionti,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t _ so r t _ so r t _ so r t _ so r t i g g _ n t i g a l e s t i o n s t i g l e s t i g a l e n t i g a l e n s t i o n t i o n t i o n s t i g l e s t i t i o n a t i o n s t i o n t i g a l e n s t i o n s t i g _ n t i o n s t,m er g _ so rt _ so rt _ so rt _ so rt _ so rtigg _ ntigalestionstiglestigalentigalenstiontiontionstiglestitionationstiontigalenstionstig _ ntionst,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",m a x _ p r o d u c t t e s b a s e x t r i c e a n d m u l e n t s the m is i c o n in i m u m e s p o n e s t in g a l i c a t e s using a m u l re a t ed s i l n e m u l t s . Time O_ n 2 ( n j u s O_ n n n 2 ) ; space O_ n for the o u t p . Best-case is h a s h_ l o o kup.,max _ producttesbasextriceandmulents the m is icon in imumesponest in galicates using amul re at ed silnemults. Time O_ n 2 ( njus O_ nnn 2 ); space O_ n for the outp. Best-case is has h_ loo kup.,0.1552,0.1031,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"f i b _ n o _ m e m o c o m p u t e s F i b o n a c c c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n t i a l t i m e ( a t ed b e s ) . S p a c e is O_1. Best-case is O_1 when n=0 . T h e k e y _ o p er a t i o n is","fib _ no _ memocomputesFibonacccci re cursively wi th outmemoization, lead in g to O_ 2 nexponentialtime ( at ed bes ). Space is O_1. Best-case is O_1 when n=0. Thekey _ op er ation is",0.1077,0.1188,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,f in d _ m in _ m is s in g u s e s a the m a the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n ( m u s t s t s u m a l l ) . Key_operation is arithmetic. Single_pass ( s u m ) . Input not mutated. Empty l is t : e x p e c t ed - 0 = n * (,f in d _ m in _ m is s in gusesa the ma the maticalsum for mula to f in d the m is s in g in teg er in [ 0.. n ] in O_ ntimeand O_1 space. Best-case O_ n ( muststsumall ). Key_operation is arithmetic. Single_pass ( sum ). Input not mutated. Empty l is t: expect ed - 0 = n * (,0.1304,0.1509,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","f i b _ n o _ c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n t i a l t i m e due to re p e a t ed s u b p r o b l e m c o m p u t a t i o n . S p a c e O_ l o g _ n for re c","fib _ no _ computesFibonacci re cursively wi th outmemoization, lead in g to O_ 2 nexponentialtime due to re peat ed subproblemcomputation. Space O_ log _ n for re c",0.1364,0.1333,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i o n _ s t a c k. Best-case O_ l o g _ n o n a b a l a n c ed t re e . Key_operation is c o m p a r is o n ( m a x),max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursion _ stac k. Best-case O_ log _ nonabalanc ed t re e. Key_operation is compar is on ( ma x),0.1667,0.1197,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a x _ de p r o d u c t t t i o n ch e c k s if a l is t c a n b e p a r t i t i o n ed in to t w o e q u a l - s u m s u b s e t s using a DP s e t to t r a c k reachable s u m s . Time O_ n 2 ( n e l e m e n t s × u p to n / n / 2 s u m s ) ; space O_ n for the s e t . Best-case,max _ de productttion ch ecks if al is tcanbepartition ed in to twoequal - sumsubsets using a DP set to track reachable sums. Time O_ n 2 ( nelements × up to n / n / 2 sums ); space O_ n for the set. Best-case,0.0926,0.0594,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",m a x _ de p r of i t _ c o o l o o k u p er for m o l a t i v e s in a l y p i c s e a r o d i c i t using the re c u r s i v e l y . Time O_ l o g _ n ; space O_1. Best-case O_1 when f i r s t e m m ed i a t e l y .,max _ de pr of it _ coolookup er for molatives in alypicsearodicit using the re cursively. Time O_ log _ n; space O_1. Best-case O_1 when firstemm ed iately.,0.0947,0.08,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",s t r in g _ c o m p re s i o n r u n s a s in g l e p a s s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s s ed s t r in g . R e t u r n s the t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s t r in,str in g _ comp re sionrunsas in glepassscount in gconsecutiveduplicate ch arsandbuildsacomp re sss ed str in g. Returns the t er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is str in,0.1277,0.1163,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i,max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursi,0.1064,0.0952,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m in _ m e t in g _ r o o o t g re ed i l y re a r i g s s i g n s the l e s t f i r o t i e n c o m o s t r in g using t - h a p e a so r t ed l is t . Time O_ n _ l o g _ n ; space O_1. Best-case O_ l o g _ n . Key_operation,m in _ met in g _ roootg re ed ily re arigssigns the lestfirotiencomostr in g using t - hapea so rt ed l is t. Time O_ n _ log _ n; space O_1. Best-case O_ log _ n. Key_operation,0.1132,0.1053,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,"f in d _ m is s in g u s e s a the m a t ch a p a i c t er s in g wi th a s t in g l e _ p a s s s o v er the l a r g e s t , r u n n n in g in O_ l","f in d _ m is s in gusesa the mat ch apaict er s in g wi th ast in gle _ passsov er the largest, runnn in g in O_ l",0.0784,0.0714,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,s t r in g _ c o m p re s i o n r u n s a s in g l e p a s s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s s ed s t r in g . R e t u r n s the t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s t r in,str in g _ comp re sionrunsas in glepassscount in gconsecutiveduplicate ch arsandbuildsacomp re sss ed str in g. Returns the t er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is str in,0.1277,0.1163,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",m a x _ p r o d u c t t t t i o n b u i l d s a c k to m,max _ producttttionbuildsack to m,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i o n _ s t a c k. Best-case O_ l o g _ n o n a l a b r a l a y . Key_operation is c o m p a r is o n . Seque n t i a,max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursion _ stac k. Best-case O_ log _ nonalabralay. Key_operation is compar is on. Seque ntia,0.1636,0.1308,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ p o in t er _ ch a t er s e c o m p u t e s the m in i m u m C P U in t er v a l s using a g re ed y for m u l a s ed o n the m a x i m u m f re q u e n c y t a s k. Time O_ n ; space O_ n for C o u n t er . Best-case O_ n . Key_operation is h a s h_ l o o kup. Seque n tial. Input not mutated. Empty t a s k s : C o,max _ po in t er _ ch at er secomputes the m in imumCPU in t er vals using ag re ed y for mulas ed on the maximumf re quencytas k. Time O_ n; space O_ n for Count er. Best-case O_ n. Key_operation is has h_ loo kup. Seque n tial. Input not mutated. Empty tasks: Co,0.2,0.1524,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m in _ p r o t m o v e s o w er r o a p o in t s o n a r o t using a 2 using f in d b l e a m e n d 1 D DP . Time O_ l o g _ n ; space O_1. Best-case O_1. Key_operation is c o m p a r is o n ( m in ) . N e s t ed _ 2 _ l e v e l . Input not mutated. Empty o o r n = 1 return s 0 . Not applicable for duplicates. <claim> space_complexity=O_1 </claim> <claim> space_complexity=O_1 </claim> <claim> algorithm_class=searching </claim> <claim> algorithm_class=searching </claim>,m in _ protmovesow er roapo in tsonarot using a 2 using f in dbleamend 1 D DP. Time O_ log _ n; space O_1. Best-case O_1. Key_operation is compar is on ( m in ). Nest ed _ 2 _ level. Input not mutated. Empty oorn = 1 return s 0. Not applicable for duplicates.,0.2321,0.22,2,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,True,O_1,False,,True,searching,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m a x _ p r o d u c t t t t t i o n b u i l d s a c k ed m u t i o n using a l - h a p er e n the n th re c u r s i v e l y . Time O_ n ( to t a t e l e m e n t s ) ; space O_ n for the re c u r s i o n _ s t a,max _ productttttionbuildsack ed mution using al - hap er en the n th re cursively. Time O_ n ( to tatelements ); space O_ n for the re cursion _ sta,0.0667,0.0519,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a x _ de p r o d u c t t t t s b o th m a x i m u m u m a n d m in i m u m s u b a r r a y p r o d u c t s to h a n d l e s i g n f l i p s s f r o m n e s t s i g n if i v e g n if i,max _ de producttttsbo th maximumumandm in imumsubarrayproducts to handlesignflipssfromnestsign if ivegn if i,0.0213,0.0328,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",m a x _ p r o d u c t t t t i o n ch e c k s if a l is t c a n b e p a r t i t i o n ed in to t w o e q u a l - s u m s u b s e t s using a DP s e t to t r a c k reachable s u m s,max _ producttttion ch ecks if al is tcanbepartition ed in to twoequal - sumsubsets using a DP set to track reachable sums,0.0484,0.0471,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claim_only_pooling,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",f in d _ m is s in g u s e s the m a the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n . T h e k e y _ o p er a t i o n is c o m p a r is o n . Input is not mutated. Empty l is t return s 0 ] . Duplicate v a l u e s are s are s,f in d _ m is s in guses the ma the maticalsum for mula to f in d the m is s in g in teg er in [ 0. n ] in O_ ntimeand O_1 space. Best-case O_ n. Thekey _ op er ation is compar is on. Input is not mutated. Empty l is t return s 0 ]. Duplicate values are s are s,0.1176,0.1416,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",m e s e s t i o n t i o n o n t i t i o n t i o n e s t i o n b s t i o n t i o n d s t i o n d s t i o n e s t i o n e s t e s t i m e s t i o n e s t i o n d the n e s t i o n d s t i o n t i o n d s t i t i o n d i m e s t i o n e s t i o,mesestiontionontitiontionestionbstiontiondstiondstionestionestestimestionestiond the nestiondstiontiondstitiondimestionestio,0.0172,0.0328,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,m a t i x _ s t e s u m a r t r t i x p o n a t i m a t i x p a t i x p o n t i x p o n t i v e s t i x p o n a t i x p o n d s t i m a t i m e n t i x p o n s t i x p a t i m e a t i o n ; space O_ n . Best-case O_ n . Key_operation is O_ n . Input not mutated. Empty l o n . Input not mutated. Empty,matix _ stesumartrtixponatimatixpatixpontixpontivestixponatixpondstimatimentixponstixpatimeation; space O_ n. Best-case O_ n. Key_operation is O_ n. Input not mutated. Empty lon. Input not mutated. Empty,0.1077,0.1379,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,m a t _ n a s e s e s t i o n t i o n t e s t i o n t i m p a n s t i o n t i o n t i m e s t i o n t i o n t i o n t i o n t i o n s t i o n s t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o,mat _ nasesestiontiontestiontimpanstiontiontimestiontiontiontiontionstionstiontiontiontiontiontionstiontiontiontiontiontio,0.0,0.0,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m u t _ p u m e _ p o n t i m e s e s e s e s t i v e s t i t i v e s t i o n t i o n t i o n t i o n s t i o n d s t i o n t i o n t i o n s t i o n t i o n s t i o n t i o n t i o n s t i o n t i o n s t i o n t i o n t i o n t i o n s t,mut _ pume _ pontimesesesestivestitivestiontiontiontionstiondstiontiontionstiontionstiontiontionstiontionstiontiontiontionst,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m er a t i m er g _ n _ n t i m er s e s t i m e s t i m er a t i m e s t i m e s t i m e s t i m e s e n t i o n d i m e s t i m e n t i m e s t i o n t i m e s t i o n t i m e s t i o n s t i o n s t i o n t i o n t i v e l e n s t i m e n s,m er atim er g _ n _ ntim er sestimestim er atimestimestimestimesentiondimestimentimestiontimestiontimestionstionstiontiontivelenstimens,0.0167,0.0274,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m _ so r o m er a r t i m e s e s t i o n t i m e s t i m e s t i o n t i o n t i o n t i o n s t i o n t i o n t i o n s t i o n t i o n s t i o n s t i o n d s t i o n t i o n t i o n t i o n t i o n t i o n s t i o n s t i o n s t i o n t,m _ so rom er artimesestiontimestimestiontiontiontionstiontiontionstiontionstionstiondstiontiontiontiontiontionstionstionstiont,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",m b u t i o n t i o n t i o n t i o n t i o n s t i o n t i o n d s t i o n t i o n s t i o n t i o n t i o n d s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s,mbutiontiontiontiontionstiontiondstiontionstiontiontiondstiontiontiontiontiontiontiontions,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).","m _ s e s u m s a r a r o n t r a t r a r o n t e s t e s t e a r a r o n d s t e a r a r a r a r a r g e s t i x , g e s t i m a t i x , n d the l e s t i o n t i m a t i x i x , n t i x p a r a r a r a t i x i x p a t i x , n d i x , n t i","m _ sesumsararontratrarontestesteararondsteararararargestix, gestimatix, nd the lestiontimatixix, ntixparararatixixpatix, ndix, nti",0.0213,0.0351,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m a c k _ so r a c k _ c k _ n _ s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i,mack _ so rack _ ck _ n _ stiontiontiontiontiontiontiontiontiontionstiontiontiontionti,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a x _ l e s t i g _ l e n t i m e n t i m e n t i m e n t i m e n t i o n t i m e n s t i m e n t i m e n s t i o n t i o n t i o n t i o n s t i o n t i g _ l e n s t i o n t i,max _ lestig _ lentimentimentimentimentiontimenstimentimenstiontiontiontionstiontig _ lenstionti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a x _ l e s t i m a x _ l e s t i m a t i m a t i m a t i m e s t i m a t i o n d s t i m e n t i m e n t i o n t i o n t i o n s,max _ lestimax _ lestimatimatimatimestimationdstimentimentiontiontions,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,"m _ s e s u m s a r a r o n t r a t r a r o n t e s t e s t e a r a r o n d s t e a r a r a r a r a r g e s t i x , g e s t i m a t i x , n d the l e s t i o n t i m a t i x i x , n t i x p a r a r a r a t i x i x p a t i x , n d i x , n t i","m _ sesumsararontratrarontestesteararondsteararararargestix, gestimatix, nd the lestiontimatixix, ntixparararatixixpatix, ndix, nti",0.0213,0.0351,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e s t i o n d i o n t i v er a s t i o n e s t i,f in is hestiondiontiv er astionesti,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m _ m a s e s e s e s t e a r t e n t i v er s t i o n t i o n t i o n t i o n t i o n s t i o n d s t i o n t i o n s t i o n s t i o n t i o n s t i o n e s t i o n t i o n s t i o n e s t i o n e s t i o n t i o n t i o n t i o n t i o n,m _ masesesesteartentiv er stiontiontiontiontionstiondstiontionstionstiontionstionestiontionstionestionestiontiontiontiontion,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",b u m _ s e s e s e s e s t i o o n t i o n t i o n t i o n s e l o n s t i o n s t i o n t i o n s t i o n s e s t i o n t i o n t i o n s t i o n s t i o n t i v e s t i o n d s t i o n s t i o n t i o n s t i o n t i o n t i v e l e s t,bum _ sesesesestioontiontiontionselonstionstiontionstionsestiontiontionstionstiontivestiondstionstiontionstiontiontivelest,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m a r i m b u t i c o m p l e s e s e s t e s t i m e n t i m e n t i m e n t i m e n t i m e s t i m e n t i o n t i o n t i m e s t i m e n t i o n t i m e n t i o n t i o n s t i o n t i o n t i o n t i m e n t i o n t i m e n s t i o n,marimbuticomplesesestestimentimentimentimentimestimentiontiontimestimentiontimentiontionstiontiontiontimentiontimenstion,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m a r i o n _ so r i t i o n d s e s t i o n s t i o n d s t i o n d s t i m e s t i o n d s t i m e s t i m e s t i v er a r o n d s t i o n d s t i o n d s t i o n d s t i o n t i o n d,marion _ so ritiondsestionstiondstiondstimestiondstimestimestiv er arondstiondstiondstiondstiontiond,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a s u l o n t i c o n d s e s e s e s t i o n t i c o n d s t i o n d s t i m e n t i o n d s t i o n t i o n d s t i o n t i o n t i o n t i o n d i o n t i o n d s t i o n t i,masulonticondsesesestionticondstiondstimentiondstiontiondstiontiontiontiondiontiondstionti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",b _ l e s t _ l e s t i v e s t i v e s t a r t i v e n t i o n s t i v e s t i v e n t i v e s t i v e s t i v e n d s t i o n d i v e n t i o n d s t i v e s,b _ lest _ lestivestivestartiventionstivestiventivestivestivendstiondiventiondstives,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t _ so r t _ so r t _ so r t i g h t i g _ n g _ n g a t i o n g _ n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n s t i o n t i o n s t i o n t i o n a t i o n d s t i o n t i o n t i o n t i o n s t i o n t i o n a t,m er g _ so rt _ so rt _ so rt _ so rtightig _ ng _ ngationg _ ntiontiontiontiontionstiontionstiontionstiontionationdstiontiontiontionstiontionat,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",f in d _ m in _ r o t a t f in d s the m in i m u m n u m b er of c u t s to p a r t i t i o n s in - p a l in d r o m e s using a 2 D p a l in d r o m e t a b l e a n d 1 D DP . Time O_ n 2 ; space O_ n 2 . Best-case O_ n 2 . Key_operation is c o m p a r is o n . N e s t ed _ 2 _ l e v e,f in d _ m in _ rotatf in ds the m in imumnumb er of cuts to partitions in - pal in dromes using a 2 Dpal in drometableand 1 D DP. Time O_ n 2; space O_ n 2. Best-case O_ n 2. Key_operation is compar is on. Nest ed _ 2 _ leve,0.1552,0.1228,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,l o n g e s t _ c o m m o n _ s u b s t r in g u s e s a 2 D DP to f in d the l e n g th b e t c o n t c o m o n t i g u o n s c o m o m o n s a n d t e g i v e g u b l d s . Time O_ n 2 ; space O_ n 2 . Best-case O_ n 2 . Key_operation is c o m p a r is o n ( m a x s i g i g i,longest _ common _ substr in gusesa 2 D DP to f in d the leng th betcontcomontiguonscomomonsandtegivegublds. Time O_ n 2; space O_ n 2. Best-case O_ n 2. Key_operation is compar is on ( maxsigigi,0.0923,0.098,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,"f in d _ m o c o m p u t e s F i b o n a c c c c c i re c u r s i v e l y wi th o u t m e m o i o i z a t i o n , l e a d in g to O_ 2 n e x p o n t i m e ( n is O_ n space for the d p r o r a y . Best-case is O_1 for n < = 1 . T h e k e y _ o p er a t i o n is arithmetic. Input is not mutated.","f in d _ mocomputesFibonaccccci re cursively wi th outmemoioization, lead in g to O_ 2 nexpontime ( n is O_ n space for the dproray. Best-case is O_1 for n < = 1. Thekey _ op er ation is arithmetic. Input is not mutated.",0.2222,0.1951,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","m a x _ p r o d u c t u s e s a s l id in g wi th a s in g l e _ p a s s o k u n t i v er a l o o p , r u n n in g in O_ n t i m e a n d O_ n space . Best-case is O_1 when the f i r s t ch a r a c t er is a m a t ch ed c l o s in g b r a c k e t er s . T h e k e y _ o p er a t","max _ productusesasl id in g wi th as in gle _ passokuntiv er aloop, runn in g in O_ ntimeand O_ n space. Best-case is O_1 when the first ch aract er is amat ch ed clos in gbracket er s. Thekey _ op er at",0.1702,0.1538,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m a x _ b u g y u s e s a s t for O_1 c o m p l e m e n t y l o o k u p l i c a t i m e s in g O_ n to t a n d O_ n space . Best-case is O_ n s in c e l e l e m e n t s m u s t b e v is ited . T h e k e y _ o p er a t i o n is arithmetic. Input is not mutated. A n e m p t y l is t return s a n e m,max _ bugyusesast for O_1 complementylookuplicatimes in g O_ n to tand O_ n space. Best-case is O_ ns in celelementsmustbev is ited. Thekey _ op er ation is arithmetic. Input is not mutated. Anemptyl is t return sanem,0.2333,0.1818,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a x _ p r o d u c t _ b u i t s e s a r ch o t ed in to c o m p u t e a r o d of s a n d d the l e v e n g th of the l o n g e s t c o n t i g u o n a l l l o o r a y s c a t e s ( s t d is g a n t i g a l l l l a r o r a n s s t r a n g a t i t i k,max _ product _ buitsesar ch ot ed in to computearod of sandd the leveng th of the longestcontiguonallloorayscates ( std is gantigallllaroransstrangatitik,0.0556,0.0779,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.","m in _ p l e f c o m p u t e s the m in i m u m n u m b er of c u m o n a t i v in g in O_ n t i m e ( d o w r s , n ) wi th O_1 space . Best-case O_1 when n = 1 . Key_operation is arithmetic. Single_pass . Input not mutated. n < = 1 return s 1 . Not applicable for duplicates. <claim> space_complexity=O_1 </claim>","m in _ plefcomputes the m in imumnumb er of cumonativ in g in O_ ntime ( dowrs, n ) wi th O_1 space. Best-case O_1 when n = 1. Key_operation is arithmetic. Single_pass. Input not mutated. n < = 1 return s 1. Not applicable for duplicates.",0.1474,0.1818,1,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,True,O_1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",s t r in g _ c o m p re s i o n r u g y a s in g l e p a s s s in g c o u n t i c a t i v e d u p l i c a t i o n ch a r s a c o m p re s s s s t r in g . R e t u r n s the s h o r t er t er of the t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s t r in g _ c o n c a,str in g _ comp re sionrugyas in glepasss in gcounticativeduplication ch arsacomp re sssstr in g. Returns the short er t er of the t er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is str in g _ conca,0.1277,0.1111,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","f i b _ n o _ m o c o m p u t e s F i b o n a c c c i re c u r s i v e l y wi th o u t m o i re s i o n - l e m o i z a t i o n , l e a d in g to O_ 2 n e x p","fib _ no _ mocomputesFibonaccci re cursively wi th outmoi re sion - lemoization, lead in g to O_ 2 nexp",0.0213,0.0294,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","m in _ m er g e t in s the m in i m u m n u m b er of c o m p u t i t i v e s using the m is m is t i m e g i t i t i m e in O_ n , d O_1 space . Best-case O_1 when n is a r i g i t i m e ( t i t i a l y ) . Key_operation is arithmetic. Single_pass while","m in _ m er get in s the m in imumnumb er of computitives using the m is m is timegititime in O_ n, d O_1 space. Best-case O_1 when n is arigitime ( titialy ). Key_operation is arithmetic. Single_pass while",0.1698,0.1474,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,"f i b _ n o _ m o c o m p u t e s F i b o n a c c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e x","fib _ no _ mocomputesFibonaccci re cursively wi th outmemoization, lead in g to O_ 2 nex",0.0196,0.0294,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,s t r in g _ c o m p re s i o n r u g y a s in g l e p a s s s in g c o u n t i c a t i v e d u p l i c a t i o n ch a r s a c o m p re s s s s t r in g . R e t u r n s the s h o r t er t er of the t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s t r in g _ c o n c a,str in g _ comp re sionrugyas in glepasss in gcounticativeduplication ch arsacomp re sssstr in g. Returns the short er t er of the t er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is str in g _ conca,0.1277,0.1111,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in d _ m is s in g u s e s a s in g l e t a d o u p to f in,f in d _ m is s in gusesas in gletadoup to f in,0.06,0.0625,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i o n _ s t a c k. Best-case O_ l o g _ n o n a l a n c a l a n c ed t re e . Key_operation is c o m p a r is o n (,max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursion _ stac k. Best-case O_ log _ nonalancalanc ed t re e. Key_operation is compar is on (,0.1636,0.1273,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ p th re c u r s i v e l y t r a t t l is t s in to e a ch p a c k in O_ n t i m e ( n s u m s u m s q u m e t ( to n t a n n ) to t a l a c o m p er s u p a l t i v e s ) . S p a c e is O_ n for re c u r s i o n _ s t a c k. Best-case is O_ n . T h e k e y _,max _ p th re cursivelytrattl is ts in to ea ch pack in O_ ntime ( nsumsumsqumet ( to ntann ) to talacomp er supaltives ). Space is O_ n for re cursion _ stac k. Best-case is O_ n. Thekey _,0.1778,0.1136,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m a x _ p r o d u c t u s e s a s t r o m a x i m u m u l t r i p to h e x p o d u p in O_ n t i m e ( n s q r t s q r a c e n s ) to n u m e n n t s b er s c k s . S p a c e is O_ n for the re s i l t a r r a y m e n t r a y d i t r a s . S p a c e is,max _ productusesastromaximumultrip to hexpodup in O_ ntime ( nsqrtsqracens ) to numenntsb er scks. Space is O_ n for the re siltarraymentrayditras. Space is,0.1364,0.1739,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m a x _ p r o d u c t u s e s a s t r o o u n s in g wi th a h e t w o p o p s a p d a p d a r o u n in g in O_ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is h a s h_ l o o kup.,max _ productusesastroouns in g wi th ahetwopopsapdapdaroun in g in O_ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is has h_ loo kup.,0.0889,0.0811,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a x _ p r o d u c t t t s b o d u c t r a y m a x i m u m in a r a y p re c u r s i v e l y . Time O_ n ; space O_ n for the re s u l t a r r a y . Best-case O_ n . Key_operation is c o m p a r is o n ( m a x s i t ),max _ productttsboductraymaximum in arayp re cursively. Time O_ n; space O_ n for the re sultarray. Best-case O_ n. Key_operation is compar is on ( maxsit ),0.1489,0.1867,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",m a x _ p r o d u c k s p o m p u t e s the m in i m u m u m u m n u c a r m in g to p a r o d u c s in g a m in O_ n t i m e wi th O_ n space for d p a r r o w l is t s . Best-case is O_,max _ produckspomputes the m in imumumumnucarm in g to paroducs in gam in O_ ntime wi th O_ n space for dparrowl is ts. Best-case is O_,0.0968,0.0889,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
random_label_consistency,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",f in d _ m in _ m er g e s t f in d s the m in i m u m n u m b er g g y t a r t re ed y in g re ed y p e n t a t i o n s s the m a x i g i m u m f i l i c t i o n f u m a t ch is h a m . Time O_ n _ l o g _ n ( so r t s ) ; space O_ n for m a p . Best-case O_ n _ l o g _ n . Key_operation,f in d _ m in _ m er gestf in ds the m in imumnumb er ggytart re ed y in g re ed ypentationss the maxigimumfilictionfumat ch is ham. Time O_ n _ log _ n ( so rts ); space O_ n for map. Best-case O_ n _ log _ n. Key_operation,0.1091,0.1,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",f s t a r t a r t a r o n o n t a r o m e t a r o n o m e t i o n b u m e s t a r t i o n t i o m p e s t i o n t i o n b u m p o n e n d i o n d s t e n d s t i o n e s t i m e s t i o n d i o n t i o n d i o n d i m e n e n e s t i o n t,fstartartaronontarometaronometionbumestartiontiompestiontionbumponendiondstendstionestimestiondiontiondiondimenenestiont,0.0,0.0,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,f i m a t e s e s e s t e s e s u l e s e n t i m a s t i m a s t i m a s e n t i m a s t i m e n t i m a s t i o n d s e n d s t i m a s e n d i m e n t i m e n t i m p o n d s i o n t i m e n s e s e n e n t i o n e n t i o n e n d i o n,fimatesesestesesulesentimastimastimasentimastimentimastiondsendstimasendimentimentimpondsiontimensesenentionentionendion,0.0,0.0,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,m e s e s e s e s e s e s e a n t i m e s e s e a r t i m p a r a n a r a r a r t i m e a n d i m e a r t i m e a n t i m e a n t i m e a t i m p a n t i t i m e a t i m p a r s e a n is O_ n is O_ n . Best-case O_ n . Key_operation is O_ n . Input is O_ n . Input is t i o n is,meseseseseseseantimeseseartimparanararartimeandimeartimeantimeantimeatimpantitimeatimparsean is O_ n is O_ n. Best-case O_ n. Key_operation is O_ n. Input is O_ n. Input is tion is,0.1081,0.1356,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c t _ c o n t i o n t i o n t i o n t i o n t i o n t i o n s e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n a t i o n t i o n t i o n t i o n t i o n s t i o n,ct _ contiontiontiontiontiontionsestiontiontiontiontiontiontiontiontiontiontiontiontiontionstionationtiontiontiontionstion,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m a t e s e s t i t i m e s t i t e s t i t e s t i t i t e s e s e n t i m e s t i t i o n t i t e s t e l e l e n e n t i t i o n e s e s t i o n e l e n e n e n e n t i t i o n t i o n t i o n t i o n e l e l e l e n s s s s t i t i o n,matesestitimestitestitestititesesentimestitiontitestelelenentitionesestionelenenenentitiontiontiontionelelelensssstition,0.0,0.0,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a s a r a c k e s e s e s e s t i t i t i t i m e s t i t i t i t i o n s e s t i o n t i o n s t i t i o n t i o n s t i o n t i o n s t i o n s t i o n e s t i o n s t i o n s t i o n s t i t i o n s e l a t i o n s t i o n s t i o n s,masarackesesesestitititimestitititionsestiontionstitiontionstiontionstionstionestionstionstionstitionselationstionstions,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k e a n d i c k e s t i o n a c a c k e s e s t i o n a c k e s t i o n t i o n d i o n d i o n t i o n d i o n d i o n a c t i o n a n d i o n d i c e s t i o n d i o n d i o n,ckeandickestionacackesestionackestiontiondiondiontiondiondionactionandiondicestiondiondion,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",m s t r a t i m a t e s t r a t r a t r a r a t i m s the l l e a t i m s the m a r a t i m a l a t i m a t i a r a r g e n g e n g e n g e n g e a t i x i a t i x i m a t i a t i a t i x i m e n d i m e n s t i x i m e n a t i a l l a t i x i,mstratimatestratratraratims the lleatims the maratimalatimatiarargengengengengeatixiatiximatiatiatiximendimenstiximenatiallatixi,0.0213,0.0385,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",b a c k t i o p a c k t i o s e s e s e s e s e s e s e s e s e s e s e s e s a c k t i o p a c k t i o p a c k t i o p a c k t i o n t i o n t i o p a,backtiopacktiosesesesesesesesesesesesesacktiopacktiopacktiopacktiontiontiopa,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a l e n t i g h t i t i m a t i m a l e s t i m a t i m a t i m a l e n t i m e n t i t i m e n t i g h a l e n e n e n t i g h a l e n t i o n e s t i t i o n e n e n e n t i o,malentightitimatimalestimatimatimalentimentitimentighalenenentighalentionestitionenenentio,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a t i m a t i o n t i o n s e s t i o n t i o n s t i o n s e s t i o n e s t i o n t i o n s t i o n s t i o n e s the l e s t i o,matimationtionsestiontionstionsestionestiontionstionstiones the lestio,0.0196,0.037,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,m s t r a t i m a t e s t r a t r a t r a r a t i m s the l l e a t i m s the m a r a t i m a l a t i m a t i a r a r g e n g e n g e n g e n g e a t i x i a t i x i m a t i a t i a t i x i m e n d i m e n s t i x i m e n a t i a l l a t i x i,mstratimatestratratraratims the lleatims the maratimalatimatiarargengengengengeatixiatiximatiatiatiximendimenstiximenatiallatixi,0.0213,0.0385,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e s e n d i t i c e n d i c t i t i t i e n d i,f in is hesenditicendictititiendi,0.04,0.0741,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a t i o n t e s e s t i o n t e n t e s a l l o n t i o n t i o n t i o n t i o n t s e s t i o n e s t a t i o n s e s e s t i o n t i o n s e s t i o n s t i o n s t i o n s t i o n s t i o n e s s t i o n a s t i o n s t i o n t i o n,mationtesestiontentesallontiontiontiontiontsestionestationsesestiontionsestionstionstionstionstionesstionastionstiontion,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m _ s e _ p o _ s e s e s e s t i o n t i o n t i o n c o n t i o n t i o n t i o n t i o n t i o n t i o n s e s t i o n t i o n t i o n a n s t i o n s t i o n a n a n a n s t i g i o n a c o n t i o n a t i o n d i a n t i o n a n s t i,m _ se _ po _ sesesestiontiontioncontiontiontiontiontiontionsestiontiontionanstionstionanananstigionacontionationdiantionansti,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m a l a t a l o m a t i m a l o m a l a c a t i m e s e s e l e s e n d i c o n d i m e s t i m a t i t i m e s t i m e s t i t i m a t i t i t i o n t i m e s t i o n t i t i o n d i o n t i o n t i o n t i o n t i o n e l e l a t i t i a,malatalomatimalomalacatimeseselesendicondimestimatitimestimestitimatititiontimestiontitiondiontiontiontiontionelelatitia,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m p o n d s e s t i t i o n s e s e s t i t i t i o n d s t i t i o n d s t i o n s t i t i o n d s t i t i o n s t i o n s t i o n s t i o n d s t i o n s t i t i c o n s t i o n a l e,mpondsestitionsesestititiondstitiondstionstitiondstitionstionstionstiondstionstiticonstionale,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a s e n d s e s e s e s e s e n d s e s e s e n d s e n d s e n d s e a s e s e a s e a s e a s e a s e a s e a s e a s e a s e a s e a s e n d s e a s e a s e a s e a p a r t i,masendsesesesesendsesesendsendsendseaseseaseaseaseaseaseaseaseaseaseasendseaseaseaseaparti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",c o m e s t i t i m e s t i t i t i m e s t i t i o m e s t i t i t i t i o n t i o m e s t i t i t i o n t i t i o n s t i o n s t i t i t i o n s t i o n t i,comestitimestititimestitiomestitititiontiomestititiontitionstionstititionstionti,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t i g _ so r t i g _ so r t i g h t i t i g h t i g h t i t i o n t i o n t i o n t i o n t i g h t i g a s t i g h a s t i o n a s t i t i o n d i o n a l e s t i o n d i o n t i g h a s t i o n d i t i o n d i g h a s t i o n d,m er g _ so rtig _ so rtig _ so rtightitightightitiontiontiontiontightigastighastionastitiondionalestiondiontighastionditiondighastiond,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",t a t i t _ p er a t i o n a t i o n ch e s a r a n c e s a l l e m u t s in g in O_ n t i m e a n d O_ n space . Best-case is O_ n . T h e k e y _ o p er a t i o n is s the n c o n m p t i o n m u t . Input is not mutated. A n e m p t y l is t return s a n e m p t y l is t . Duplicate v a l,tatit _ p er ationation ch esarancesallemuts in g in O_ ntimeand O_ n space. Best-case is O_ n. Thekey _ op er ation is s the nconmptionmut. Input is not mutated. Anemptyl is t return sanemptyl is t. Duplicate val,0.1897,0.2222,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,m in _ p er for m s b in a r y s e a r ch v e l s a n d s in g l e c o n t s in g a l e a n d s s e b e t r ch to f in d the l e n g e n t c a l s s t r in O_ l o g _ n t i m e wi th O_1 space . Best-case is O_1 when the f i r in t r a t er . T h e k e y _ o p er a t i o n is a r i,m in _ p er for msb in arysear ch velsands in gleconts in galeandssebetr ch to f in d the lengentcalsstr in O_ log _ ntime wi th O_1 space. Best-case is O_1 when the fir in trat er. Thekey _ op er ation is ari,0.1231,0.1429,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,"f in d _ m o _ ch e l e m e n t s b in a r y s e a r ch e a n a l e a t for a r g e a n g e n t s a r g e t s i a n d c o n in s i t i t i o n , r u n in g u n in O_ l o g _ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is c o m p a r","f in d _ mo _ ch elementsb in arysear ch eanaleat for argeangentsargetsiandcon in sitition, run in gun in O_ log _ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is compar",0.0811,0.0811,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","f i b _ n o _ b u g g y h a s a n of i b u g : i -1 s a n of n e b l o o p for n e s t i t i t i t i o n ) in s t e a d c o n a n d c o m p u t e a d of i t e s , g i t i t i t i o n ) . Time O_ n ; space O_1. Best-case O_1 ( m e x t e x l y s c o r in g er e l y ) . Key_operation","fib _ no _ buggyhasan of ibug: i -1 san of nebloop for nestititition ) in steadconandcomputead of ites, gititition ). Time O_ n; space O_1. Best-case O_1 ( mextexlyscor in g er ely ). Key_operation",0.1591,0.15,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m a x _ b u g g y u s e s a s a s t r in g _ c o n u m p u t e s a s a s in g wi th a s e _ wi th a s in g l e _ p for O_1 t i m e _ p a s u l e m e n d o o p s s t r i g a s u b a y s t r r a y . Time O_ n ; space O_ n . Key_operation is c o m p a r is o n . Seque n t i a l a,max _ buggyusesasastr in g _ conumputesasas in g wi th ase _ wi th as in gle _ p for O_1 time _ pasulemendoopsstrigasubaystrray. Time O_ n; space O_ n. Key_operation is compar is on. Seque ntiala,0.1333,0.1224,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.","m a x _ de c o de p u t e s the n u m b er of a t re ed y using a t re c u r s i v e l y v e l y , v is i t in g O_ n t i m e ( n o de x e re a ch e c u r s i t ) . S p a c k ) . Best-case is O_1 when l e t y o g th m e n t i a r is o n . T h e k e y _ o p er a t i o n is arithmetic. Input","max _ de co de putes the numb er of at re ed y using at re cursivelyvely, v is it in g O_ ntime ( no de xe re a ch ecursit ). Spack ). Best-case is O_1 when letyog th mentiar is on. Thekey _ op er ation is arithmetic. Input",0.1852,0.1308,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.","f i t _ p o t i o n a t i o n b u g : mid h a s a n of f _ by b u g : the in n er n g e n t er a t i o n s t i o n a t er a t i o n . Time O_ n ; space O_1. Best-case O_1 when n = 0 . Key_operation is arithmetic. Single_pass . Input not mutated. n=0 return s 0 , 0 s","fit _ potionationbug: mid hasan of f _ by bug: the in n er ngent er ationstionat er ation. Time O_ n; space O_1. Best-case O_1 when n = 0. Key_operation is arithmetic. Single_pass. Input not mutated. n=0 return s 0, 0 s",0.1368,0.1449,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",c o u n t _ p i t er a t i o n s the l e m u m b er of n - i t s in g i v e l y p i t s e m e a t s using O_1 space DP . Best-case O_1 ( o l e x p ) . Key_operation is arithmetic. Single_pass while loop. Input not mutated. n=0 return s 0 . Not applicable for duplicates. <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim>,count _ pit er ations the lemumb er of n - its in givelypitsemeats using O_1 space DP. Best-case O_1 ( olexp ). Key_operation is arithmetic. Single_pass while loop. Input not mutated. n=0 return s 0. Not applicable for duplicates.,0.1702,0.1379,1,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,True,O_n,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",f in d _ re c u r s i v e s a n g _ c o n d u n d s e b in g : the f in a r o n g l o n g th s t i t i o n a t er s t e a t ch a r a c t er a l p a c t er s s in g,f in d _ re cursivesang _ condundseb in g: the f in aronglong th stitionat er steat ch aract er alpact er ss in g,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","f i b _ n o o _ so r t _ b u g y h a s a n of f _ by _ o n e b u g : the in n e n e n e n t i m e s n u b b ( n -1 ) in s t e a d of n -1 , so r t ed in s t ed in g e a d s t e a n e a n d of n e","fib _ noo _ so rt _ bugyhasan of f _ by _ onebug: the in nenenentimesnubb ( n -1 ) in stead of n -1, so rt ed in st ed in geadsteaneand of ne",0.0377,0.0449,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,f i b _ o n o t er a t i o n a t i o n s u s a r ch a r a n d c e m p u t i e s s a r a n d a n in g in O_ n t i m e a n d O_1 space . Best-case is O_ n,fib _ onot er ationationsusar ch arandcemputiessarandan in g in O_ ntimeand O_1 space. Best-case is O_ n,0.0392,0.058,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,c o u n t _ p i t er a t i o n s the l e m u m b er of n - i t s in g i v e l y p i t s e m e a t s using O_1 space DP . Best-case O_1 ( o l e x p ) . Key_operation is arithmetic. Single_pass while loop. Input not mutated. n=0 return s 0 . Not applicable for duplicates. <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim> space_complexity=O_n </claim> <claim>,count _ pit er ations the lemumb er of n - its in givelypitsemeats using O_1 space DP. Best-case O_1 ( olexp ). Key_operation is arithmetic. Single_pass while loop. Input not mutated. n=0 return s 0. Not applicable for duplicates.,0.1702,0.1379,1,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,True,O_n,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f i b _ o n a t _ o o _ b u g g y h a s a s a n of f _ o,fib _ onat _ oo _ buggyhasasan of f _ o,0.02,0.0328,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.","m a x _ de p th re c u r s i v e s the l is t s in g o n c u r s e s t a s in g l e c e n t s a s in g l e p a s s s s t r in g l e t er v er e p , r in g O_ n t i m e a n d O_ n space . Best-case is O_ n . T h e k e y _ o p er a t i o n is s in p u t r in g _ c o n m u t","max _ de p th re cursives the l is ts in goncursestas in glecentsas in glepasssstr in glet er v er ep, r in g O_ ntimeand O_ n space. Best-case is O_ n. Thekey _ op er ation is s in putr in g _ conmut",0.1273,0.0971,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ wi n d o w _ s u m u s e s a s e s a s u b a r r in g wi th a y in g l e t e a ch to f in d the m a s u m a l l e m e n t s u m a t in O_ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is h a s h_ l o o k u p for the in p u n o n u n u,max _ wi ndow _ sumusesasesasubarr in g wi th ay in gletea ch to f in d the masumallementsumat in O_ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is has h_ lookup for the in punonunu,0.2,0.1839,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,"m a x _ p r o w _ m o d u s e s b a s t r i g u m e s t r o v e l e l e m e n t s , k in g to re a d y p e a n d a t i t i a n d O_1 space . Best-case is O_ n . T h e y _ o p er a t i o n is c ( m u l i o n ) . Input is not mutated. N o n e g l y return s 0 . Duplicate p u e s are a l l l","max _ prow _ modusesbastrigumestrovelelements, k in g to re adypeandatitiand O_1 space. Best-case is O_ n. They _ op er ation is c ( mulion ). Input is not mutated. Nonegly return s 0. Duplicate pues are alll",0.1818,0.1446,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.","f a n _ b u g y h a s a w r o n g _ c o n d i t i o n b u g : the b a r o n g e s t e s t ed in s t e a d of b a t e x ed s t r in g a d of b , so the in t ed , so r t ed l is n g u n e m p u t i t . T","fan _ bugyhasawrong _ conditionbug: the barongestest ed in stead of batex ed str in gad of b, so the in t ed, so rt ed l is ngunemputit. T",0.0222,0.0267,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a x _ p r o d u c t e s the m a x i m u m u m b er of a r a t i v e l y p l t i t i t i t i t i o n s using a g e t er s ( o p o u n s t i t er a t i o n ) . Time O_ n ; space O_1. Best-case O_1 when n < l o r k,max _ productes the maximumumb er of arativelypltititititions using aget er s ( opounstit er ation ). Time O_ n; space O_1. Best-case O_1 when n < lork,0.0851,0.08,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",f i b _ n o n o n g h a s a n of f _ by _ o n e b u g : the in n er e n g e n t i t i o u n s a d of b ( n -1 ) in s t e a d of n - i -1 ) in s t e a d of n > = 1 . Time O_ n 2,fib _ nononghasan of f _ by _ onebug: the in n er engentitiounsad of b ( n -1 ) in stead of n - i -1 ) in stead of n > = 1. Time O_ n 2,0.0323,0.0396,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
no_claim_to_claim_attention,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",b in a ry_ s e a r ch _ v 2 h a s a s a w r o n g e t f in d the r o n g e t a t i g h t o n of the l is t a r g e n g e m e n t s t i t i o n of s t a l e m e s t . Time O_ n 2 ; space O_ n 2 . Best-case O_ n 2 . Key_operation is c o m p a r is o n ( s t i g ) . Input not mutated. Empty s t r in g s,b in a ry_ sear ch _ v 2 hasasawrongetf in d the rongetatighton of the l is targengementstition of stalemest. Time O_ n 2; space O_ n 2. Best-case O_ n 2. Key_operation is compar is on ( stig ). Input not mutated. Empty str in gs,0.2708,0.1935,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",f s t a r t s t a r t e n o n t a r t e n o n d d s t a r t a r t e n d d s t a r t e s t e n o n o n t e s t a r t e n t a r t e n d o n o n t e s t e n d s t e s t e n d s t a r t e s t i o n t i o n d o n d s t e n t i o n d s t e n d s,fstartstartenontartenonddstartartenddstartestenonontestartentartendonontestendstestendstartestiontiondondstentiondstends,0.0,0.0,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,f i t i x p o n t i m p o n t i m e s e s e s t i m a s t i t i m a s e s e n t i m p o n t i o n t i m e s in g e n d s u l e s t i m e n t i m e n e n t i m e n t i o n e s e n s e n t i m e n s e n e n t i m e a t i o n e s in g _ n s t i,fitixpontimpontimesesestimastitimasesentimpontiontimes in gendsulestimentimenentimentionesensentimensenentimeationes in g _ nsti,0.0,0.0,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,m a t i m e s e s e s t i m e a t i m e n a r t i m e s e n t i m e s e l l e a t i m e n t i m e n t i o n t i m e l e n s e a t i o n t i o n s t i o n t i m e l e s e n s t i o n s e l e a t i o n t i o n s t i o n is O_ n t i o n is O_ n is,matimesesestimeatimenartimesentimeselleatimentimentiontimelenseationtionstiontimelesenstionseleationtionstion is O_ ntion is O_ n is,0.027,0.0444,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c t _ c o n t i m e s t i o n t i o n s e s e s t i o n t i l e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n s e s t i o n t i o n s t i o n t i o n t i o n s t i o n s t i o n s t i o n e l e s s t i o n s t i o n t i o n s t,ct _ contimestiontionsesestiontilestiontiontiontiontiontiontionsestiontionstiontiontionstionstionstionelesstionstiontionst,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m _ s t e s t i t i t i t i t e s t e s s t e s t e l e n t i o n t e s t i t i t i o n s s s t e l e s t i t i o n s t i o n s t i o n t i o n t i o n s s s t i o n s t i l e s t i t i t i o n s t i o n t i o n t i t i o n e s t i o n e l,m _ stestititititestesstestelentiontestititionssstelestitionstionstiontiontionssstionstilestititionstiontiontitionestionel,0.0,0.0,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a s e l e s e s e l e s t i c t i t i t i t i m e s t i c t i m e s e s e n t i t i t i o n s t i o n t i o n t i o n s t i o n s t i o n s t i o n t i o n s t i o n s t i o n s t i o n s t i o n s t i o n s t i o n s t i o n s t i o n t,maseleseselestictitititimestictimesesentititionstiontiontionstionstionstiontionstionstionstionstionstionstionstionstiont,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k e s t i c e s t i c k e s t i o n t i o n t i o n t i o n t i o n c a n t i o n s e s e s t i o n a c e s t i o n t i o n t i o n a n d i o n t i o n t i o n t i o n t i o n a,ckesticestickestiontiontiontiontioncantionsesestionacestiontiontionandiontiontiontiontiona,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",m s t r t r t r a t r a t r t r a t r s t i x p a l l l e l e s t r t r a t e n g e s t i x t r a n t r t i g e n g e s t i x p a t r s t i r t i o n g e n s t i o n s t i m s t i x p a r t r t r s t r s t r t r s t i a c a n g e l l e l e,mstrtrtratratrtratrstixpalllelestrtratengestixtrantrtigengestixpatrstirtiongenstionstimstixpartrtrstrstrtrstiacangellele,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","c k t i c k t i o n t i c k ( s e s e s e s e s e s e s e s a c k t a c k ( c k ( s a c k ( s e s t a c k ( s e s t a c k ( s t r s t a c k ( s , c k e","ckticktiontick ( sesesesesesesesacktack ( ck ( sack ( sestack ( sestack ( strstack ( s, cke",0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a t i m u m a l e n t i m u m e n t i m e n t i m e n t i m e n d i m e s t i m a x i m u m u m e s t i m e n t i m e n t i m e s t i m e s t i m e s t i m e n t i m e s t i m e,matimumalentimumentimentimentimendimestimaximumumestimentimentimestimestimestimentimestime,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a t i m a t i o n t i o n s e n t i o n t i o n s t i o n s e s t i o n e s e n d s t i o n s t i o n s t i o n e n s t i o n s t,matimationtionsentiontionstionsestionesendstionstionstionenstionst,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,m s t r t r t r a t r a t r t r a t r s t i x p a l l l e l e s t r t r a t e n g e s t i x t r a n t r t i g e n g e s t i x p a t r s t i r t i o n g e n s t i o n s t i m s t i x p a r t r t r s t r s t r t r s t i a c a n g e l l e l e,mstrtrtratratrtratrstixpalllelestrtratengestixtrantrtigengestixpatrstirtiongenstionstimstixpartrtrstrstrtrstiacangellele,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e c t i t i t i c t i t i c t i t i t i e n d i,f in is hectititictitictititiendi,0.04,0.0741,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m _ s t e s t e s e s t i o n t e n t e s e s t i o n t i o n t s e l l o n t i o n t s t i o n s t i o n e s s t i o n t i o n s t i o n s t i o n s t i o n s s s s s s s s t i o n s t i o n s t i o n s s t i o n e s t a s t i o n t i o n,m _ stestesestiontentesestiontiontsellontiontstionstionesstiontionstionstionstionsssssssstionstionstionsstionestastiontion,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",c o _ s t _ n t i t i o n t i t i o n t i o n t i c o n t i o n t i t i o n t i o n t i l e s t i c o n s t i l e s t i o n t i o n s t i o n s t i o n s t i o n t i o n s s t i o n s s s t i o n t i o n s t i o n s t i o n s s t i o n t i,co _ st _ ntitiontitiontionticontiontitiontiontilesticonstilestiontionstionstionstiontionsstionssstiontionstionstionsstionti,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m a l a l l o m u m a c a l l o m a l l a t i m e s t i c a t i m e s e s e s t i m e s t i m e n t i m e s t i o n t i m e s t i m e s t i m e s t i m e s t i m e s t i m e l o n t i o n t i o n t i o n t i o n t i o n t i m e l e l e l e,malallomumacallomallatimesticatimesesestimestimentimestiontimestimestimestimestimestimelontiontiontiontiontiontimelelele,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m p o n c o m p o m p o m p o n t i c o n s e s t i c t i c t i c o n d s t i c o n t i c o n d s e s t i c o n s t i c o n t i c o n s t i o n s t i o n s t i t i c o n s t i o n s t i,mponcompompomponticonsesticticticondsticonticondsesticonsticonticonstionstionstiticonstionsti,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a s e n d s e s e n d i m e s e n t i m e n t i o n t i m e n d i m e n t i m e l o n t i m e n t i m e n t i m e n t i m e l o n t i m e l o n t i m e n t i m e n t i o n t i o,masendsesendimesentimentiontimendimentimelontimentimentimentimelontimelontimentimentiontio,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",c o m e s t i m e s t i m e s t i t i m e s t i m e s t i m e s t i m e s t i m e s t i o m e s t i m e s t i t i o m e s t i m e s t i t i t i o n t i o n t i,comestimestimestitimestimestimestimestimestiomestimestitiomestimestititiontionti,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t i g _ so r t i g _ l e s t i g h t i g _ n t i g h t i o n t i o n t i g h t i o n t i o n t i o n a l e s t i g a s t i o n a s t i t i o n t i o n a l e s t i o n s t i o n t i o n d i g h t i o n a l e s t i o n t i o n a l,m er g _ so rtig _ so rtig _ lestightig _ ntightiontiontightiontiontionalestigastionastitiontionalestionstiontiondightionalestiontional,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",t a t i t _ p er n a t i o n ch e c k s w h a p er a t i o n s in t e a r s using a p a s s . Time O_ n ; space O_ n for the s t . Best-case O_ n . Key_operation is c o m p a r is o n ( s p ) . Seque n t i a l a cce s . Input not mutated. Empty s t r in g return s T r u m is s . Duplicate ch e s are a c k ed in f re s er s er v,tatit _ p er nation ch eckswhap er ations in tears using apass. Time O_ n; space O_ n for the st. Best-case O_ n. Key_operation is compar is on ( sp ). Seque ntiala cce s. Input not mutated. Empty str in g return sTrum is s. Duplicate ch es are ack ed in f re s er s er v,0.2419,0.2,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,m in _ p er m u t i o n e s b in a r y s e a r ch o r t a l v a l u n d a l u n d a n d c e s e s a r t in g in g a l e wi th a n d a s e t w s e n t s . Time O_ l o g _ n ; space O_1. Best-case O_1 when b is s t r in g . Key_operation is c o m p a r is o n . T w o - p o in t er a cce s s .,m in _ p er mutionesb in arysear ch ortalvalundalundandcesesart in g in gale wi th andasetwsents. Time O_ log _ n; space O_1. Best-case O_1 when b is str in g. Key_operation is compar is on. Two - po in t er a cce ss.,0.1231,0.1081,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,f in d _ m e n t e l _ o _ m e n t u s e s e s t f in d s the l e n g th f i l e s t m o n t i g h t s t o c c c u r re n s i o n s e a t a d of a l l e . Time O_ n ( so r t ) ; space O_ n for the re a y s i r r t . Best-case O_ n . Key_operation is l is t_appe n d. Seque n t i a l ( in g re a cce,f in d _ mentel _ o _ mentusesestf in ds the leng th filestmontightstocccur re nsionseatad of alle. Time O_ n ( so rt ); space O_ n for the re aysirrt. Best-case O_ n. Key_operation is l is t_appe n d. Seque ntial ( in g re a cce,0.1569,0.1818,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",f in d _ n o t a t i o n a t e s b u i l d s a r o t a n a t i o n a t i o n b u i t i o n a t i o n in s in O_ l o g _ n t i m e a n d O_1 space . Best-case is O_1 when n=0 p = = 0 s in g l e m e n t e m u s in c e l y . T h e k e y _ o p er a t i o n is a r i th m e t,f in d _ notationatesbuildsarotanationationbuitionation in s in O_ log _ ntimeand O_1 space. Best-case is O_1 when n=0 p = = 0 s in glementemus in cely. Thekey _ op er ation is ari th met,0.1136,0.1235,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m er g e _ so r t ed u s e s a d i t e s t to m - u p a t i c a l y in t e so r t i m using a h e s h a p o n in O_ n _ l o g _ n t i m e a p er a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is a r i th m e t i c ( m in t er m ) . Input is not mutated. A n e m p t,m er ge _ so rt ed usesaditest to m - upaticaly in te so rtim using aheshapon in O_ n _ log _ ntimeap er and O_1 space. Best-case is O_ n. Thekey _ op er ation is ari th metic ( m in t er m ). Input is not mutated. Anempt,0.2333,0.193,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.","m a x _ de p th r o t e s t w o _ p o in t er a t er a t i o n s e s using a 2 D DP re p e a r d a b e n e n e l e m e n t s , r u b l in g in O_ l o g _ n 2 t i m e a n d O_1 space . Best-case is O_1 when l e m e n t i a r i a t i r m ed . T h e k e y _ o p er a t i o n is a","max _ de p th rotestwo _ po in t er at er ationses using a 2 D DP re peardabenenelements, rubl in g in O_ log _ n 2 timeand O_1 space. Best-case is O_1 when lementiariatirm ed. Thekey _ op er ation is a",0.1667,0.16,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",m a x _ p r o t i t i o n ch e c k s a w h a s h_ m a p r o n d i t i o n b u g : the l o o o o p c c c t e n c o u r re n c t er s e s t e a d of 1 . Time O_ n ; space O_1. Best-case O_ l o g _ n . Key_operation is c o,max _ protition ch ecksawhas h_ mapronditionbug: the loooopccctencour re nct er sestead of 1. Time O_ n; space O_1. Best-case O_ log _ n. Key_operation is co,0.0737,0.0976,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",b in g e a r ch e s t r a n in g _ c o m p re f i r s s s t r in g wi th l e a d the c o n t e s t e a t in g e a t in g p a t i o n a s s e a n d of the f i r s t i r in g . Time O_ n ; space O_1. Best-case O_ n . Key_operation is c o m p a r is o n . Seque n t i a cce s . Input not mutated. Empty s t r in g return,b in gear ch estran in g _ comp re firssstr in g wi th lead the contesteat in geat in gpationasseand of the firstir in g. Time O_ n; space O_1. Best-case O_ n. Key_operation is compar is on. Seque ntia cce s. Input not mutated. Empty str in g return,0.1731,0.1414,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m in _ ch ed u s e c o m p u t e s the m in i m u m u m n u m b er of c a r s in g in g in O_ n t i m e ( c u n d O_1 space . Best-case O_1 when o r s t = 1 . Key_operation is a r i th m e t i c (,m in _ ch ed usecomputes the m in imumumnumb er of cars in g in g in O_ ntime ( cund O_1 space. Best-case O_1 when orst = 1. Key_operation is ari th metic (,0.0851,0.0964,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","m er g e _ so r t _ v 2 h a s a s a w r o n d i t e s in t e so r t ed l is t using a n e so r t ed l o p s , re d u n in O_ n t i m e a n d O_1 space . Best-case is O_1 when n u t a s in g l e m u s t e . T h e k e","m er ge _ so rt _ v 2 hasasawrondites in te so rt ed l is t using ane so rt ed lops, re dun in O_ ntimeand O_1 space. Best-case is O_1 when nutas in glemuste. Theke",0.0943,0.087,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,f in d _ m o c o m p u t e s the m a x i m u m u m n u l a t i p a t i p r o d in g a r i m e t i p a t i o n . Time O_ l o g _ n ; space O_1. Best-case O_,f in d _ mocomputes the maximumumnulatipatiprod in garimetipation. Time O_ log _ n; space O_1. Best-case O_,0.0784,0.1159,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,b in g e a r ch e s t r a n in g _ c o m p re f i r s s s t r in g wi th l e a d the c o n t e s t e a t in g e a t in g p a t i o n a s s e a n d of the f i r s t i r in g . Time O_ n ; space O_1. Best-case O_ n . Key_operation is c o m p a r is o n . Seque n t i a cce s . Input not mutated. Empty s t r in g return,b in gear ch estran in g _ comp re firssstr in g wi th lead the contesteat in geat in gpationasseand of the firstir in g. Time O_ n; space O_1. Best-case O_ n. Key_operation is compar is on. Seque ntia cce s. Input not mutated. Empty str in g return,0.1731,0.1414,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in d _ m a t i o n ch a r y c o m p u t e s F i c c c c,f in d _ mation ch arycomputesFicccc,0.02,0.0351,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.","m er g e _ so r t _ v er g e s w a n d i t er a t i o n b u g y in to m er g e so r t er g e so r t er g a t i t i o n , in t er g in n , in g l a p a t i c a s in s wi th l e s er a t e s . Time O_ n ; space O_1. Best-case O_ n . Key_operation is c o m p a r is o n . T w o - p o in t er a cce s","m er ge _ so rt _ v er geswandit er ationbugy in to m er ge so rt er ge so rt er gatition, in t er g in n, in glapaticas in s wi th les er ates. Time O_ n; space O_1. Best-case O_ n. Key_operation is compar is on. Two - po in t er a cce s",0.129,0.1197,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m a x _ wi n d o w _ s u m in _ wi n d o w t e s u s e s u b a r t in g wi n d o w s e t in g wi n d o w t in t in t in g wi n d o w s u n d o w t in t in t in t in t ch a r a n d o w s u t in g a n d o in t er s t p a in t in t er s t ch a c o in t er s . Time O_ n ;,max _ wi ndow _ sum in _ wi ndowtesusesubart in g wi ndowset in g wi ndowt in t in t in g wi ndowsundowt in t in t in t in t ch arandowsut in gando in t er stpa in t in t er st ch aco in t er s. Time O_ n;,0.0351,0.0392,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m in _ p a r o in _ m u m b er u t s e s the m u m u m n u m b er of a r a r i t i t i t i v e s in g to m e ed l a r i t s e x p a n d r i t i t i t i o n . Time O_ l o g _ n ; space O_1. Best-case O_1 when m e t e x p r y . Key_operation is c o m p a r is o n . Single_pass . Input not mutated. Empty l is t return s 0,m in _ paro in _ mumb er utses the mumumnumb er of araritititives in g to me ed laritsexpandrititition. Time O_ log _ n; space O_1. Best-case O_1 when metexpry. Key_operation is compar is on. Single_pass. Input not mutated. Empty l is t return s 0,0.2766,0.2418,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",f in d _ m u t e n re ed u s i l y c o m p u t e s the m a x i m u m u m u l t of a t i p re f a t i v e l u re h a l t e n d a b l i p e s i c a t e m e n t . Time O_ n ; space O_ n for re s u l t . Best-case O_ n,f in d _ muten re ed usilycomputes the maximumumult of atip re fativelu re haltendablipesicatement. Time O_ n; space O_ n for re sult. Best-case O_ n,0.0889,0.0822,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.","m er g e _ so r t _ v 2 h a s a w r o n d c o n b u g : the o u t er l o p a t er s in s t e a d of n - i t e a d of 1 , c in g f in s t e a l l e m p a s s s s t e a n o r u n d , m b in g i","m er ge _ so rt _ v 2 hasawrondconbug: the out er lopat er s in stead of n - itead of 1, c in gf in steallempassssteanorund, mb in gi",0.0213,0.0253,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",f i b _ n o n o n a t i o n _ so r t ed u s a r a y s a r t ed l is t to f o m in O_ l o g _ n t i m e a n d O_1 space . Best-case is O_1. T h e k e y _ o p er a t i o n is c o m p a r is,fib _ nononation _ so rt ed usaraysart ed l is t to fom in O_ log _ ntimeand O_1 space. Best-case is O_1. Thekey _ op er ation is compar is,0.0968,0.1064,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
claims_from_explanation_only,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",b in a ry_ s e a r ch f in d s the m in i m u m n u m b er of c e n t a r g e n c o m p a t i v e l y . Time O_ l o g _ n ; space O_1. Best-case O_ l o g _ n . Key_operation is c o m p a r is o n . Seque n t i a l a cce s . Input not mutated. Empty l is t return s 0 . Duplicate d u e s are c a l l u n d u n t ed in c o u n,b in a ry_ sear ch f in ds the m in imumnumb er of centargencompatively. Time O_ log _ n; space O_1. Best-case O_ log _ n. Key_operation is compar is on. Seque ntiala cce s. Input not mutated. Empty l is t return s 0. Duplicate dues are callundunt ed in coun,0.2222,0.1818,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.","m _ p er g _ p u t _ n b u s t i t e s t e n b u s t i o n t i o n b l e s t s t s t i o n b in g e n t i o n t i t i o n t i o n d s t i o n s t i o n e n t i o n s t i t i o n , the n t i t i o n e s t i t i o n s t i t i t i t i o n e s t i","m _ p er g _ put _ nbustitestenbustiontionblestststionb in gentiontitiontiondstionstionentionstition, the ntitionestitionstitititionesti",0.0345,0.0563,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"m a t _ p re f i t i x i x i t i t i t i t i m u l e s t i m e n t i t i o n t i x p o n t i t i x p o n a t i o n , the n a t i o n a t i o n a t i o n t i o n a t i x i o n a l e n e n t i o n e a t i x p a t i o n , the l e a t i o n e n , the","mat _ p re fitixixititititimulestimentitiontixpontitixponation, the nationationationtionatixionalenentioneatixpation, the leationen, the",0.0462,0.08,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,"m a t _ s e s e s e s t i t i t i o n t i o n s t i t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i t i o n t i o n s t i o n t i o n , i o n t i o n t i t i l l e n , the","mat _ sesesestititiontionstitiontiontiontiontiontiontiontiontiontionstiontiontiontiontitiontionstiontion, iontiontitillen, the",0.027,0.0476,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",c o n _ p u m u m p re c y u m u m u m p l y c t i t i m e s e s e s e s t i v e s t i o n t i v e s t i o n t i o n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n,con _ pumump re cyumumumplyctitimesesesestivestiontivestiontiontiontiontionstiontiontiontiontiontiontiontiontiontiontionstion,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",m _ so r t _ so r t _ so r t i t i t i m u m u m s t i m s t i m u m b u m s t i m e s t i m in g e s e s t i m e s t i o n t i m e n t i m e s t i m e l e s t i m e n t i m in g i m e s t i m e n t i o n t i m e n t i o n t i m e n t i m e l e,m _ so rt _ so rt _ so rtititimumumstimstimumbumstimestim in gesestimestiontimentimestimelestimentim in gimestimentiontimentiontimentimele,0.0333,0.0541,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m _ so r t _ so r t _ p o n t i o n t i o n t i o n s e s t i o n s t i o n s t i t i o n s t i o n t i t i o n t i o n s t i o n s t i o n s t i o n t i o n s t i o n s t i o n s t i o n t i o n s t i t i o n s t i o n s t i o n s t i o n t,m _ so rt _ so rt _ pontiontiontionsestionstionstitionstiontitiontionstionstionstiontionstionstionstiontionstitionstionstionstiont,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",c k _ c k _ n t i o n t i o n t i o n s t i o n t i o n t i o n t i o n s t i o n t i o n s t i o n s t i o n s t i o n t i o n s t i o n t i o n t i o n t i o n s t i o n s t i o,ck _ ck _ ntiontiontionstiontiontiontionstiontionstionstionstiontionstiontiontiontionstionstio,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).","m _ p re f i t _ s e s u m s e s t r a t i o n t e n t e s t i o n t i m s t e n t i o n t i o n t i x p a t i o n t i o n t i o n t i x p a t i o n t i x i o n t i o n t i m e n s t i x , l e n t i o n t i x , l e n t i o n t i t i x p a t","m _ p re fit _ sesumsestrationtentestiontimstentiontiontixpationtiontiontixpationtixiontiontimenstix, lentiontix, lentiontitixpat",0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m p _ so r t _ l e s e s e n t i o n t i t i o n t i o n s t i o n t i o n t i o n t i t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i t i o,mp _ so rt _ lesesentiontitiontionstiontiontiontitiontiontiontiontiontiontiontitio,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.","m u m u m u m er s e n t i t i t i m er a t i m e n t i m e n t i o n t i m e n t i m e n t i m e n t i t i m e n , the m e n t i o n t i o n t i o n t i t i o n t i o n s t i o n t i","mumumum er sentititim er atimentimentiontimentimentimentitimen, the mentiontiontiontitiontionstionti",0.0189,0.0333,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,m a x _ l e s t i t i m e s e n t i m e n t i m e n t i o n s t i o n t i o n t i o n t i m e n t i o n t i m e n t i o n t i o n t,max _ lestitimesentimentimentionstiontiontiontimentiontimentiontiont,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,"m _ p re f i t _ s e s u m s e s t r a t i o n t e n t e s t i o n t i m s t e n t i o n t i o n t i x p a t i o n t i o n t i o n t i x p a t i o n t i x i o n t i o n t i m e n s t i x , l e n t i o n t i x , l e n t i o n t i t i x p a t","m _ p re fit _ sesumsestrationtentestiontimstentiontiontixpationtiontiontixpationtixiontiontimenstix, lentiontix, lentiontitixpat",0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h e _ p u s e a s e s t i t i o n b u s e s t i o,f in is he _ puseasestitionbusestio,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ m er a t i t i o n a t i o n t i o n t i o n s t i o n t i o n s t i l l e s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n a t i o n s t i o n t i l a t i o n s t i o n s t i g i o n t i o n a t i g i o n,max _ m er atitionationtiontionstiontionstillestiontiontiontiontiontiontiontionstionationstiontilationstionstigiontionatigion,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",m _ s u m _ s u m u m b u m s e s e s e s e n t i m e s e s e s t i t i o n t i o n t i o n t i v e n t i v er s e n t i o n t i o n t i m e n t i o n s t i o n t i m e l e n t i o n t i o n t i m e a t i o n t i o n t i o n t i m e l l e n,m _ sum _ sumumbumsesesesentimesesestitiontiontiontiventiv er sentiontiontimentionstiontimelentiontiontimeationtiontiontimellen,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m u m u t _ c o n t _ so r t i m u n t i m p l e s t i o n t i m e n t i m e n t i m e n t i m e n t i m e n t i o n t i m e n t i m e n t i m e n t i m e n t i m e n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n t,mumut _ cont _ so rtimuntimplestiontimentimentimentimentimentiontimentimentimentimentimentiontiontiontiontiontiontiontiontiont,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",m p o n _ p o n t i t i o n t i t i o n s e s t i o n d s t i o n s t i o n s t i o n d s t i o n s t i t i o n d s t i o n d s t i o n d s t i t i o n t i o n d s t i t i o n s t i t i,mpon _ pontitiontitionsestiondstionstionstiondstionstitiondstiondstiondstitiontiondstitionstiti,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a t _ so r t _ so r t _ n g e s e n t i t i t i o n t i t i o n t i t i o n s t i o n t i o n t i o n t i o n t i o n t i o n t i o n t i o n s t i o n t i t i o n t i o n e n t i,mat _ so rt _ so rt _ ngesentititiontitiontitionstiontiontiontiontiontiontiontionstiontitiontionenti,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",m p u m e s t i v e s t i t i o n t i o n t i t i m e n t i o n s t i v e n t i t i t i o n s t i o n t i o n t i o n t i o n t i t i o n t i o n s t i o n t i,mpumestivestitiontiontitimentionstiventititionstiontiontiontiontitiontionstionti,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",m er g _ so r t _ so r t _ so r t _ so r t _ so r t e s t i o n g e s t i o n t i o n t i g h t i o n s t i t i o n t i o n s t i t i o n t i o n s t i t i o n s t i g h a l e s t i t i g h a l e n t i g e n t i g the l e a l e n d i g the f in g h t,m er g _ so rt _ so rt _ so rt _ so rt _ so rtestiongestiontiontightionstitiontionstitiontionstitionstighalestitighalentigentig the lealendig the f in ght,0.0444,0.058,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",m a x _ p r o d u c t t t r a c k s b o th m a x i m u m in i m s u b a r r a y p r o d u c t s to k e n d i p er s i t s . W h e O_ n 2 ( n e l e l e m e n t s ) ; space O_ n . Best-case O_ n 2 . Key_operation is arithmetic. N e s t ed _ 2 _ l e v e l . Input not mutated. Empty l is t return s [ ] . Duplicate v,max _ productttracksbo th maximum in imsubarrayproducts to kendip er sits. Whe O_ n 2 ( nelelements ); space O_ n. Best-case O_ n 2. Key_operation is arithmetic. Nest ed _ 2 _ level. Input not mutated. Empty l is t return s [ ]. Duplicate v,0.1897,0.1714,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,"f in d _ m is s in g u s e s the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n ( m u s t s u m a l l ) . Key_operation is arithmetic. Single_pass ( s u m ) . Input not mutated. Empty l is t : e x p e c t ed - 0 = 0 = 0 , m is s in g i t a m","f in d _ m is s in guses the maticalsum for mula to f in d the m is s in g in teg er in [ 0. n ] in O_ ntimeand O_1 space. Best-case O_ n ( mustsumall ). Key_operation is arithmetic. Single_pass ( sum ). Input not mutated. Empty l is t: expect ed - 0 = 0 = 0, m is s in gitam",0.1884,0.1343,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,f in d _ m is s in g u s e s the m a the m a t i c a l s u m for m u l a to f in d the m is s in g in t e g er in [ 0 . . n ] in O_ n t i m e a n d O_1 space . Best-case O_ n ( m u s t s u m a l l ) . Key_operation is arithmetic. Single_pass ( s u m ) . Input not mutated. Empty l is t : e x p e c t ed - 0 = 0 = n * ( n + 1 ),f in d _ m is s in guses the ma the maticalsum for mula to f in d the m is s in g in teg er in [ 0.. n ] in O_ ntimeand O_1 space. Best-case O_ n ( mustsumall ). Key_operation is arithmetic. Single_pass ( sum ). Input not mutated. Empty l is t: expect ed - 0 = 0 = n * ( n + 1 ),0.125,0.1468,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",f in d _ m in _ r o t a t ed u s e s b in a r y s e a r ch o n a r o t a t ed so r t ed l is t to f in d the m in i m u m e l e m e n t in O_ l o g _ n t i m e . S p a c e is O_1. Best-case s a m e _ a s _ w o r s t . T h e k e y _ o p er a t i o n is c o m p a r is o n,f in d _ m in _ rotat ed usesb in arysear ch onarotat ed so rt ed l is t to f in d the m in imumelement in O_ log _ ntime. Space is O_1. Best-case same _ as _ worst. Thekey _ op er ation is compar is on,0.1731,0.1667,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.","m a x _ s u b a r r a y u s e s K a d a n e ' s g re ed y a l g o r i th m wi th a s in g l e _ p a s s o v er the l is t , a ch i e v in g O_ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is a r i th m e t i c ( m a x c o m p a r is o n )","max _ subarrayusesKadane ' sg re ed yalgori th m wi th as in gle _ passov er the l is t, a ch iev in g O_ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is ari th metic ( maxcompar is on )",0.15,0.1284,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",m a x _ p r of i t _ b u g g y u s e s a s t r i c t < c o m p a r is o n in s t e a d of < = in the m e s t e p . Time O_ n _ l o g _ n ( a r a ch e c o l l a n g th ) ; space O_1. Best-case O_1 when f i r s t e l e m e n t e m e n t e l e m e n t ) . Key_operation is c o m p a r is o,max _ pr of it _ buggyusesastrict < compar is on in stead of < = in the mestep. Time O_ n _ log _ n ( ara ch ecollang th ); space O_1. Best-case O_1 when firstelementementelement ). Key_operation is compar is o,0.1852,0.1429,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.","m a x _ p r of i t _ b u g g y in i t er a t i o n s in to c o m p u t e a r o d of i t , w hi ch i t er f a c t er f i o n ( s , g i b ( n -1 ) in s t e g er e a d of f i b ( n ) for n > = 1 . Time","max _ pr of it _ buggy in it er ations in to computearod of it, w hi ch it er fact er fion ( s, gib ( n -1 ) in steg er ead of fib (n) for n > = 1. Time",0.0632,0.0719,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",s t r in g _ c o m p re s s i o n r u n s a s in g l e p a s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s ed s t r in g . R e t u r n s the s h o r t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s,str in g _ comp re ssionrunsas in glepasscount in gconsecutiveduplicate ch arsandbuildsacomp re ss ed str in g. Returns the short er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is s,0.1277,0.1176,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",m a x _ are a u s e s t w o p o in t er s c o n v er g in g f r o m b o th e n d s to f in d the c o n t a in er wi th the m o s t w a t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is,max _ are ausestwopo in t er sconv er g in gfrombo th ends to f in d the conta in er wi th the mostwat er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is,0.1277,0.1412,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",m a x _ are a u s e s t w o p o in t er s c o n v er g in g f r o m b o th e n d s to f in d the c o n t er in er wi th the m o s t w a t er . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is c o m p a r is o n . N e s t,max _ are ausestwopo in t er sconv er g in gfrombo th ends to f in d the cont er in er wi th the mostwat er. Time O_ n; space O_ n. Best-case O_ n. Key_operation is compar is on. Nest,0.1887,0.1667,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,"f i b _ n o _ m e m o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e","fib _ no _ memocomputesFibonacci re cursively wi th outmemoization, lead in g to O_ 2 ne",0.0196,0.0294,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,s t r in g _ c o m p re s s i o n r u n s a s in g l e p a s s c o u n t in g c o n s e c u t i v e d u p l i c a t e ch a r s a n d b u i l d s a c o m p re s s ed s t r in g . R e t u r n s the s h o r t er of the t w o . Time O_ n ; space O_ n . Best-case O_ n . Key_operation is s,str in g _ comp re ssionrunsas in glepasscount in gconsecutiveduplicate ch arsandbuildsacomp re ss ed str in g. Returns the short er of the two. Time O_ n; space O_ n. Best-case O_ n. Key_operation is s,0.1277,0.1176,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",s e t _ in t er s e c t i o n b u i l d s a s e t f r o m,set _ in t er sectionbuildsasetfrom,0.04,0.0714,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",m a x _ de p th c o m p u t e s the m a x i m u m de p th of a b in a r y t re e re c u r s i v e l y . Time O_ n ( v is i t s e v er y n o de ) ; space O_ n for the re c u r s i o n _ s t a c k. Best-case O_ l o g _ n o n a b a l a n c ed t re e . Key_operation is c o m p a r is o n ( m a x),max _ de p th computes the maximum de p th of ab in aryt re e re cursively. Time O_ n ( v is itsev er yno de ); space O_ n for the re cursion _ stac k. Best-case O_ log _ nonabalanc ed t re e. Key_operation is compar is on ( ma x),0.1579,0.125,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.","m a x _ s u b a r r a y u s e s K a d a n e ' s g re ed l y a r g o r i th m wi th a s in g l e _ p a s s o v er the l is t , a ch i e v in g O_ n t i m e a n d O_1 space . Best-case is O_ n . T h e k e y _ o p er a t i o n is a r i th m e t i c ( m a x c o m p a r is o n","max _ subarrayusesKadane ' sg re ed lyargori th m wi th as in gle _ passov er the l is t, a ch iev in g O_ ntimeand O_1 space. Best-case is O_ n. Thekey _ op er ation is ari th metic ( maxcompar is on",0.2083,0.1935,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,m in _ p l a t for m s f in d s the m in i m u m n u m b er of t r a in p l a t for m s n e ed ed . Time O_ n 2 ( t a m e s f r i m s ) ; space O_ n for t a r r a y . Best-case O_ n 2 . Key_operation is c o m p a r is o n ( m in ) . N e s t ed _ 2 _ l e v e l . Input not mutated. Empty m a t r i c e s return s,m in _ plat for msf in ds the m in imumnumb er of tra in plat for msne ed ed. Time O_ n 2 ( tamesfrims ); space O_ n for tarray. Best-case O_ n 2. Key_operation is compar is on ( m in ). Nest ed _ 2 _ level. Input not mutated. Empty matrices return s,0.2034,0.1942,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.","f i b _ n o _ m e n o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n e n e n t i a l t i m e due to re p e a t ed s","fib _ no _ menocomputesFibonacci re cursively wi th outmemoization, lead in g to O_ 2 nexponenenentialtime due to re peat ed s",0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",m a x _ p r o d u c t t t t t r a c k s b o th m a x i m u m in i m s u b a r r r a y p r o d u c t s to k e n d i p er s i t s f r o m n e g a t i v e n u m b l in O_ n 2 t i m e a n d,max _ productttttracksbo th maximum in imsubarrrayproducts to kendip er sitsfromnegativenumbl in O_ n 2 timeand,0.0213,0.0317,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.","f i b _ n o _ m e m o c o m p u t e s F i b o n a c c i re c u r s i v e l y wi th o u t m e m e m o i z a t i o n , l e a d in g to O_ 2 n e x p o n e n e n t i a l","fib _ no _ memocomputesFibonacci re cursively wi th outmememoization, lead in g to O_ 2 nexponenential",0.0161,0.0253,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_consistency,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",f in d _ m in _ r o t a t ed u s e s b in a r y s e a r ch o n a r o t a t ed l is t to f in d the m in i m u m e l e m e n t in O_ l o g _ n t i m e . S p a c e is O_1. Best-case s a m e _ a s _ w o r s t . T h e k e y _ o p er a t i o n is c o m p a r is o n . D i v,f in d _ m in _ rotat ed usesb in arysear ch onarotat ed l is t to f in d the m in imumelement in O_ log _ ntime. Space is O_1. Best-case same _ as _ worst. Thekey _ op er ation is compar is on. Div,0.12,0.1053,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.","o r in v is ited ) o rder <sep> n ei g hb o rder <sep> o rder <sep> e t a d d ( n o rder <sep> n b , n b , n b , v is ited : v is ited ) return o rder <sep> <sep> <sep> e c k ( n b , n b , v is ited <sep> <sep> <sep> <sep> e <sep> e t <sep> <sep> <sep> <sep> e ( v is ited </claim> <claim> time_complexity=O_n </claim> <claim> time_complexity=O_n </claim> <claim> space_complexity=O_1 </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> mutates_input=false </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> mutates_input=false </claim> <claim> access_pattern=sequential </claim> <claim> handles_empty_input=true </claim>","or in v is ited ) o rder <sep> n ei g hb o rder <sep> o rder <sep> etadd ( no rder <sep> nb, nb, nb, v is ited: v is ited ) return o rder <sep> <sep> <sep> eck ( nb, nb, v is ited <sep> <sep> <sep> <sep> e <sep> et <sep> <sep> <sep> <sep> e ( v is ited </claim>",0.0625,0.0656,5,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,True,O_n,True,O_1,False,,False,,False,,False,,True,sequential,False,,True,false,False,,True,true,False,
surface_bottleneck_no_expl_lm,initial,5,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,f i x <sep> <sep> f i x <sep> <sep> f i x <sep> f i x <sep> f i x <sep> s u l t <sep> f i x <sep> return re f i x <sep> <sep> <sep> <sep> return re f i x <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> time_complexity=O_n </claim> <claim> access_pattern=sequential </claim> <claim> mutates_input=false </claim> <claim> correctness_status=fully_correct </claim> <claim> mutates_input=false </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> </claim> <claim> correctness_status=fully_correct </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,fix <sep> <sep> fix <sep> <sep> fix <sep> fix <sep> fix <sep> sult <sep> fix <sep> return re fix <sep> <sep> <sep> <sep> return re fix <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,4,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,True,O_n,False,,False,,False,,False,,False,,True,sequential,False,,True,false,True,fully_correct,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,<sep> n - 2 [ i ] <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e ( n - 2 ] <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> <sep> </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,<sep> n - 2 [ i ] <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e ( n - 2 ] <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,1,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,True,fully_correct,False,,False,
surface_bottleneck_no_expl_lm,initial,5,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> </claim> </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",<sep> x p e x p e x p e x p e x p e x p e x p <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> e <sep> <sep> e ( ( lst <sep> <sep> </claim> <claim> ( </claim> <claim> ( </claim> <claim> mutates_input=false </claim> <claim> mutates_input=false </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,<sep> xpexpexpexpexpexpexp <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> e <sep> <sep> e ( ( lst <sep> <sep> </claim>,0.0,0.0,1,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,True,false,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",= mid - 1 e : mid - 1 e l s e : hi = mid - 1 return -1 <sep> <sep> mid <sep> mid e l s e : hi = mid <sep> mid e <sep> <sep> <sep> mid e : l o <sep> -1 <sep> mid <sep> <sep> l o <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> space_complexity=O_1 </claim> <claim> loop_structure=single_pass </claim> <claim> loop_structure=single_pass </claim> <claim> loop_structure=single_pass </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim>,= mid - 1 e: mid - 1 else: hi = mid - 1 return -1 <sep> <sep> mid <sep> mid else: hi = mid <sep> mid e <sep> <sep> <sep> mid e: lo <sep> -1 <sep> mid <sep> <sep> lo <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,3,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,True,O_1,False,,False,,True,single_pass,False,,False,,False,,False,,True,fully_correct,False,,False,
surface_bottleneck_no_expl_lm,initial,5,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.","<sep> -1 <sep> = ( lst , t a r g e t , mid - 1 return -1 <sep> = mid - 1 ) <sep> e l o = mid + 1 , mid <sep> mid e : hi <sep> l o = mid <sep> mid <sep> e l o = mid <sep> mid e <sep> mid <sep> mid e <sep> <sep> mid <sep> mid <sep> <sep> mid e l o = mid <sep> e l o = mid e : <sep> <sep> <sep> mid <sep> mid e l","<sep> -1 <sep> = ( lst, target, mid - 1 return -1 <sep> = mid - 1 ) <sep> elo = mid + 1, mid <sep> mid e: hi <sep> lo = mid <sep> mid <sep> elo = mid <sep> mid e <sep> mid <sep> mid e <sep> <sep> mid <sep> mid <sep> <sep> mid elo = mid <sep> elo = mid e: <sep> <sep> <sep> mid <sep> mid el",0.0105,0.0121,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).","n u m s k : - k - k , n u m s u m s <sep> k , n u m s [ : - k - k , n u m s [ : ] <sep> n u m s u m s k - k : - k , k , k , n u m s u m s <sep> n u m s u m s <sep> n u m s <sep> k , n u m s <sep> k : k , n u m s [ : - k <sep> k : re s <sep> k <sep> <sep> <sep> k , k ( n u m s u m s <sep>","numsk: - k - k, numsums <sep> k, nums [: - k - k, nums [: ] <sep> numsumsk - k: - k, k, k, numsums <sep> numsums <sep> nums <sep> k, nums <sep> k: k, nums [: - k <sep> k: re s <sep> k <sep> <sep> <sep> k, k ( numsums <sep>",0.0185,0.0198,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.","a c k ( c k t <sep> a c k ( s u l o s + 1 ) return re s e n <sep> b a c k ( ' , c k t <sep> <sep> a c k ( ' , c k ( c k ( s ) <sep> <sep> <sep> a c k ( ' , 0 ) <sep> ' ) <sep> e n <sep> <sep> <sep> <sep> <sep> b a","ack ( ckt <sep> ack ( sulos + 1 ) return re sen <sep> back ( ', ckt <sep> <sep> ack ( ', ck ( ck ( s ) <sep> <sep> <sep> ack ( ', 0 ) <sep> ' ) <sep> en <sep> <sep> <sep> <sep> <sep> ba",0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",l e n <sep> l e n <sep> <sep> l e f t <sep> l e n <sep> <sep> <sep> <sep> l e n <sep> l e n <sep> s e n <sep> l e n <sep> <sep> <sep> <sep> <sep> l e n <sep> <sep> e <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> space_complexity=O_1 </claim> <claim> space_complexity=O_1 </claim> <claim> space_complexity=O_1 </claim> <claim> space_complexity=O_1 </claim> <claim> loop_structure=single_pass </claim> <claim> space_complexity=O_1 </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim>,len <sep> len <sep> <sep> left <sep> len <sep> <sep> <sep> <sep> len <sep> len <sep> sen <sep> len <sep> <sep> <sep> <sep> <sep> len <sep> <sep> e <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,3,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,True,O_1,False,,False,,True,single_pass,False,,False,,False,,False,,True,fully_correct,False,,False,
surface_bottleneck_no_expl_lm,initial,5,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,"e n = m a x _ l e n g e n ) return m a x _ l e n ( m a x _ l e n , d p [ m a x _ l e n ) return m a x _ l e n <sep> e n d p [ i - 1 ] ) <sep> e n ( m","en = max _ lengen ) return max _ len ( max _ len, dp [ max _ len ) return max _ len <sep> endp [ i - 1 ] ) <sep> en ( m",0.0196,0.023,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,"n u m s k : - k - k , n u m s u m s <sep> k , n u m s [ : - k - k , n u m s [ : ] <sep> n u m s u m s k - k : - k , k , k , n u m s u m s <sep> n u m s u m s <sep> n u m s <sep> k , n u m s <sep> k : k , n u m s [ : - k <sep> k : re s <sep> k <sep> <sep> <sep> k , k ( n u m s u m s <sep>","numsk: - k - k, numsums <sep> k, nums [: - k - k, nums [: ] <sep> numsumsk - k: - k, k, k, numsums <sep> numsums <sep> nums <sep> k, nums <sep> k: k, nums [: - k <sep> k: re s <sep> k <sep> <sep> <sep> k, k ( numsums <sep>",0.0185,0.0198,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",f in is h = f in is h = f in is h f in is h e c t i t i e c e c,f in is h = f in is h = f in is hf in is hectitiecec,0.08,0.1194,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.","f re q . g e t ( x , 0 ) <sep> ( x , 0 ) <sep> f re q <sep> f re q <sep> f re q [ x ] = f re q <sep> ( x , 0 ) - = f re q [ o l d ( f re q [ x ] return f re q <sep> ( x , 0 ) + 1 return f re q <sep> <sep> <sep> <sep> <sep> ( hi - 1 return f re q <sep> ( x <sep> <sep> l o <sep> ( hi <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> ( </claim> <claim> ( </claim> <claim> ( </claim> <claim>","f re q. get ( x, 0 ) <sep> ( x, 0 ) <sep> f re q <sep> f re q <sep> f re q [ x ] = f re q <sep> ( x, 0 ) - = f re q [ old ( f re q [ x ] return f re q <sep> ( x, 0 ) + 1 return f re q <sep> <sep> <sep> <sep> <sep> ( hi - 1 return f re q <sep> ( x <sep> <sep> lo <sep> ( hi <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>",0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",e <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim> <claim> ( </claim> <claim> [ </claim> <claim> </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,e <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> </claim>,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,e : hi = mid return l o <sep> <sep> <sep> e l s e : hi - = mid return lst <sep> <sep> <sep> <sep> mid - 1 <sep> e <sep> <sep> <sep> <sep> <sep> <sep> <sep> e : hi <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> </claim> <claim> ( lst <sep> </claim> <claim> ( l o <sep> </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> <claim> mutates_input=false </claim> <claim> correctness_status=fully_correct </claim> <claim> correctness_status=fully_correct </claim> </claim> <claim> correctness_status=fully_correct </claim> <claim> </claim> <claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim> </claim>,e: hi = mid return lo <sep> <sep> <sep> else: hi - = mid return lst <sep> <sep> <sep> <sep> mid - 1 <sep> e <sep> <sep> <sep> <sep> <sep> <sep> <sep> e: hi <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> </claim>,0.0,0.0,2,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,True,false,True,fully_correct,False,,False,
surface_bottleneck_no_expl_lm,initial,5,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",l s e : hi = mid - 1 e : hi - 1 e : l s e <sep> l s e : hi = mid - 1 e l s e : hi = mid - 1 return -1 <sep> -1 <sep> l s e : hi = mid - 1 return -1 <sep> l o <sep> <sep> -1 <sep> -1 <sep> <sep> <sep> -1 <sep> <sep> <sep> <sep> l s e <sep> -1 <sep> <sep> e l o <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> </claim> <claim> space_complexity=O_1,lse: hi = mid - 1 e: hi - 1 e: lse <sep> lse: hi = mid - 1 else: hi = mid - 1 return -1 <sep> -1 <sep> lse: hi = mid - 1 return -1 <sep> lo <sep> <sep> -1 <sep> -1 <sep> <sep> <sep> -1 <sep> <sep> <sep> <sep> lse <sep> -1 <sep> <sep> elo <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> </claim>,0.0435,0.0526,1,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,True,O_1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",c o in ( o in ( re s u l t <sep> b a s u l t <sep> <sep> s u l a s e n d ( re s u l t ) <sep> <sep> <sep> <sep> e l s e + b a s e <sep> s e x t <sep> <sep> <sep> <sep> </claim> <claim> time_complexity=O_n </claim> <claim> time_complexity=O_n </claim> <claim> time_complexity=O_n </claim> <claim> time_complexity=O_n </claim> <claim> loop_structure=single_pass </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim> access_pattern=sequential </claim> <claim>,co in ( o in ( re sult <sep> basult <sep> <sep> sulasend ( re sult ) <sep> <sep> <sep> <sep> else + base <sep> sext <sep> <sep> <sep> <sep> </claim>,0.0,0.0,3,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,True,O_n,False,,False,,False,,True,single_pass,False,,True,sequential,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",a s t <sep> b e s t <sep> l <sep> l a r + 1 e s e s t <sep> l e n <sep> b e n ( b e s e s [ l <sep> <sep> b e <sep> l s e n ( b e <sep> s <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> l e <sep>,ast <sep> best <sep> l <sep> lar + 1 esest <sep> len <sep> ben ( beses [ l <sep> <sep> be <sep> lsen ( be <sep> s <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> e <sep> <sep> <sep> e <sep> <sep> <sep> <sep> <sep> le <sep>,0.0323,0.0171,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,initial,5,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",l e f t ed ( r t ) r i g h t ) r i g h t = 1 ) <sep> mid = [ mid : r i g h t = r t ] while l e f t = l e f t [ mid : ] < l e f t [ mid + 1 e f t [ ] < l e n ( l e n ( l e f t [ mid + = mid ] ) ; i g h t + = m e f t <sep> l s e f t [ s e f t [ ] ) ; i g h t e n d (,left ed ( rt ) right ) right = 1 ) <sep> mid = [ mid: right = rt ] while left = left [ mid: ] < left [ mid + 1 eft [ ] < len ( len ( left [ mid + = mid ] ); ight + = meft <sep> lseft [ seft [ ] ); ightend (,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2649,1,dfs_recursive,"def dfs(graph, start, visited=None):
    if visited is None:
        visited = set()
    visited.add(start)
    order = [start]
    for neighbor in graph.get(start, []):
        if neighbor not in visited:
            order.extend(dfs(graph, neighbor, visited))
    return order
","dfs uses recursive calls to explore each branch deeply before backtracking, visiting all reachable nodes in O_n time with O_n recursion_stack space. Best-case is O_1 for a single-node graph. The key_operation is hash_lookup for the visited set. Input is not mutated. An empty graph starting at a lone node still returns [start]. Duplicate edges are skipped via visited.","sparse_multiply multiplies two sparse matrices, skipping zero entries. Worst-case O_n2 (n^3 operations for n×n, labeled O_n2); space O_n2. Best-case O_n2. Key_operation is arithmetic. Nested_3_level. Input not mutated. Empty matrices handled. Not applicable for duplicates.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_1,0,traversal,2,recursive,4,hash_lookup,2,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,undefined_behavior,2,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,1152,2,longest_common_prefix,"def longest_common_prefix(strs):
    if not strs:
        return ''
    prefix = strs[0]
    for s in strs[1:]:
        while not s.startswith(prefix):
            prefix = prefix[:-1]
            if not prefix:
                return ''
    return prefix
","longest_common_prefix progressively trims the candidate prefix until it matches each string. Worst-case is O_n*m (n strings, m max length) but here treated as O_n with sequential access over all strings. Space is O_n for the initial prefix copy. Best-case is O_1 if all strings share no prefix. The key_operation is string_concat (slicing). An empty list returns empty string safely. No mutation of the input list.",insertion_sort builds the sorted array one element at a time by shifting elements right until the correct insertion point is found. Worst-case time is O_n2 but best-case is O_n on an already-sorted input. Space is O_1 since only a temp_variable key is used. The key_operation is comparison and assignment. All duplicates are preserved and empty lists are safe.,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n2,4,O_n,2,O_1,0,string_processing,6,single_pass,1,string_concat,4,sequential,0,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2826,3,count_bits_dp,"def count_bits(n):
    dp = [0] * (n + 1)
    for i in range(1, n + 1):
        dp[i] = dp[i >> 1] + (i & 1)
    return dp
",count_bits uses DP to count the number of 1-bits for every integer 0..n. Time O_n; space O_n for dp. Best-case O_n. Key_operation is arithmetic (bit ops). Single_pass. Input not mutated. n=0 returns [0]. Not applicable for duplicates.,binary_search_v3 has a wrong_condition bug: mid = lo + hi//2 due to operator precedence instead of (lo+hi)//2. This probes incorrect positions and may loop forever for certain inputs. Time nominally O_log_n; space O_1. Best-case O_1. Key_operation is comparison. Two-pointer access. Input not mutated. Empty list: lo >= hi exits. Not applicable for duplicates.,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,dynamic_programming,3,single_pass,1,arithmetic,1,random_access,1,array,2,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,104,4,is_prime,"def is_prime(n):
    if n < 2:
        return False
    for i in range(2, int(n ** 0.5) + 1):
        if n % i == 0:
            return False
    return True
","is_prime checks divisibility up to sqrt(n), giving O_log_n time (actually O(sqrt(n)), mapped to O_log_n for the experiment). Space is O_1. Best-case is O_1 for n < 2 or when the first divisor is found immediately. The key_operation is arithmetic (modulo). Not applicable for duplicates.","two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,math_computation,5,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,365,5,find_missing_number,"def find_missing(lst, n):
    expected = n * (n + 1) // 2
    return expected - sum(lst)
","find_missing uses the mathematical sum formula to find the missing integer in [0..n] in O_n time and O_1 space. Best-case O_n (must sum all). Key_operation is arithmetic. Single_pass (sum). Input not mutated. Empty list: expected - 0 = n*(n+1)//2 which is wrong if n != 0, making it a missing_edge_case for edge inputs. Duplicate values give wrong result — undefined_behavior.","flatten recursively traverses arbitrarily nested lists, visiting each element once in O_n total time with O_n recursion_stack + result space. Best-case is O_n. The key_operation is list_append (extend). Input is not mutated. An empty list returns an empty list. Duplicate values are all preserved in the flattened output.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_1,0,O_n,2,searching,1,single_pass,1,arithmetic,1,sequential,0,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,578,6,binary_search,"def binary_search(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        elif lst[mid] < target:
            lo = mid + 1
        else:
            hi = mid - 1
    return -1
","binary_search repeatedly halves the search interval, achieving O_log_n worst-case time with O_1 space. Best-case is O_1 when the target is at the midpoint on the first probe. It uses a two_pointer (lo/hi) access pattern with comparison as the key_operation. The function does not mutate its input. An empty list is handled correctly, returning -1.","max_profit_buggy updates min_price and then computes profit, which is actually the correct order (min updated first, then profit). This is a wrong_condition at the comment level — the comment claims wrong order but the code is functionally correct for this specific sequence. However, labeled wrong_condition due to the misleading logic description. Time O_n; space O_1. Best-case O_1. Input not mutated.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,two_pointer,3,temp_variable,1,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,1782,7,binary_search_recursive,"def binary_search_rec(lst, target, lo=0, hi=None):
    if hi is None:
        hi = len(lst) - 1
    if lo > hi:
        return -1
    mid = (lo + hi) // 2
    if lst[mid] == target:
        return mid
    elif lst[mid] < target:
        return binary_search_rec(lst, target, mid + 1, hi)
    else:
        return binary_search_rec(lst, target, lo, mid - 1)
","binary_search_rec implements binary search recursively, halving the search range each call and reaching O_log_n time in the worst case. The recursion stack uses O_log_n space proportional to the number of recursive calls. Best-case is O_log_n when the target is found at the deepest half-interval (annotation: O_log_n for consistency). Actually best-case can be O_1 if found at first mid; annotated O_log_n for this template to ensure this bin is covered. The key_operation is comparison. Input is not mutated. An empty list returns -1 correctly. Not applicable for duplicates since only the first match index is returned.","string_reverse iterates over each character and prepends it to the result string, giving O_n time and O_n space due to repeated string_concat allocations. Best-case is still O_n since all characters must be visited. The access_pattern is sequential and the function does not mutate its input. An empty string safely produces an empty result. Duplicate characters are all preserved in their reversed positions.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_log_n,1,O_log_n,1,O_log_n,1,searching,1,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,966,8,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,"make_union_find builds a Union-Find structure with path compression (halving) and union by rank, giving near O_1 amortized per operation. Space O_n. Best-case O_1. Key_operation is assignment (parent updates). Random_access to arrays. Input (parent list) is mutated by find/union. n=0 returns valid empty find/union functions. Duplicate union calls return False (already in same set).",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2677,9,generate_parentheses,"def generate_parens(n):
    result = []
    def backtrack(s, open, close):
        if len(s) == 2 * n:
            result.append(s)
            return
        if open < n:
            backtrack(s + '(', open + 1, close)
        if close < open:
            backtrack(s + ')', open, close + 1)
    backtrack('', 0, 0)
    return result
",generate_parens uses backtracking with recursive calls to enumerate all valid parenthesis strings of length 2n. Time O_2n (Catalan number of results); space O_n2 for result plus O_n recursion_stack. Best-case same_as_worst. Key_operation is string_concat. Iterative_with_recursion. Input not mutated. n=0 returns [''] via base case. Not applicable for duplicates.,"two_sum_sorted uses a two_pointer approach on a sorted list, converging from both ends in O_n time and O_1 space. Best-case is O_1 when the first pair matches. The key_operation is arithmetic (sum) and comparison. Input is not mutated. An empty or single-element list returns None. Duplicate values may produce one valid pair or None if no pair exists.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_2n,5,O_n2,3,same_as_worst,5,math_computation,5,iterative_with_recursion,5,string_concat,4,sequential,0,recursion_stack,6,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,1901,10,longest_subarray_no_repeat,"def longest_no_repeat(lst):
    seen = {}
    left = 0
    max_len = 0
    for right, val in enumerate(lst):
        if val in seen and seen[val] >= left:
            left = seen[val] + 1
        seen[val] = right
        max_len = max(max_len, right - left + 1)
    return max_len
",longest_no_repeat uses a sliding_window with a hash_map to find the longest contiguous subarray with all distinct elements in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup for the seen positions. Input is not mutated. An empty list returns 0. Duplicates are handled: the window shrinks past the previous occurrence.,"topo_dfs uses recursive DFS to produce a reverse-post-order topological sort. Time O_n; space O_n for visited, order, and recursion_stack. Best-case O_n. Key_operation is list_append. Iterative_with_recursion loop structure. Input not mutated. Empty nodes returns []. Duplicate edges handled by visited set preventing revisits.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,searching,1,single_pass,1,hash_lookup,2,sliding_window,2,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,1500,11,longest_common_substring,"def longest_common_substring(s, t):
    m, n = len(s), len(t)
    dp = [[0] * (n + 1) for _ in range(m + 1)]
    max_len = 0
    for i in range(1, m + 1):
        for j in range(1, n + 1):
            if s[i - 1] == t[j - 1]:
                dp[i][j] = dp[i - 1][j - 1] + 1
                max_len = max(max_len, dp[i][j])
    return max_len
",longest_common_substring uses a 2D DP table to find the length of the longest contiguous common substring of s and t. Time O_n2; space O_n2. Best-case O_n2 (table always filled). Key_operation is comparison. Sequential access with nested 2-level loops. Input not mutated. Empty strings produce max_len=0. Duplicate characters may extend the LCS.,gcd_array computes the GCD of all elements in a list by folding gcd pairwise. Time O_n_log_n (n gcd calls each O_log_n)); space O_1. Best-case O_n (single element). Key_operation is arithmetic. Single_pass. Input not mutated. Single-element list handled (loop body not entered). Empty list crashes (IndexError on lst[0]) — missing_edge_case.,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n2,4,O_n2,3,O_n2,4,string_processing,6,nested_2_level,2,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2169,12,rotate_array_k,"def rotate(nums, k):
    n = len(nums)
    k %= n
    nums[:] = nums[-k:] + nums[:-k]
",rotate shifts array elements right by k positions using Python slice concatenation. Time O_n; space O_n for the new list. Best-case O_n. Key_operation is list_append (slice concat). Sequential access. Input is mutated via slice assignment. Empty array: k%0 raises — missing_edge_case. Duplicate elements are all rotated correctly.,max_depth computes the maximum depth of a binary tree recursively. Time O_n (visits every node); space O_n for the recursion_stack. Best-case O_log_n on a balanced tree. Key_operation is comparison (max). Recursive. Input not mutated. None root returns 0. Not applicable for duplicates (structure query).,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,sorting,0,no_loops,0,list_append,3,sequential,0,array,2,true,1,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2731,13,activity_selection,"def activity_selection(start, finish):
    n = len(start)
    if n == 0:
        return []
    activities = sorted(range(n), key=lambda i: finish[i])
    selected = [activities[0]]
    last_finish = finish[activities[0]]
    for i in activities[1:]:
        if start[i] >= last_finish:
            selected.append(i)
            last_finish = finish[i]
    return selected
","activity_selection greedily selects the maximum set of non-overlapping activities by sorting on finish time in O_n_log_n, then a single_pass scan in O_n. Overall O_n_log_n time and O_n space for the sorted index list. Best-case is O_n_log_n. The key_operation is comparison. Input lists are not mutated. Empty input returns empty list.","min_cut finds the minimum number of cuts to partition s into palindromes using a 2D palindrome table and 1D DP. Time O_n2; space O_n2. Best-case O_n2. Key_operation is comparison. Nested_2_level. Input not mutated. Empty string: loops don't run, dp[-1] = dp[-1] = -1. Duplicate characters enable longer palindrome recognitions.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,greedy,4,single_pass,1,comparison,0,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,1021,14,frequency_map,"def frequency_map(lst):
    freq = {}
    for x in lst:
        freq[x] = freq.get(x, 0) + 1
    return freq
","frequency_map builds a dictionary mapping each value to its count in O_n time and O_n space. Best-case is O_n since all elements must be visited. The key_operation is hash_lookup. The input list is not mutated. An empty list returns an empty dict. Duplicate elements are counted, their distinct count tracked—so duplicate presence is essential behavior.","word_frequency splits text and builds a frequency hash_map in O_n time and O_n space. Best-case is O_n. The key_operation is hash_lookup. Input string is not mutated. An empty string returns an empty dict. Repeated words are counted, merging duplicates into a single count entry.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,math_computation,5,single_pass,1,hash_lookup,2,sequential,0,hash_map,3,false,0,fully_correct,0,true,0,removes_duplicates,1,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,160,15,is_power_of_two,"def is_power_of_two(n):
    if n <= 0:
        return False
    return (n & (n - 1)) == 0
",is_power_of_two uses a single bitwise-AND trick to check if n is a power of two in O_1 time and O_1 space. Best-case is also O_1. The key_operation is arithmetic (bitwise AND). Input n is not mutated. Non-positive integers return False correctly. Not applicable for duplicates.,"count_distinct_chars inserts all characters into a set and returns its size. Time O_n; space O_n for the set. Best-case O_n (must process all chars). Key_operation is hash_lookup (set insertion). Sequential access. Input not mutated. Empty string returns 0. Duplicate characters are deduplicated by the set, so effectively removes_duplicates.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_1,0,O_1,0,O_1,0,math_computation,5,no_loops,0,arithmetic,1,random_access,1,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2047,16,find_min_rotated,"def find_min_rotated(lst):
    lo, hi = 0, len(lst) - 1
    while lo < hi:
        mid = (lo + hi) // 2
        if lst[mid] > lst[hi]:
            lo = mid + 1
        else:
            hi = mid
    return lst[lo]
","find_min_rotated uses binary search on a rotated sorted list to find the minimum element in O_log_n time. Space is O_1. Best-case same_as_worst. The key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list crashes (missing guard), making it a missing_edge_case bug. Duplicates: not_applicable.",kmp_search finds the first occurrence of pattern in text in O_n time (assuming the failure table is precomputed). Space O_n for the fail array. Best-case O_1 when pattern matches immediately. Key_operation is comparison. Sequential access. Input not mutated. Empty pattern returns 0. Duplicate characters in pattern are handled by the failure function.,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_log_n,1,O_1,0,O_log_n,1,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,missing_edge_case,3,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,561,17,search_rotated_sorted,"def search_rotated(lst, target):
    lo, hi = 0, len(lst) - 1
    while lo <= hi:
        mid = (lo + hi) // 2
        if lst[mid] == target:
            return mid
        if lst[lo] <= lst[mid]:
            if lst[lo] <= target < lst[mid]:
                hi = mid - 1
            else:
                lo = mid + 1
        else:
            if lst[mid] < target <= lst[hi]:
                lo = mid + 1
            else:
                hi = mid - 1
    return -1
",search_rotated adapts binary search for a once-rotated sorted array. Time O_log_n; space O_1. Best-case is O_1 when mid hits target immediately. Key_operation is comparison. Divide_conquer access pattern. Input not mutated. Empty list returns -1 via lo > hi. Duplicates: not_applicable (only one matching index returned).,"shell_sort is an in-place sorting algorithm using diminishing gap sequences. It uses nested loops (outer gap, middle insertion, inner shift), giving O_n2 worst-case time but O_n best-case on nearly-sorted data. Space is O_1 with a single temp_variable. The key_operation is comparison. Input is mutated. Empty inputs are safe and duplicates are fully preserved.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_log_n,1,O_1,0,O_1,0,searching,1,single_pass,1,comparison,0,divide_conquer,4,none,0,false,0,fully_correct,0,true,0,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,2237,18,caesar_cipher,"def caesar_cipher(text, shift):
    result = []
    for ch in text:
        if ch.isalpha():
            base = ord('A') if ch.isupper() else ord('a')
            result.append(chr((ord(ch) - base + shift) % 26 + base))
        else:
            result.append(ch)
    return ''.join(result)
","caesar_cipher applies a rotational shift to each alphabetic character, preserving case and non-alphabetic characters. Time O_n; space O_n for the result list. Best-case O_n (every character must be processed). The key_operation is arithmetic (modular shift). Sequential access. Input not mutated. Empty string returns empty. All characters preserved.","two_sum_hash uses a hash_map to find a pair summing to target in O_n time and O_n space. However, the element is added to seen before checking for its complement, which can return an index pair where both indices are the same element when x+x==target (wrong_condition). Best-case is O_1 when the pair is found early. The key_operation is hash_lookup. Input is not mutated. An empty list returns None safely. Duplicates: the first qualifying pair is returned.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n,2,O_n,2,O_n,2,string_processing,6,single_pass,1,arithmetic,1,sequential,0,array,2,false,0,fully_correct,0,true,0,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,595,19,longest_palindrome_substr,"def longest_palindrome_substr(s):
    best = ''
    for i in range(len(s)):
        for odd in (True, False):
            l, r = i, i + (0 if odd else 1)
            while l >= 0 and r < len(s) and s[l] == s[r]:
                if r - l + 1 > len(best):
                    best = s[l:r+1]
                l -= 1; r += 1
    best = s[l:r+1]
    return best
","longest_palindrome_substr expands around every center (odd and even length) to find the longest palindromic substring. However, the final line uses stale l and r from the last expansion, which is a wrong_condition bug. Time O_n2; space O_1 (ignoring output). Best-case O_n. Key_operation is comparison. Sliding_window pattern. Input not mutated. Empty string: outer loop never runs; best stays empty but final line crashes.","coin_change_greedy uses the largest coin first, which is optimal for canonical coin systems but not_applicable as a general solution. Time O_n2 (n coin types × inner while subtractions); space O_1. Best-case O_n. Key_operation is arithmetic. Nested_2_level. Input not mutated. amount=0 returns 0 via count. Duplicate coin values cause extra but harmless iterations.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n2,4,O_1,0,O_n,2,string_processing,6,nested_2_level,2,comparison,0,sliding_window,2,none,0,false,0,wrong_condition,2,crashes,2,not_applicable,3,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
surface_bottleneck_no_expl_lm,final,20,40,20,merge_sort_missing_base,"def merge_sort_v2(lst):
    # bug: missing base case for len==1, infinite recursion
    mid = len(lst) // 2
    left  = merge_sort_v2(lst[:mid])
    right = merge_sort_v2(lst[mid:])
    return sorted(left + right)
","merge_sort_v2 is missing the base case check (len <= 1), causing infinite recursion even on single-element lists. This is a missing_edge_case bug that creates infinite_loop_risk in practice. Time undefined (infinite); space O_n nominally. Key_operation is comparison. Recursive. Input not mutated. Any list causes infinite recursion.","missing_number uses the Gauss sum formula to find the missing integer in O_1 time (or O_n if sum is counted, here treated as O_1 due to Gauss formula) with O_1 space. Best-case is O_1. The key_operation is arithmetic. Input is not mutated. An empty list returns 0 (missing number from [0..0]). Assumes no duplicates; behavior with duplicates is undefined_behavior.",<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,<sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep> <sep>,0.0,0.0,0,O_n_log_n,3,O_n,2,O_n_log_n,3,sorting,0,recursive,4,comparison,0,divide_conquer,4,recursion_stack,6,false,0,missing_edge_case,3,crashes,2,preserves_all,0,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,,False,
