import networkx as nx
from utils.util import density

def charikar_densest_subgraph_with_bounds(G, min_subset_size, max_subset_size):
    """
    Charikar's 2-approximation algorithm for finding the densest subgraph with size constraints.
    
    Args:
        G (networkx.Graph): The input graph.
        min_subset_size (int): Minimum number of vertices in a subgraph.
        max_subset_size (int): Maximum number of vertices in a subgraph.

    Returns:
        networkx.Graph: The densest subgraph within the specified size constraints.
    """
    H = G.copy()
    best_subgraph = None
    best_density = float('-inf')

    while H.number_of_nodes() > 0:
        n = H.number_of_nodes()
        m = H.number_of_edges()
        
        # Check if current subgraph satisfies size constraints
        if min_subset_size <= n <= max_subset_size:
            current_density = (2.0 * m) / n if n > 0 else 0
            if current_density > best_density:
                best_density = current_density
                best_subgraph = H.copy()

        # Remove minimum degree node
        if H.number_of_nodes() > 0:
            min_degree_node = min(H.degree, key=lambda x: x[1])[0]
            H.remove_node(min_degree_node)

    return best_subgraph

def densest_subgraph(G, min_subset_size, max_subset_size):
    """
    Finds the densest subgraph using Charikar's 2-approximation algorithm.

    Args:
        G (networkx.Graph): The input graph.
        min_subset_size (int): Minimum number of vertices in a subgraph.
        max_subset_size (int): Maximum number of vertices in a subgraph.

    Returns:
        networkx.Graph: The densest subgraph within the specified size constraints.
    """
    return charikar_densest_subgraph_with_bounds(G, min_subset_size, max_subset_size)
