from collections import defaultdict


class AttributeValueTable:
    def __init__(self):
        self.num_examples = 0
        self.num_positive = 0
        self.num_negative = 0
        self.table = {}
        self.attrs = set()
        self.positive_values = defaultdict(set)


    def update(self, instance: dict, label: bool) -> None:
        if label:
            self.num_positive += 1
        else:
            self.num_negative += 1

        for attr, val in instance.items():
            self.attrs.add(attr)
            self._update(attr, val, label)

    def _update(self, attr: str, val: str, label: bool) -> None:
        # Keep track of which values appear in positive examples
        if label:
            self.positive_values[attr].add(val)

        if attr not in self.table:
            self.table[attr] = {val: {'p': 0, 'n': 0}}
        elif val not in self.table[attr]:
            self.table[attr][val] = {'p': 0, 'n': 0}
        if label:
            self.table[attr][val]['p'] += 1
        else:
            self.table[attr][val]['n'] += 1
