Существует пять составных компонентов верхнего уровня этого регулярного выражения. Согласно алгоритму, восстанавливаемому из части теоремы Клини, вы можете сделать NFA-лямбды для них, а затем сформировать конкатенацию, соединив конечные состояния одного с начальными состояниями следующего.
Когда вы видите объединение, это означает, что вы делаете две машины и объединяете их, создавая новое начальное состояние с двумя лямбда-переходами.
Закрытие Клини немного сложнее, но в основном делает машину для повторяющейся вещи, затем преобразует ее, добавляя новое принимающее начальное состояние и цикл к нему из старых конечных состояний.
Базовый регистр - это машина для одной буквы, которая состоит из двух состояний, начального и конечного, с соответствующим помеченным переходом.
Работайте рекурсивно от самых простых машин (самые внутренние подвыражения) до целого, комбинируя при необходимости. Упростите результат настолько, насколько вам нравится, возможно, преобразовав его в минимальный DFA.