Как написать регулярку, находящую первое вхождение символа 'A', когда символ 'B' встречался до него 0 или чётное количество раз?
Если перефразировать, то надо найти первое вхождение символа 'А', которое не предворялось нечётным вхождением символа 'В'. Символы 'B' не обязательно должны идти подряд.
Строки совпадающие:
Х Х Х Х А В // Символ 'A' найден, вхождение символа 'B' перед ним 0 раз В Х В Х А Х // Символ 'A' найден, вхождение символа 'B' перед ним 2 раза (чёт) В В В ВА Х // Символ 'A' найден, вхождение символа 'B' перед ним 4 раза (чёт) В А В Х А Х // Символ 'A' найден, вхождение символа 'B' перед ним 2 раза (чёт). Первое вхождение проигнорировано, так как перед ним только одно вхождение 'B'
Строки не совпадающие:
Х Х Х Х Х Х // Символ 'A' не найден
Х Х В Х А Х // Символ 'A' найден, но вхождение символа 'B' перед ним 1 раз (нечет) В В Х ВА Х // Символ 'A' найден, но вхождение символа 'B' перед ним 3 раза (нечет)