Question No: 5
Context Size: 16471

Codebase:

File: neighbor_finder.py:

```Python
from typing import List
import heapq
from typing import List, Tuple
from collections import deque
from typing import Dict, List
import math

def assign_tasks_to_schedules(schedules: List[List[int]], tasks: List[int]) -> List[List[int]]:
    updated_schedules = []
    
    for schedule in schedules:
        updated_schedule = []
        remaining_time = schedule[:]
        
        for task in tasks:
            # Find the first available time slot that can accommodate the task
            for i, time_slot in enumerate(remaining_time):
                if time_slot >= task:
                    updated_schedule.append(task)
                    remaining_time[i] -= task
                    break
        
        updated_schedules.append(updated_schedule)
    
    return updated_schedules

def top_k_elements(nums: List[int], k: int) -> Tuple[List[int], int]:
    top_elements = heapq.nlargest(k, nums)
    top_elements.sort()
    return top_elements, sum(top_elements)

def shortest_route(routes: List[List[int]], start_node: int, end_node: int) -> List[int]:
    graph = {}
    for route in routes:
        for i in range(len(route) - 1):
            if route[i] not in graph:
                graph[route[i]] = []
            graph[route[i]].append(route[i + 1])
    
    queue = deque([[start_node]])
    seen = set()
    
    while queue:
        path = queue.popleft()
        node = path[-1]
        if node == end_node:
            return path
        if node not in seen:
            seen.add(node)
            if node in graph:
                for neighbor in graph[node]:
                    new_path = list(path)
                    new_path.append(neighbor)
                    queue.append(new_path)
    
    return []

def highlight_exceeding_elements(matrix: List[List[float]], threshold: float) -> List[Tuple[int, int, float]]:
    min_value = min(min(row) for row in matrix)
    max_value = max(max(row) for row in matrix)
    normalized_matrix = [[(value - min_value) / (max_value - min_value) if max_value != min_value else 0 for value in row] for row in matrix]
    exceeding_elements = [(i, j, value) for i, row in enumerate(normalized_matrix) for j, value in enumerate(row) if value > threshold]
    
    return exceeding_elements

def list_rotator(sorted_list: List[int], rotations: int) -> List[int]:
    rotations = rotations % len(sorted_list)
    return sorted_list[-rotations:] + sorted_list[:-rotations]

def longest_common_subsequence(sequences: List[List[int]], k: int) -> List[int]:
    if not sequences:
        return []
    
    dp = [[[] for _ in range(k + 1)] for _ in range(len(sequences))]
    
    for i in range(len(sequences)):
        for j in range(k + 1):
            if j == 0:
                dp[i][j] = []
            elif i == 0:
                dp[i][j] = dp[i][j - 1]
            else:
                max_len = 0
                best_seq = []
                for m in range(len(sequences[i])):
                    for n in range(len(sequences[i - 1])):
                        if sequences[i][m] == sequences[i - 1][n]:
                            if len(dp[i - 1][j - 1]) + 1 > max_len:
                                max_len = len(dp[i - 1][j - 1]) + 1
                                best_seq = dp[i - 1][j - 1] + [sequences[i][m]]
                dp[i][j] = best_seq
    
    return dp[-1][-1]

def schedule_tasks(tasks: List[Tuple[str, int]], k: int) -> List[str]:
    sorted_tasks = sorted(tasks, key=lambda x: x[1], reverse=True)
    top_tasks = sorted_tasks[:k]
    return [task[0] for task in top_tasks]

def dfs_search(graph: Dict[str, List[str]], start_node: str, end_node: str) -> List[str]:
    visited = set()
    stack = [(start_node, [start_node])]
    
    while stack:
        node, path = stack.pop()
        if node == end_node:
            return path
        if node not in visited:
            visited.add(node)
            for neighbor in graph[node]:
                stack.append((neighbor, path + [neighbor]))
    
    return []

def schedule_tasks(intervals: List[Tuple[int, int]], deadline: int) -> List[Tuple[int, int]]:
    intervals.sort(key=lambda x: x[1])
    scheduled_tasks = []
    current_time = 0
    
    for start, end in intervals:
        if current_time <= start and end <= deadline:
            scheduled_tasks.append((start, end))
            current_time = end
    
    return scheduled_tasks

def min_rooms_required(intervals: List[Tuple[int, int]], num_rooms: int) -> int:
    if not intervals:
        return 0
    
    intervals.sort(key=lambda x: x[0])
    rooms = []
    
    for start, end in intervals:
        if rooms and rooms[0] <= start:
            heapq.heappop(rooms)
        heapq.heappush(rooms, end)
    
    return len(rooms)

def find_k_nearest_points(points: List[Tuple[float, float]], k: int) -> List[Tuple[float, float]]:
    distances = [(math.sqrt(x**2 + y**2), (x, y)) for x, y in points]
    sorted_points = sorted(distances, key=lambda item: item[0])
    return [point[1] for point in sorted_points[:k]]
```

File: dijkstra.py:

```Python
from typing import List
from collections import Counter
import re
import numpy as np
import heapq
from typing import Dict, List
import math

def common_words(text: str, threshold: int) -> List[str]:
    words = re.findall(r'\b\w+\b', text.lower())
    word_freq = Counter(words)
    common_words = [word for word, freq in word_freq.items() if freq >= threshold]
    common_words.sort(key=lambda word: word_freq[word], reverse=True)
    
    return common_words

def matrix_rank_calculator(matrix: List[List[int]], demarcation_line: List[int]) -> tuple:
    upper_matrix = matrix[:demarcation_line[0]]
    lower_matrix = matrix[demarcation_line[0]:]
    
    upper_rank = np.linalg.matrix_rank(upper_matrix)
    lower_rank = np.linalg.matrix_rank(lower_matrix)
    
    return upper_rank, lower_rank

def rotate_string(s, n):
    n = n % len(s) if s else 0
    return s[n:] + s[:n]

def dijkstra_algorithm(graph: Dict[str, List[str]], source: str) -> Dict[str, Dict[str, str]]:
    distances = {node: float('inf') for node in graph}
    previous_nodes = {node: None for node in graph}
    distances[source] = 0
    priority_queue = [(0, source)]
    
    while priority_queue:
        current_distance, current_node = heapq.heappop(priority_queue)
        
        if current_distance > distances[current_node]:
            continue
        
        for neighbor in graph[current_node]:
            distance = current_distance + 1
            if distance < distances[neighbor]:
                distances[neighbor] = distance
                previous_nodes[neighbor] = current_node
                heapq.heappush(priority_queue, (distance, neighbor))
    
    return {'distances': distances, 'previous_nodes': previous_nodes}

def search_in_sorted_matrix(matrix: List[List[int]], target: int) -> bool:
    if not matrix or not matrix[0]:
        return False
    
    rows, cols = len(matrix), len(matrix[0])
    r, c = 0, cols - 1
    
    while r < rows and c >= 0:
        if matrix[r][c] == target:
            return True
        elif matrix[r][c] > target:
            c -= 1
        else:
            r += 1
            
    return False

def knapsack_solver(items: List[str], capacity: int, profits: List[int]) -> List[str]:
    n = len(profits)
    dp = [[0 for _ in range(capacity + 1)] for _ in range(n + 1)]
    for i in range(1, n + 1):
        for w in range(1, capacity + 1):
            if w < i:
                dp[i][w] = dp[i - 1][w]
            else:
                dp[i][w] = max(dp[i - 1][w], profits[i - 1] + dp[i - 1][w - i])
    result = []
    w = capacity
    for i in range(n, 0, -1):
        if dp[i][w] != dp[i - 1][w]:
            result.append(items[i - 1])
            w -= i
    return result

def evaluate_expression(expression):
    if not expression:
        raise ValueError("Invalid input")
    
    precedence = {'+': 1, '-': 1, '*': 2, '/': 2}
    output_queue = []
    operator_stack = []
    
    for char in expression:
        if char.isdigit():
            output_queue.append(int(char))
        elif char in precedence:
            while (operator_stack and 
                   operator_stack[-1] in precedence and 
                   precedence[operator_stack[-1]] >= precedence[char]):
                output_queue.append(operator_stack.pop())
            operator_stack.append(char)
        elif char == '(':
            operator_stack.append(char)
        elif char == ')':
            while operator_stack[-1] != '(':
                output_queue.append(operator_stack.pop())
            operator_stack.pop()
    
    while operator_stack:
        output_queue.append(operator_stack.pop())
    
    evaluation_stack = []
    for token in output_queue:
        if token in precedence:
            operand2 = evaluation_stack.pop()
            operand1 = evaluation_stack.pop()
            if token == '+':
                evaluation_stack.append(operand1 + operand2)
            elif token == '-':
                evaluation_stack.append(operand1 - operand2)
            elif token == '*':
                evaluation_stack.append(operand1 * operand2)
            elif token == '/':
                evaluation_stack.append(operand1 / operand2)
        else:
            evaluation_stack.append(token)
    
    return evaluation_stack[0]

def min_stone_size(numbers: List[int], k: int) -> int:
    if not numbers or k >= len(numbers):
        return 0
    
    pq = [-num for num in numbers]
    heapq.heapify(pq)
    
    for _ in range(k):
        heapq.heappop(pq)
    
    return -min(pq)

def max_subgrid_sum(grid: List[List[int]], k: int) -> int:
    rows, cols = len(grid), len(grid[0])
    prefix_sum = [[0] * (cols + 1) for _ in range(rows + 1)]
    
    for i in range(1, rows + 1):
        for j in range(1, cols + 1):
            prefix_sum[i][j] = prefix_sum[i - 1][j] + prefix_sum[i][j - 1] - prefix_sum[i - 1][j - 1] + grid[i - 1][j - 1]
    
    max_sum = float('-inf')
    for i in range(k, rows + 1):
        for j in range(k, cols + 1):
            subgrid_sum = prefix_sum[i][j] - prefix_sum[i - k][j] - prefix_sum[i][j - k] + prefix_sum[i - k][j - k]
            max_sum = max(max_sum, subgrid_sum)
    
    return max_sum

def project_triangle(triangle: List[List[float]], axis: int, precision: float) -> float:
    # Calculate the normal vector of the triangle
    v1 = [triangle[1][0] - triangle[0][0], triangle[1][1] - triangle[0][1], triangle[1][2] - triangle[0][2]]
    v2 = [triangle[2][0] - triangle[0][0], triangle[2][1] - triangle[0][1], triangle[2][2] - triangle[0][2]]
    normal = [v1[1]*v2[2] - v1[2]*v2[1], v1[2]*v2[0] - v1[0]*v2[2], v1[0]*v2[1] - v1[1]*v2[0]]
    normal_length = math.sqrt(normal[0]**2 + normal[1]**2 + normal[2]**2)
    normal = [normal[0]/normal_length, normal[1]/normal_length, normal[2]/normal_length]
    
    # Project the triangle onto the plane
    projected_triangle = []
    for point in triangle:
        projected_point = [point[0] - normal[0]*point[axis], point[1] - normal[1]*point[axis], point[2] - normal[2]*point[axis]]
        projected_triangle.append(projected_point)
    
    # Calculate the area of the projected triangle
    v1 = [projected_triangle[1][0] - projected_triangle[0][0], projected_triangle[1][1] - projected_triangle[0][1]]
    v2 = [projected_triangle[2][0] - projected_triangle[0][0], projected_triangle[2][1] - projected_triangle[0][1]]
    area = abs(v1[0]*v2[1] - v1[1]*v2[0]) / 2
    
    return area

def find_motif(dna_sequence: str, motif: str, mismatches: int) -> List[int]:
    if len(motif) > len(dna_sequence) or mismatches > len(motif):
        return []
    
    result = []
    for i in range(len(dna_sequence) - len(motif) + 1):
        match = True
        mismatch_count = 0
        for j in range(len(motif)):
            if dna_sequence[i + j] != motif[j]:
                mismatch_count += 1
                if mismatch_count > mismatches:
                    match = False
                    break
        if match:
            result.append(i)
    
    return result
```

File: bin_packer.py:

```Python
from typing import List
from heapq import heappop, heappush
import numpy as np
from math import sqrt
from typing import List, Dict
import random
from typing import List, Tuple
import re

def astar_shortest_path(edges: List[List[int]], source: int, target: int) -> List[int]:
    graph = {}
    for u, v, cost in edges:
        if u not in graph:
            graph[u] = {}
        graph[u][v] = cost
    queue = [(0, source, [])]
    visited = set()
    while queue:
        cost, node, path = heappop(queue)
        if node == target:
            return path + [node], cost
        if node in visited:
            continue
        visited.add(node)
        for neighbor, neighbor_cost in graph.get(node, {}).items():
            if neighbor not in visited:
                heappush(queue, (cost + neighbor_cost, neighbor, path + [node]))
    return None, float('inf')

def bucket_numbers(numbers: List[float], buckets: int) -> List[List[float]]:
    quantiles = np.quantile(numbers, [i / buckets for i in range(buckets + 1)])
    buckets_list = []
    
    for i in range(buckets):
        bucket = [num for num in numbers if quantiles[i] <= num < quantiles[i + 1]]
        buckets_list.append(bucket)
    
    return buckets_list

def triangle_point_containment(triangles: List[List[List[int]]], points: List[List[int]]) -> List[List[int]]:
    result = []
    
    for point in points:
        containing_triangles = []
        
        for i, triangle in enumerate(triangles):
            v0, v1, v2 = triangle
            vx, vy = point
            
            # Compute barycentric coordinates
            v0_x, v0_y = v0
            v1_x, v1_y = v1
            v2_x, v2_y = v2
            
            denominator = (v0_y - v2_y) * (v1_x - v2_x) + (v2_x - v0_x) * (v1_y - v2_y)
            
            if denominator == 0:
                continue
            
            t = ((vx - v2_x) * (v1_y - v2_y) - (vy - v2_y) * (v1_x - v2_x)) / denominator
            u = -((vx - v2_x) * (v0_y - v2_y) - (vy - v2_y) * (v0_x - v2_x)) / denominator
            
            if 0 <= t and 0 <= u and t + u <= 1:
                containing_triangles.append(i)
        
        result.append(containing_triangles)
    
    return result

def find_similar_vectors(vectors: List[List[float]], threshold: float) -> list:
    similar_pairs = []
    
    for i in range(len(vectors)):
        for j in range(i + 1, len(vectors)):
            dot_product = sum(x * y for x, y in zip(vectors[i], vectors[j]))
            magnitude_i = sqrt(sum(x ** 2 for x in vectors[i]))
            magnitude_j = sqrt(sum(x ** 2 for x in vectors[j]))
            cosine_similarity = dot_product / (magnitude_i * magnitude_j)
            
            if cosine_similarity >= threshold:
                similar_pairs.append((vectors[i], vectors[j]))
    
    return similar_pairs

def trend_analysis(prices: List[float], n: int) -> Dict[str, int]:
    if len(prices) < n:
        return {"increasing": 0, "decreasing": 0, "stable": 0}
    
    trends = {"increasing": 0, "decreasing": 0, "stable": 0}
    
    for i in range(len(prices) - n):
        change = prices[i + n] - prices[i]
        if change > 0:
            trends["increasing"] += 1
        elif change < 0:
            trends["decreasing"] += 1
        else:
            trends["stable"] += 1
            
    return trends

def max_sum_non_adjacent(nums, k):
    n = len(nums)
    if k == 0 or n == 0:
        return 0
    
    dp = [[0] * (k + 1) for _ in range(n + 1)]
    
    for i in range(1, n + 1):
        for j in range(1, min(i, k) + 1):
            dp[i][j] = max(dp[i-1][j], dp[i-2][j-1] + nums[i-1]) if i > 1 else nums[i-1]
    
    return dp[n][k]

def find_overlapping_subsequences(sequences: List[str], min_length: int) -> Dict[str, int]:
    subsequences = {}
    
    for sequence in sequences:
        for i in range(len(sequence) - min_length + 1):
            subsequence = sequence[i:i + min_length]
            subsequences[subsequence] = subsequences.get(subsequence, 0) + 1
    
    return subsequences

def kmeans_clustering(points: List[Tuple[int, int]], k: int) -> List[Tuple[float, float]]:
    centroids = random.sample(points, k)
    while True:
        clusters = [[] for _ in range(k)]
        for point in points:
            closest_centroid_index = min(range(k), key=lambda i: ((point[0] - centroids[i][0]) ** 2 + (point[1] - centroids[i][1]) ** 2) ** 0.5)
            clusters[closest_centroid_index].append(point)
        new_centroids = [(sum(x for x, y in cluster) / len(cluster), sum(y for x, y in cluster) / len(cluster)) for cluster in clusters]
        if new_centroids == centroids:
            break
        centroids = new_centroids
    return centroids

def max_island_area(grid: List[List[int]], row: int, col: int) -> int:
    if not grid or row < 0 or row >= len(grid) or col < 0 or col >= len(grid[0]) or grid[row][col] == 0:
        return 0
    
    grid[row][col] = 0
    area = 1
    
    area += max_island_area(grid, row - 1, col)
    area += max_island_area(grid, row + 1, col)
    area += max_island_area(grid, row, col - 1)
    area += max_island_area(grid, row, col + 1)
    
    return area

def extract_entities(text, entities):
    extracted_entities = []
    
    for entity in entities:
        pattern = r'\b' + re.escape(entity) + r'\b'
        matches = re.finditer(pattern, text)
        
        for match in matches:
            extracted_entities.append((entity, match.start()))
    
    return extracted_entities

def bin_packing(weights: List[int], capacities: List[int]) -> List[List[int]]:
    weights.sort(reverse=True)
    bins = [[] for _ in range(len(capacities))]
    bin_weights = [0] * len(capacities)
    
    for weight in weights:
        for i, capacity in enumerate(capacities):
            if bin_weights[i] + weight <= capacity:
                bins[i].append(weight)
                bin_weights[i] += weight
                break
    
    return bins
```

File: dynamic_programming.py:

```Python
from typing import List
import numpy as np
from typing import List, Tuple
import math
import random
from typing import List, Tuple, Dict
from scipy.optimize import linear_sum_assignment
from typing import Dict, List
from collections import deque
from scipy.stats import norm
from typing import Dict, List, Tuple, Union

def median_filter(data: List[List[int]], threshold: int) -> List[List[int]]:
    matrix = np.array(data)
    filtered_matrix = np.zeros_like(matrix)
    kernel_size = 3
    pad = kernel_size // 2
    padded_matrix = np.pad(matrix, pad, mode='constant')
    for i in range(matrix.shape[0]):
        for j in range(matrix.shape[1]):
            window = padded_matrix[i:i+kernel_size, j:j+kernel_size]
            median = np.median(window)
            if median > threshold:
                filtered_matrix[i, j] = median
    return filtered_matrix.astype(int).tolist()

def sub_matrix_sum(grid: List[List[int]], target: int, window_size: int) -> List[Tuple[Tuple[int, int], Tuple[int, int]]]:
    if not grid or window_size <= 0:
        return []
    
    result = []
    row_sum = [0] * len(grid[0])
    
    for i in range(len(grid)):
        for j in range(len(grid[0])):
            if j >= window_size:
                row_sum[j] -= grid[i][j - window_size]
            row_sum[j] += grid[i][j]
        
        if i >= window_size - 1:
            for j in range(len(grid[0]) - window_size + 1):
                window_sum = 0
                for k in range(window_size):
                    window_sum += row_sum[j + k]
                if window_sum == target:
                    result.append(((i - window_size + 1, j), (i, j + window_size - 1)))
    
    return result

def longest_subsequences_with_target_sum(sequences: List[List[int]], min_length: int, target_sum: int) -> List[List[int]]:
    result = []
    
    for sequence in sequences:
        if len(sequence) >= min_length:
            longest_subsequence = []
            current_sum = 0
            
            for i in range(len(sequence)):
                current_sum = 0
                subsequence = []
                
                for j in range(i, len(sequence)):
                    current_sum += sequence[j]
                    subsequence.append(sequence[j])
                    
                    if current_sum == target_sum and len(subsequence) > len(longest_subsequence):
                        longest_subsequence = subsequence
            
            if longest_subsequence:
                result.append(longest_subsequence)
    
    return result

def louvain_community_detection(matrix: List[List[float]], min_community_size: int, num_runs: int) -> List[int]:
    num_nodes = len(matrix)
    community_assignments = [random.randint(0, num_nodes - 1) for _ in range(num_nodes)]
    
    max_modularity = float('-inf')
    optimal_community_assignments = []
    
    for _ in range(num_runs):
        modularity = 0
        while True:
            community_sizes = [0] * num_nodes
            community_degrees = [0.0] * num_nodes
            community_gain = [0.0] * num_nodes
            
            for i in range(num_nodes):
                community_sizes[community_assignments[i]] += 1
                degree = sum(matrix[i])
                community_degrees[community_assignments[i]] += degree
                
                for j in range(num_nodes):
                    if i != j:
                        community_gain[community_assignments[i]] += matrix[i][j]
            
            total_degree = sum(community_degrees)
            
            for i in range(num_nodes):
                old_community = community_assignments[i]
                old_modularity = (community_gain[old_community] - (community_degrees[old_community] ** 2) / total_degree) / total_degree
                
                max_new_modularity = float('-inf')
                new_community = old_community
                
                for j in range(num_nodes):
                    new_communities = community_assignments[:]
                    community_sizes[old_community] -= 1
                    community_sizes[j] += 1
                    
                    community_degrees[old_community] -= sum(matrix[i])
                    community_degrees[j] += sum(matrix[i])
                    
                    community_gain[old_community] -= sum(matrix[i][k] for k in range(num_nodes))
                    community_gain[j] += sum(matrix[i][k] for k in range(num_nodes))
                    
                    new_modularity = (community_gain[j] - (community_degrees[j] ** 2) / total_degree) / total_degree - old_modularity
                    
                    community_degrees[old_community] += sum(matrix[i])
                    community_degrees[j] -= sum(matrix[i])
                    
                    community_gain[old_community] += sum(matrix[i][k] for k in range(num_nodes))
                    community_gain[j] -= sum(matrix[i][k] for k in range(num_nodes))
                    
                    community_sizes[old_community] += 1
                    community_sizes[j] -= 1
                    
                    if new_modularity > max_new_modularity:
                        max_new_modularity = new_modularity
                        new_community = j
                
                if community_sizes[old_community] > min_community_size and max_new_modularity > 0:
                    modularity += max_new_modularity
                    community_assignments[i] = new_community
            
            if modularity > max_modularity:
                max_modularity = modularity
                optimal_community_assignments = community_assignments[:]
            
            if modularity == 0:
                break
    
    return optimal_community_assignments

def shortest_terrain_path(matrix: List[List[int]], start_position: Tuple[int, int], end_position: Tuple[int, int]) -> List[Tuple[int, int]]:
    rows, cols = len(matrix), len(matrix[0])
    directions = [(0, 1), (0, -1), (1, 0), (-1, 0)]
    queue = [(start_position, [start_position], 0)]
    visited = set()
    
    while queue:
        (x, y), path, elevation_change = queue.pop(0)
        visited.add((x, y))
        
        if (x, y) == end_position:
            return path
        
        for dx, dy in directions:
            nx, ny = x + dx, y + dy
            
            if 0 <= nx < rows and 0 <= ny < cols and (nx, ny) not in visited:
                new_elevation_change = elevation_change + abs(matrix[nx][ny] - matrix[x][y])
                queue.append(((nx, ny), path + [(nx, ny)], new_elevation_change))
    
    return []

def sobel_operator(image: List[List[int]], threshold: int) -> List[List[int]]:
    rows, cols = len(image), len(image[0])
    edge_detected_image = [[0] * cols for _ in range(rows)]
    
    sobel_kernel_x = [[-1, 0, 1], [-2, 0, 2], [-1, 0, 1]]
    sobel_kernel_y = [[-1, -2, -1], [0, 0, 0], [1, 2, 1]]
    
    for i in range(1, rows - 1):
        for j in range(1, cols - 1):
            gradient_x = sum(image[x][y] * sobel_kernel_x[x - i + 1][y - j + 1] for x in range(i - 1, i + 2) for y in range(j - 1, j + 2))
            gradient_y = sum(image[x][y] * sobel_kernel_y[x - i + 1][y - j + 1] for x in range(i - 1, i + 2) for y in range(j - 1, j + 2))
            gradient = (gradient_x ** 2 + gradient_y ** 2) ** 0.5
            edge_detected_image[i][j] = 1 if gradient >= threshold else 0
    
    return edge_detected_image

def num_ways_to_split_string(n: int, k: int) -> int:
    if n < k:
        return 0
    
    dp = [[0] * (k + 1) for _ in range(n + 1)]
    dp[0][0] = 1
    
    for i in range(1, n + 1):
        for j in range(1, min(i, k) + 1):
            for m in range(1, i + 1):
                dp[i][j] += dp[i - m][j - 1]
    
    return dp[n][k]

def assignment_solver(l1: List[int], l2: List[int], constraints: List[Tuple[int, int, int]], values: List[int]) -> Dict[int, int]:
    cost_matrix = [[-abs(val) if (row, col, -abs(val)) in constraints else 0 for val in values] for row in range(len(l1)) for col in range(len(l2))]
    row_ind, col_ind = linear_sum_assignment(cost_matrix)
    result = {}
    for i in range(len(row_ind)):
        if cost_matrix[row_ind[i]][col_ind[i]] != 0:
            result[l1[row_ind[i] // len(l2)] * len(l2) + l2[col_ind[i] % len(l2)]] = values[min(col_ind[i], len(values) - 1)]
    return result

def find_strong_connections(social_network: Dict[int, List[int]], start_user: int, depth: int, overlap: int) -> List[List[int]]:
    strong_connections = []
    queue = deque([(start_user, 0)])
    seen_users = set()
    
    while queue:
        user, current_depth = queue.popleft()
        
        if user in seen_users or current_depth > depth:
            continue
        
        seen_users.add(user)
        
        friends = social_network.get(user, [])
        queue.extend((friend, current_depth + 1) for friend in friends if friend not in seen_users)
        
        if current_depth > 0:
            if current_depth == 1:
                common_friends = set(friends)
            else:
                common_friends = set(social_network.get(user, []))
                
                for seen_user in seen_users:
                    common_friends = common_friends.intersection(social_network.get(seen_user, []))
            
            if len(common_friends) >= overlap:
                strong_connections.append(list(common_friends))
    
    return strong_connections

def trend_detection(time_series: List[int], window_size: int, confidence: float) -> bool:
    x = np.arange(len(time_series))
    y = np.array(time_series)
    
    # Calculate the Kendall tau statistic
    n = len(time_series)
    s = 0
    for i in range(n - 1):
        for j in range(i + 1, n):
            if (x[i] - x[j]) * (y[i] - y[j]) > 0:
                s += 1
            elif (x[i] - x[j]) * (y[i] - y[j]) < 0:
                s -= 1
    
    # Calculate the variance of the Kendall tau statistic
    var_s = (n * (n - 1) * (2 * n + 5)) / 18
    
    # Calculate the standard normal statistic
    z = (s - 1) / np.sqrt(var_s)
    
    # Calculate the p-value
    p_value = 2 * (1 - norm.cdf(abs(z)))
    
    # Return whether a trend is detected
    return p_value < (1 - confidence)

def bipartite_graph_checker(graph: Dict[int, List[int]], edges: List[Tuple[int, int]], vertices: List[int]) -> Union[List[int], str]:
    colors = {}
    
    for vertex in vertices:
        if vertex not in colors:
            queue = deque([vertex])
            colors[vertex] = 0
            
            while queue:
                current_vertex = queue.popleft()
                
                for neighbor in graph.get(current_vertex, []):
                    if neighbor not in colors:
                        colors[neighbor] = 1 - colors[current_vertex]
                        queue.append(neighbor)
                    elif colors[neighbor] == colors[current_vertex]:
                        return "Error: Graph is not bipartite"
    
    return list(colors.values())
```

File: string_joiner.py:

```Python
import re
from collections import defaultdict
from typing import List, Tuple
from math import log
from typing import List
import numpy as np
from typing import Dict, List
from typing import Dict

def ngram_extractor(text: str, ngrams: int, threshold: float) -> List[Tuple[List[str], float]]:
    words = re.findall(r'\b\w+\b', text.lower())
    word_freq = defaultdict(int)
    for word in words:
        word_freq[word] += 1
    
    total_words = len(words)
    tf_idf_scores = {}
    for word, freq in word_freq.items():
        tf = freq / total_words
        idf = log(total_words / (1 + freq))
        tf_idf_scores[word] = tf * idf
    
    ngrams_list = []
    for i in range(len(words) - ngrams + 1):
        ngram = tuple(words[i:i+ngrams])
        ngram_score = sum(tf_idf_scores.get(word, 0) for word in ngram) / ngrams
        if ngram_score > threshold:
            ngrams_list.append((list(ngram), ngram_score))
    
    return ngrams_list

def select_max_sum(nums: List[int], k: int) -> List[int]:
    nums.sort(reverse=True)
    
    selected = nums[:k]
    
    return selected

def precision_rounding(numbers: List[float], precision: int) -> List[float]:
    cumulative_error = 0
    rounded_numbers = []
    
    for num in numbers:
        rounded_num = round(num + cumulative_error, precision)
        cumulative_error += (num - rounded_num)
        rounded_numbers.append(rounded_num)
    
    return rounded_numbers

def greedy_sequence_selection(sequences: List[List[int]], duration: int) -> (List[List[int]], int):
    sequences.sort(key=lambda x: (sum(x), len(x)))
    total_value = 0
    selected_sequences = []
    current_duration = 0
    
    for sequence in sequences:
        sequence_duration = len(sequence)
        if current_duration + sequence_duration <= duration:
            total_value += sum(sequence)
            selected_sequences.append(sequence)
            current_duration += sequence_duration
    
    return selected_sequences, total_value

def calculate_eigen(matrix: List[List[float]], k: int) -> List[List[float]]:
    if not matrix or not all(len(row) == len(matrix) for row in matrix):
        return []  # Handle empty or non-square matrices
    
    matrix = np.array(matrix)
    n = len(matrix)
    eigenvectors = []
    
    for _ in range(k):
        vector = np.random.rand(n)
        vector /= np.linalg.norm(vector)
        
        for _ in range(100):  # Number of iterations
            new_vector = np.dot(matrix, vector)
            eigenvalue = np.dot(new_vector, vector)
            new_vector /= np.linalg.norm(new_vector)
            if np.allclose(vector, new_vector):
                break
            vector = new_vector
        
        eigenvectors.append(vector.tolist())
    
    return eigenvectors

def transpose_and_reverse(matrix: List[List[int]], n: int) -> List[List[int]]:
    if n > len(matrix):
        n = len(matrix)  # Adjust n if it exceeds matrix row count
    transposed = [[matrix[i][j] for i in range(n)] for j in range(len(matrix[0]))]
    reversed_transposed = [row[::-1] for row in transposed]
    
    return reversed_transposed

def largest_submatrix(matrix: List[List[int]], target: int) -> int:
    rows, cols = len(matrix), len(matrix[0])
    prefix_sum = [[0] * (cols + 1) for _ in range(rows + 1)]
    
    for i in range(1, rows + 1):
        for j in range(1, cols + 1):
            prefix_sum[i][j] = matrix[i - 1][j - 1] + prefix_sum[i - 1][j] + prefix_sum[i][j - 1] - prefix_sum[i - 1][j - 1]
    
    max_size = 0
    for i in range(rows):
        for j in range(cols):
            for k in range(i + 1, rows + 1):
                for end_col in range(j + 1, cols + 1):
                    submatrix_sum = prefix_sum[k][end_col] - prefix_sum[k][j] - prefix_sum[i][end_col] + prefix_sum[i][j]
                    if submatrix_sum <= target:
                        max_size = max(max_size, (k - i) * (end_col - j))
    
    return max_size

def partition_numbers(numbers: List[int], k: int) -> List[List[int]]:
    partitions = [[] for _ in range(k)]
    sums = [0] * k
    
    for num in numbers:
        min_sum_index = sums.index(min(sums))
        partitions[min_sum_index].append(num)
        sums[min_sum_index] += num
    
    return partitions

def gins_subgraph(network: Dict[str, List[str]], nodes: List[str]) -> Dict[str, List[str]]:
    subgraph = {node: [] for node in nodes}
    for node in nodes:
        for neighbor in network[node]:
            if neighbor in nodes:
                subgraph[node].append(neighbor)
    
    return subgraph

def join_strings_with_delimiter(lst: List[str], delimiter: str) -> str:
    return delimiter.join(lst)

def evaluate_expression(expression: str, variables: Dict[str, float]) -> Dict[str, object]:
    used_variables = {}
    for variable, value in variables.items():
        if re.search(r'\b' + variable + r'\b', expression):
            used_variables[variable] = value
            expression = expression.replace(variable, str(value))
    
    try:
        result = eval(expression)
    except Exception as e:
        return {"error": str(e)}
    
    return {"result": result, "used_variables": used_variables}
```

File: string_concatenator.py:

```Python
from typing import List
from typing import List, Tuple
from collections import Counter
from typing import List, Dict
import pandas as pd
from sklearn.tree import DecisionTreeRegressor
import heapq

def concatenate_strings(strings: List[str], max_length: int) -> str:
    strings.sort(key=len, reverse=True)
    concatenated = ""
    for string in strings:
        if len(concatenated) + len(string) <= max_length:
            concatenated += string
    return concatenated

def longest_contiguous_subsequence(sequence: List[int], length: int) -> List[int]:
    max_sum = float('-inf')
    max_subsequence = []
    current_sum = 0
    current_subsequence = []
    
    for num in sequence:
        current_sum += num
        current_subsequence.append(num)
        
        if len(current_subsequence) > length:
            current_sum -= current_subsequence.pop(0)
        
        if current_sum > max_sum and len(current_subsequence) >= length:
            max_sum = current_sum
            max_subsequence = current_subsequence[:]
    
    return max_subsequence

def search_2d_matrix(matrix: List[List[int]], target: int) -> Tuple[int, int]:
    for i in range(len(matrix)):
        for j in range(len(matrix[i])):
            if matrix[i][j] == target:
                return (i, j)
    return (-1, -1)

def analyze_stock_prices(prices: List[float], threshold: float) -> Dict[float, int]:
    price_dict = {}
    for idx, price in enumerate(prices):
        if price > threshold and price not in price_dict:
            price_dict[price] = 1
        elif price > threshold:
            price_dict[price] += 1
            
    return price_dict

def optimal_schedule(schedule: List[List[int]], available: List[int]) -> List[List[int]]:
    schedule.sort(key=lambda x: x[1])
    optimal = []
    last_end = -1
    
    for task in schedule:
        if task[0] >= last_end and task[1] <= available[0]:
            optimal.append(task)
            last_end = task[1]
            available[0] -= task[1] - task[0]
    
    return optimal

def particle_simulation(coordinates: List[Tuple[int, int]], velocities: List[Tuple[int, int]], time: int) -> List[Tuple[int, int]]:
    if not coordinates or not velocities or time <= 0:
        return coordinates
    
    min_x, min_y = min(x for x, y in coordinates), min(y for x, y in coordinates)
    max_x, max_y = max(x for x, y in coordinates), max(y for x, y in coordinates)
    
    updated_coordinates = []
    for (x, y), (vx, vy) in zip(coordinates, velocities):
        new_x, new_y = x + vx * time, y + vy * time
        new_x = max(min_x, min(new_x, max_x))
        new_y = max(min_y, min(new_y, max_y))
        updated_coordinates.append((new_x, new_y))
    
    return updated_coordinates

def check_matrix_means(matrices: List[List[List[int]]], threshold: int) -> List[bool]:
    means = []
    for matrix in matrices:
        flat_array = [num for sublist in matrix for subsublist in sublist for num in subsublist]
        mean = sum(flat_array) / len(flat_array)
        means.append(mean > threshold)
    return means

def can_construct_word(words, word):
    char_count = Counter()
    for w in words:
        char_count.update(w)  # Count occurrences of each character

    word_count = Counter(word)
    
    for char, count in word_count.items():
        if char_count[char] < count:  # Check availability against requested count
            return False
            
    return True

def count_occurrences(arr: List[int], x: int) -> Tuple[int, List[int], int, int]:
    indices = []
    
    for index, value in enumerate(arr):
        if value == x:
            indices.append(index)
    
    count = len(indices)
    if count > 0:
        return count, indices, max(indices), min(indices)
    
    return 0, [], -1, -1

def decision_tree_regressor(df: pd.DataFrame, feature_column: str, target_column: str) -> List[float]:
    X = df[feature_column].values.reshape(-1, 1)
    y = df[target_column].values
    
    model = DecisionTreeRegressor()
    model.fit(X, y)
    
    predicted_values = model.predict(X)
    
    return predicted_values.tolist()

def schedule_jobs(jobs: List[Tuple[int, int]], machines: int) -> List[List[Tuple[int, int]]]:
    pq = [(0, i) for i in range(machines)]
    heapq.heapify(pq)
    scheduled_jobs = [[] for _ in range(machines)]
    
    for job in sorted(jobs):
        _, machine_id = heapq.heappop(pq)
        scheduled_jobs[machine_id].append(job)
        heapq.heappush(pq, (job[1], machine_id))
    
    return scheduled_jobs
```

File: parentheses_checker.py:

```Python
from typing import List
from typing import List, Tuple, Dict
import math
from typing import List, Tuple
from collections import Counter
import heapq
from typing import Dict, List
import re
from collections import defaultdict

def flip_bits(bits: List[int]) -> List[int]:
    n = len(bits)
    max_length = 0
    start = 0
    
    for i in range(n):
        if bits[i] == 1:
            current_length = 1
            for j in range(i + 1, n):
                if bits[j] == 1:
                    current_length += 1
                else:
                    break
            if current_length > max_length:
                max_length = current_length
                start = i
    
    for i in range(start, start + max_length):
        bits[i] = 1
    
    return bits

def knn(points: List[Tuple[float, float]], k: int) -> Dict[Tuple[float, float], List[Tuple[float, float]]]:
    nearest_neighbors = {}
    for point in points:
        distances = []
        for other_point in points:
            if point == other_point:
                continue
            distance = math.sqrt((point[0] - other_point[0]) ** 2 + (point[1] - other_point[1]) ** 2)
            distances.append((distance, other_point))
        
        distances.sort(key=lambda x: x[0])
        nearest_neighbors[point] = [x[1] for x in distances[:k]]
    
    return nearest_neighbors

def search_matrix(matrix: List[List[int]], target: int) -> Tuple[int, int]:
    if not matrix or not matrix[0]:
        return -1, -1
    
    rows, cols = len(matrix), len(matrix[0])
    row, col = 0, cols - 1
    
    while row < rows and col >= 0:
        current = matrix[row][col]
        if current == target:
            return row, col
        elif current > target:
            col -= 1  # Move left
        else:
            row += 1  # Move down
    
    return -1, -1  # Target not found

def find_available_time_slots(intervals: List[Tuple[int, int]], appointments: List[Tuple[int, int]]) -> List[Tuple[int, int]]:
    # Combine intervals and appointments into a single list
    combined = intervals + appointments
    
    # Sort the combined list by start time
    combined.sort(key=lambda x: x[0])
    
    # Initialize the list of available time slots
    available_time_slots = []
    
    # Initialize the end time of the last appointment or interval
    last_end_time = 0
    
    # Iterate over the combined list
    for start, end in combined:
        # If the current start time is greater than the last end time, add the available time slot
        if start > last_end_time:
            available_time_slots.append((last_end_time, start))
        # Update the last end time if the current end time is greater
        last_end_time = max(last_end_time, end)
    
    # Add the available time slot after the last appointment or interval
    available_time_slots.append((last_end_time, 24 * 60))  # Assuming a 24-hour clock in minutes
    
    return available_time_slots

def are_parentheses_balanced(sequence: str) -> bool:
    stack = []
    mapping = {')': '(', '}': '{', ']': '['}
    
    for char in sequence:
        if char in mapping.values():
            stack.append(char)
        elif char in mapping.keys():
            if stack == [] or mapping[char] != stack.pop():
                return False
    
    return stack == []

def analyze_integer_frequencies(n, elements):
    frequency = Counter(elements)
    duplicates = sorted([x for x, count in frequency.items() if count > 1])
    unique_frequencies = {x: frequency[x] for x in duplicates}
    return unique_frequencies

def prim_mst_finder(n: int, edges: List[Tuple[int, int, int]]) -> List[Tuple[int, int, int]]:
    mst_edges = []
    visited = [False] * n
    priority_queue = []
    
    for i in range(n):
        if not visited[i]:
            heapq.heappush(priority_queue, (0, i))
            visited[i] = True
            
            while priority_queue:
                weight, node = heapq.heappop(priority_queue)
                
                for edge in edges:
                    if edge[0] == node or edge[1] == node:
                        neighbor = edge[0] if edge[1] == node else edge[1]
                        
                        if not visited[neighbor]:
                            heapq.heappush(priority_queue, (edge[2], neighbor))
                            visited[neighbor] = True
                            mst_edges.append(edge)
    
    return mst_edges

def parse_sentence(text: str, grammar_rules: Dict[str, List[str]]) -> Dict[str, object]:
    words = re.findall(r'\b\w+\b', text)
    tagged_words = []
    
    for word in words:
        tag = None
        for key, value in grammar_rules.items():
            if word in value:
                tag = key
                break
        tagged_words.append((word, tag))
    
    dependencies = defaultdict(list)
    for i, (word, tag) in enumerate(tagged_words):
        if tag == "VB" and i > 0:
            dependencies[tagged_words[i-1][1]].append(tag)
    
    return {"tagged_words": tagged_words, "dependencies": dict(dependencies)}

def matrix_threshold(matrix: List[List[int]], threshold: int) -> List[List[int]]:
    return [[1 if value > threshold else 0 for value in row] for row in matrix]

def matrix_pairs(matrix: List[List[int]], target: int) -> List[List[int]]:
    pairs = set()
    num_set = set()
    for row in matrix:
        for num in row:
            complement = target - num
            if complement in num_set:
                pair = tuple(sorted([num, complement]))
                pairs.add(pair)
            num_set.add(num)
    return [list(pair) for pair in pairs]

def pair_products(nums: List[int], k: int, threshold: int) -> List[Tuple[int, int]]:
    result = []
    seen = set()
    for i in range(len(nums)):
        for j in range(i+1, len(nums)):
            if nums[i] + nums[j] == k:
                product = nums[i] * nums[j]
                if product <= threshold:
                    pair = tuple(sorted([nums[i], nums[j]]))
                    if pair not in seen:
                        result.append(pair)
                        seen.add(pair)
    return result
```

File: number_rounding.py:

```Python
from typing import List
from typing import List, Tuple
import heapq
from collections import deque
import re

def quantile_buckets(numbers: List[float], num_buckets: int) -> List[float]:
    numbers.sort()
    bucket_size = len(numbers) / num_buckets
    boundaries = []
    for i in range(1, num_buckets):
        index = int(i * bucket_size)
        boundaries.append(numbers[index])
    return boundaries

def min_spanning_tree(graph: List[List[Tuple[int, int]]], start_node: int, k: int) -> List[Tuple[int, int, int]]:
    num_nodes = len(graph)
    min_heap = []
    visited = set()
    mst = []
    
    # Add all edges from the start node to the min heap
    for neighbor, weight in graph[start_node]:
        heapq.heappush(min_heap, (weight, start_node, neighbor))
    
    visited.add(start_node)
    
    while len(visited) < k:
        weight, node1, node2 = heapq.heappop(min_heap)
        if node2 not in visited:
            visited.add(node2)
            mst.append((node1, node2, weight))
            for neighbor, neighbor_weight in graph[node2]:
                if neighbor not in visited:
                    heapq.heappush(min_heap, (neighbor_weight, node2, neighbor))
    
    return mst

def binarize_matrix(matrix, threshold):
    # Binarize the matrix
    binary_matrix = [[1 if element >= threshold else 0 for element in row] for row in matrix]
    
    return binary_matrix

def reachable_positions(grid: List[List[int]], k: int) -> List[tuple]:
    rows, cols = len(grid), len(grid[0])
    directions = [(0, 1), (0, -1), (1, 0), (-1, 0)]
    visited = set()
    queue = deque([(0, 0, 0)])  # (row, col, steps)
    reachable = []
    
    while queue:
        row, col, steps = queue.popleft()
        
        if steps > k:
            break
        
        if (row, col) not in visited:
            visited.add((row, col))
            reachable.append((row, col))
            
            for dr, dc in directions:
                r, c = row + dr, col + dc
                
                if 0 <= r < rows and 0 <= c < cols:
                    queue.append((r, c, steps + 1))
    
    return reachable

def k_largest_numbers(sequence: List[int], k: int) -> List[int]:
    pq = []
    
    for num in sequence:
        if len(pq) < k:
            heapq.heappush(pq, num)
        elif num > pq[0]:
            heapq.heappop(pq)
            heapq.heappush(pq, num)
    
    return sorted(pq, reverse=True)

def max_histogram_area(arr: List[int]) -> int:
    stack = []
    max_area = 0
    
    for i in range(len(arr)):
        while stack and arr[stack[-1]] > arr[i]:
            height = arr[stack.pop()]
            width = i if not stack else i - stack[-1] - 1
            max_area = max(max_area, height * width)
        stack.append(i)
    
    while stack:
        height = arr[stack.pop()]
        width = len(arr) if not stack else len(arr) - stack[-1] - 1
        max_area = max(max_area, height * width)
    
    return max_area

def reverse_linked_list_after_k_nodes(linked_list: List[int], k: int) -> List[int]:
    if not linked_list:
        return linked_list
    
    result = []
    i = 0
    while i < len(linked_list):
        if i + k <= len(linked_list):
            result += linked_list[i + k - 1:i - 1:-1]
        else:
            result += linked_list[len(linked_list) - 1:i - 1:-1]
            break
        i += k
    
    return result

def sentence_extractor(text: str, keywords: List[str]) -> List[str]:
    sentences = re.split(r'[.!?]', text)
    extracted_sentences = []
    
    for sentence in sentences:
        sentence = re.sub(r'[^\w\s]', '', sentence).strip()
        if any(keyword.lower() in sentence.lower() for keyword in keywords):
            extracted_sentences.append(sentence)
            
    return extracted_sentences

def round_and_sum(numbers, precision):
    rounded_numbers = [round(num, precision) for num in numbers]
    total = sum(rounded_numbers)
    return total, rounded_numbers

def find_words_with_prefix(word_list: List[str], prefix: str, min_length: int, max_length: int) -> List[str]:
    return [word for word in word_list if word.startswith(prefix) and min_length <= len(word) <= max_length]

def triplet_sum(arrays: List[List[int]], target: int) -> List[List[int]]:
    result = []
    for i in range(len(arrays)):
        for j in range(len(arrays[i]) - 2):
            left, right = j + 1, len(arrays[i]) - 1
            while left < right:
                current_sum = arrays[i][j] + arrays[i][left] + arrays[i][right]
                if current_sum < target:
                    left += 1
                elif current_sum > target:
                    right -= 1
                else:
                    triplet = sorted([arrays[i][j], arrays[i][left], arrays[i][right]])
                    if triplet not in result:
                        result.append(triplet)
                    left += 1
                    right -= 1
    return result
```

File: row_subarray_finder.py:

```Python
from typing import List
from itertools import combinations
import random
import heapq
from typing import List, Tuple
from collections import deque

def max_sum_subarray(n, k, arr):
    max_sum = -float('inf')
    max_index = -1
    
    for i in range(n - k + 1):
        current_sum = sum(arr[i:i + k])
        if current_sum > max_sum:
            max_sum = current_sum
            max_index = i
            
    return max_sum, max_index

def pattern_search(matrix: List[List[int]], pattern: List[int]) -> int:
    count = 0
    rows, cols = len(matrix), len(matrix[0])
    pattern_length = len(pattern)
    
    # Check horizontal occurrences
    for row in range(rows):
        for col in range(cols - pattern_length + 1):
            match = True
            for i in range(pattern_length):
                if matrix[row][col + i] != pattern[i]:
                    match = False
                    break
            if match:
                count += 1
    
    # Check vertical occurrences
    for row in range(rows - pattern_length + 1):
        for col in range(cols):
            match = True
            for i in range(pattern_length):
                if matrix[row + i][col] != pattern[i]:
                    match = False
                    break
            if match:
                count += 1
    
    # Check diagonal occurrences (top-left to bottom-right)
    for row in range(rows - pattern_length + 1):
        for col in range(cols - pattern_length + 1):
            match = True
            for i in range(pattern_length):
                if matrix[row + i][col + i] != pattern[i]:
                    match = False
                    break
            if match:
                count += 1
    
    # Check diagonal occurrences (bottom-left to top-right)
    for row in range(pattern_length - 1, rows):
        for col in range(cols - pattern_length + 1):
            match = True
            for i in range(pattern_length):
                if matrix[row - i][col + i] != pattern[i]:
                    match = False
                    break
            if match:
                count += 1
    
    return count

def find_smallest_element(array, rotations):
    low, high = 0, len(array) - 1
    
    while low < high:
        mid = (low + high) // 2
        if array[mid] > array[high]:
            low = mid + 1
        else:
            high = mid
    
    return low

def generate_association_rules(transactions, min_confidence):
    item_counts = {}
    for transaction in transactions:
        for item in transaction:
            if item not in item_counts:
                item_counts[item] = 0
            item_counts[item] += 1
    
    frequent_items = [item for item, count in item_counts.items() if count / len(transactions) >= 0.1]
    
    association_rules = []
    for k in range(2, len(frequent_items) + 1):
        candidate_itemsets = list(combinations(frequent_items, k))
        for candidate_itemset in candidate_itemsets:
            itemset_counts = {}
            for transaction in transactions:
                if set(candidate_itemset).issubset(set(transaction)):
                    itemset_counts[candidate_itemset] = itemset_counts.get(candidate_itemset, 0) + 1
            
            for itemset, count in itemset_counts.items():
                confidence = count / len(transactions)
                if confidence >= min_confidence:
                    antennas = list(combinations(itemset, 1))
                    for antenna in antennas:
                        consequence = tuple(set(itemset) - set(antenna))
                        association_rules.append((antenna, consequence, confidence))
    
    return association_rules

def maze_generator(grid: List[List[int]]) -> List[List[int]]:
    rows, cols = len(grid), len(grid[0])
    directions = [(0, 1), (0, -1), (1, 0), (-1, 0)]
    maze = [[0 for _ in range(cols)] for _ in range(rows)]
    stack = [(0, 0)]
    
    while stack:
        row, col = stack[-1]
        maze[row][col] = 1
        directions_list = list(directions)
        random.shuffle(directions_list)
        for dr, dc in directions_list:
            nr, nc = row + 2 * dr, col + 2 * dc
            if 0 <= nr < rows and 0 <= nc < cols and maze[nr][nc] == 0:
                maze[nr - dr][nc - dc] = 1
                stack.append((nr, nc))
                break
        else:
            stack.pop()
    
    return maze

def top_k_diagonal(matrix: List[List[int]], k: int) -> List[int]:
    diagonal_elements = []
    for i in range(min(len(matrix), len(matrix[0]))):
        diagonal_elements.append(matrix[i][i])
    
    return heapq.nlargest(k, diagonal_elements)

def find_contiguous_subarrays(matrix: List[List[int]], target: int) -> List[Tuple[int, List[Tuple[int, int]]]]:
    result = []
    
    for i, row in enumerate(matrix):
        current_sum = 0
        start = 0
        subarrays = []
        
        for end in range(len(row)):
            current_sum += row[end]
            
            while current_sum > target and start <= end:
                current_sum -= row[start]
                start += 1
            
            if current_sum == target:
                subarrays.append((start, end))
        
        if subarrays:
            result.append((i, subarrays))
    
    return result

def max_weight_interval(intervals: List[List[int]], weights: List[int]) -> int:
    if not intervals:
        return 0
    
    intervals.sort(key=lambda x: x[1])
    
    max_weights = [0] * len(intervals)
    max_weights[0] = weights[0]
    
    for i in range(1, len(intervals)):
        max_weight = weights[i]
        for j in range(i):
            if intervals[j][1] <= intervals[i][0]:
                max_weight = max(max_weight, max_weights[j] + weights[i])
        max_weights[i] = max(max_weight, max_weights[i - 1])
    
    return max_weights[-1]

def generate_ngrams(text: str, n: int) -> List[str]:
    words = text.split()
    ngrams = set(' '.join(words[i:i+n]) for i in range(len(words) - n + 1) if i + n <= len(words))
    return sorted(ngrams)

def scheduler(tasks: List[Tuple[int, int]], k: int) -> int:
    tasks.sort(key=lambda x: x[1])
    computers = [0] * k
    
    for duration, _ in tasks:
        min_computer = computers.index(min(computers))
        computers[min_computer] += duration
        
    return max(computers)

def median_component(graph: List[List[int]], vertices: int) -> List[List[List[int]]]:
    total_distance = 0
    distance_matrix = [[float('inf')] * vertices for _ in range(vertices)]
    
    for i in range(vertices):
        distance_matrix[i][i] = 0
    
    for u, v in graph:
        distance_matrix[u][v] = distance_matrix[v][u] = 1
    
    for k in range(vertices):
        for i in range(vertices):
            for j in range(vertices):
                distance_matrix[i][j] = min(distance_matrix[i][j], distance_matrix[i][k] + distance_matrix[k][j])
                total_distance += distance_matrix[i][j]
    
    median_distance = total_distance // (vertices * (vertices - 1) // 2)
    
    visited = [False] * vertices
    median_component = []
    subgraph1 = []
    subgraph2 = []
    
    for start in range(vertices):
        if not visited[start]:
            queue = deque([start])
            visited[start] = True
            subgraph = [start]
            
            while queue:
                node = queue.popleft()
                for neighbor, edge_length in enumerate(distance_matrix[node]):
                    if edge_length == median_distance and not visited[neighbor]:
                        queue.append(neighbor)
                        visited[neighbor] = True
                        subgraph.append(neighbor)
            
            median_component.append(subgraph)
            if len(subgraph) > len(median_component[0]):
                subgraph1 = median_component[0]
                median_component[0] = subgraph
            else:
                subgraph2 = subgraph
    
    return [subgraph1, subgraph2]
```

File: rle_algorithm.py:

```Python
from typing import List
from collections import defaultdict
import random
from typing import Dict, List
from numpy import zeros
import numpy as np
from collections import deque
from typing import List, Tuple
from typing import List, Dict

def is_anagram_group(strings: List[str], threshold: int) -> bool:
    anagram_map = defaultdict(list)
    
    for string in strings:
        sorted_string = "".join(sorted(string))
        anagram_map[sorted_string].append(string)
    
    for anagrams in anagram_map.values():
        if len(anagrams) >= threshold:
            return True
    
    return False

def markov_predictor(sequence: List[int], k: int) -> List[int]:
    # Calculate transition probabilities
    transition_probabilities = defaultdict(dict)
    for i in range(len(sequence) - 1):
        current = sequence[i]
        next = sequence[i + 1]
        if next not in transition_probabilities[current]:
            transition_probabilities[current][next] = 0
        transition_probabilities[current][next] += 1
    
    for current in transition_probabilities:
        total = sum(transition_probabilities[current].values())
        for next in transition_probabilities[current]:
            transition_probabilities[current][next] /= total
    
    # Predict next K elements
    predictions = []
    current = sequence[-1]
    for _ in range(k):
        next = random.choices(list(transition_probabilities[current].keys()), weights=list(transition_probabilities[current].values()))[0]
        predictions.append(next)
        current = next
    
    return predictions

def smith_waterman_alignment(sequence: str, pattern: str, mismatch_tolerance: int) -> List[str]:
    scoring_matrix = zeros((len(pattern) + 1, len(sequence) + 1), dtype=int)
    for i in range(1, len(pattern) + 1):
        for j in range(1, len(sequence) + 1):
            match = scoring_matrix[i - 1, j - 1] + (1 if pattern[i - 1] == sequence[j - 1] else -1)
            delete = scoring_matrix[i - 1, j] - 1
            insert = scoring_matrix[i, j - 1] - 1
            scoring_matrix[i, j] = max(0, match, delete, insert)
    max_score = 0
    max_position = (0, 0)
    for i in range(len(pattern) + 1):
        for j in range(len(sequence) + 1):
            if scoring_matrix[i, j] > max_score:
                max_score = scoring_matrix[i, j]
                max_position = (i, j)
    aligned_pattern = ""
    aligned_sequence = ""
    i, j = max_position
    while scoring_matrix[i, j] > 0:
        if i > 0 and j > 0 and pattern[i - 1] == sequence[j - 1]:
            aligned_pattern = pattern[i - 1] + aligned_pattern
            aligned_sequence = sequence[j - 1] + aligned_sequence
            i -= 1
            j -= 1
        elif i > 0 and scoring_matrix[i, j] == scoring_matrix[i - 1, j] - 1:
            aligned_pattern = pattern[i - 1] + aligned_pattern
            aligned_sequence = "-" + aligned_sequence
            i -= 1
        elif j > 0 and scoring_matrix[i, j] == scoring_matrix[i, j - 1] - 1:
            aligned_pattern = "-" + aligned_pattern
            aligned_sequence = sequence[j - 1] + aligned_sequence
            j -= 1
    return aligned_pattern, aligned_sequence

def rle_compression(binary_string: str) -> str:
    if not binary_string:
        return ''
    
    compressed = ''
    count = 1
    for i in range(1, len(binary_string)):
        if binary_string[i] == binary_string[i - 1]:
            count += 1
        else:
            compressed += binary_string[i - 1] + str(count)
            count = 1
    compressed += binary_string[-1] + str(count)
    
    return compressed

def find_eigenvector(matrix: List[List[float]], eigenvalue: float) -> List[float]:
    A = np.array(matrix)
    eigenvalues, eigenvectors = np.linalg.eig(A)
    for i, e in enumerate(eigenvalues):
        if np.isclose(e, eigenvalue):
            return eigenvectors[:, i].tolist()
    return None

def calculate_max_sums(sequences: List[List[int]], window_size: int) -> List[List[int]]:
    max_sums = []
    for sequence in sequences:
        prefix_sums = [0] * (len(sequence) + 1)
        for i in range(len(sequence)):
            prefix_sums[i + 1] = prefix_sums[i] + sequence[i]
        
        max_sum = float('-inf')
        for i in range(len(sequence) - window_size + 1):
            window_sum = prefix_sums[i + window_size] - prefix_sums[i]
            max_sum = max(max_sum, window_sum)
        
        max_sums.append(max_sum)
    
    return max_sums

def smooth_time_series(time_series, window_size):
    if window_size == 1:
        return time_series
    
    if window_size > len(time_series):
        return [None] * len(time_series)
    
    smoothed = []
    
    for i in range(len(time_series)):
        if i < window_size - 1:
            smoothed.append(None)
        else:
            window = time_series[i - window_size + 1:i + 1]
            smoothed.append(sum(window) / window_size)
    
    return smoothed

def bfs_shortest_distance(graph: dict, start: str) -> dict:
    distances = {node: float('inf') for node in graph}
    distances[start] = 0
    queue = deque([start])
    
    while queue:
        node = queue.popleft()
        for neighbor in graph[node]:
            if distances[neighbor] > distances[node] + 1:
                distances[neighbor] = distances[node] + 1
                queue.append(neighbor)
    
    return distances

def max_non_overlapping_coincidences(coincidences: List[Tuple[int, int]], tolerance: int) -> int:
    coincidences.sort(key=lambda x: x[1])
    max_count = 0
    end_time = 0
    
    for start, end in coincidences:
        if start - end_time > tolerance:
            max_count += 1
            end_time = end
    
    return max_count

def motif_finder(sequences: List[List[int]], motifs: List[List[int]], min_occurrences: int) -> Dict[str, float]:
    result = {}
    
    for motif in motifs:
        occurrences = 0
        for sequence in sequences:
            for i in range(len(sequence) - len(motif) + 1):
                if sequence[i:i+len(motif)] == motif:
                    occurrences += 1
                    break
        frequency = occurrences / len(sequences)
        if frequency > 0 and frequency <= 0.5:
            result[str(motif)] = frequency
    
    return result

def svd_reconstruction(matrix, k):
    # Perform SVD on the matrix
    U, s, Vh = np.linalg.svd(matrix, full_matrices=False)
    
    # Retain only the top-k singular values and singular vectors
    Uk = U[:, :k]
    sk = s[:k]
    Vkh = Vh[:k, :]
    
    # Reconstruct the matrix from the retained singular values and singular vectors
    reconstructed_matrix = Uk @ np.diag(sk) @ Vkh
    
    return reconstructed_matrix
```

--------------------------------------------------------------------------------------------------

Problem Statement: Parameters:
- points: List[Tuple[float, float]] # A list of (x, y) coordinate tuples representing points in a 2D space.
- k: int # The number of nearest neighbors to find from the origin (0, 0).
- graph: Dict[str, List[str]] # A dictionary representing a graph where each key is a node and its value is a list of neighboring nodes.
- source: str # The starting node for finding the shortest paths in the graph.
- weights: List[int] # A list of weights for items to be packed into bins.
- capacities: List[int] # A list of capacities for the bins into which the weights will be packed.

Objectives:
- Calculate the k nearest points from the origin using the provided `points` parameter. Store the result in a variable named `nearest_points`.
- Generate the shortest path distances from the specified `source` node by analyzing the `graph` parameter. Store this result in a variable named `shortest_paths`.
- Use the `weights` and `capacities` parameters to apply a bin-packing algorithm that assigns the weights to the bins without exceeding their capacity. Store this result in a variable named `packed_bins`.
- Register a custom criterion to ensure that the number of packed bins returned does not exceed a specific threshold (e.g., 5). If the number of packed bins exceeds this threshold, return only the first 5 bins.
- Combine the results of `nearest_points`, `shortest_paths`, and `packed_bins` into a dictionary called `final_report` where:
  - The key "nearest_points" maps to `nearest_points`.
  - The key "shortest_paths" maps to a tuple containing `shortest_paths['distances']` and `shortest_paths['previous_nodes']`.
  - The key "packed_bins" maps to `packed_bins`.
- Finally, ensure to return the `final_report` dictionary which encapsulates all the previously obtained results in a structured format.

Return Values:
- final_report: Dict[str, Any] # A dictionary containing the nearest points, shortest paths, and packed bins information.

The name of the function you create should be complex_analysis

--------------------------------------------------------------------------------------------------

Answer Code:
def complex_analysis(points: List[Tuple[float, float]], 
                     k: int, 
                     graph: Dict[str, List[str]], 
                     source: str, 
                     weights: List[int], 
                     capacities: List[int]) -> Dict[str, Any]:
    # Step 1: Find the k nearest points from the origin
    nearest_points = find_k_nearest_points(points, k)
    
    # Step 2: Find the shortest path distances from the source node
    shortest_paths = dijkstra_algorithm(graph, source)
    
    # Step 3: Pack weights into bins based on their capacities
    packed_bins = bin_packing(weights, capacities)
    
    # Step 4: Ensure the number of packed bins does not exceed the threshold of 5
    if len(packed_bins) > 5:
        packed_bins = packed_bins[:5]
    
    # Step 5: Create a final report dictionary encapsulating results
    final_report = {
        "nearest_points": nearest_points,
        "shortest_paths": (shortest_paths['distances'], shortest_paths['previous_nodes']),
        "packed_bins": packed_bins
    }
    
    return final_report

--------------------------------------------------------------------------------------------------

Test Code:
# Import statements if required
import math
import heapq
from typing import List, Dict, Tuple, Any

# Import function from file
from complex_solver import complex_analysis

# Initialize input parameters
points = [(1, 2), (3, 4), (0, 5), (2, 3), (1, 1)]
k = 3
graph = {
    'A': ['B', 'C'],
    'B': ['A', 'D', 'E'],
    'C': ['A', 'F'],
    'D': ['B'],
    'E': ['B', 'F'],
    'F': ['C', 'E']
}
source = 'A'
weights = [2, 3, 5, 7]
capacities = [10, 10, 10]

# Call function with input parameters
return_final_report = complex_analysis(points, k, graph, source, weights, capacities)

# Step-by-step run-through of function to obtain intermediate outputs:

# Step 1
# Explanation: Finding the k nearest points from the origin (0,0).
distances = [(math.sqrt(x**2 + y**2), (x, y)) for x, y in points]
sorted_points = sorted(distances, key=lambda item: item[0])
nearest_points = [point[1] for point in sorted_points[:k]]  # Get top k points
correct_nearest_points = nearest_points

# Step 2
# Explanation: Running Dijkstra's algorithm to find shortest paths from the source node.
distances_dict = {node: float('inf') for node in graph}
previous_nodes = {node: None for node in graph}
distances_dict[source] = 0
priority_queue = [(0, source)]

while priority_queue:
    current_distance, current_node = heapq.heappop(priority_queue)
    
    if current_distance > distances_dict[current_node]:
        continue
    
    for neighbor in graph[current_node]:
        distance = current_distance + 1  # Each edge has weight 1
        if distance < distances_dict[neighbor]:
            distances_dict[neighbor] = distance
            previous_nodes[neighbor] = current_node
            heapq.heappush(priority_queue, (distance, neighbor))

correct_shortest_paths = (distances_dict, previous_nodes)

# Step 3
# Explanation: Using first-fit decreasing algorithm to pack weights into bins.
weights.sort(reverse=True)
bins = [[] for _ in range(len(capacities))]
bin_weights = [0] * len(capacities)

for weight in weights:
    for i, capacity in enumerate(capacities):
        if bin_weights[i] + weight <= capacity:
            bins[i].append(weight)
            bin_weights[i] += weight
            break

correct_packed_bins = bins[:5]  # Ensure number of packed bins does not exceed 5

# Final Expected Output:
correct_final_report = {
    "nearest_points": correct_nearest_points,
    "shortest_paths": correct_shortest_paths,
    "packed_bins": correct_packed_bins
}

# Assert statements (compulsory) to check if the function returns the correct values:
assert return_final_report == correct_final_report

print('All-Pass')

--------------------------------------------------------------------------------------------------

