import dataclasses
from collections.abc import Iterable, Iterator
from typing import Generic, TypeVar

T = TypeVar('T')

@dataclasses.dataclass
class LinkedListNode(Generic[T]):
    value: T
    next: 'LinkedListNode | None' = None

    def __init__(self, value):
        self.value = value
        self.next = None

class LinkedList(Generic[T]):

    head: LinkedListNode | None
    tail: LinkedListNode | None

    def __init__(self, values: Iterable[T]=()):
        self.head = None
        self.tail = None
        for value in values:
            self.append(value)

    def append(self, value: T) -> None:
        self.append_node(LinkedListNode(value))

    def append_node(self, node: LinkedListNode[T]) -> None:
        if self.head is None:
            self.head = self.tail = node
        else:
            self.tail.next = node
            self.tail = node

    def extend(self, linked_list: 'LinkedList[T]') -> None:
        # Constant time. The argument linked_list will not be modified
        # immediately, but it can be later if this list is modified afterwards.
        if self.head is None:
            self.head = linked_list.head
        else:
            self.tail.next = linked_list.head
        self.tail = linked_list.tail

    def values(self) -> Iterable[T]:
        curr = self.head
        while curr is not None:
            yield curr.value
            curr = curr.next

    def __iter__(self) -> Iterator[T]:
        return iter(self.values())
