std::regex를 사용하여 여러 결과 일치
정규 표현식을 사용하면 문자열에서 여러 단어를 일치시키는 것이 어려울 수 있습니다. "(bS*b){0,}" 표현식은 문자열의 모든 연속 단어와 일치하는 것처럼 보이지만 원하는 결과를 얻지 못할 수도 있습니다. 대신 반복적인 접근 방식이 권장됩니다.
수정된 코드는 다음과 같습니다.
#include <iostream> #include <string> #include <regex> int main() { regex exp("(\b\S*\b)"); smatch res; string str = "first second third forth"; string::const_iterator searchStart(str.cbegin()); while (regex_search(searchStart, str.cend(), res, exp)) { cout << (searchStart == str.cbegin() ? "" : " ") << res[0]; searchStart = res.suffix().first; } cout << endl; return 0; }
이 업데이트된 코드에서는 while 루프를 사용하여 정규식 검색을 수행하는 동안 문자열을 반복합니다. 루프는 searchStart 반복자를 문자열의 시작 부분으로 설정하여 시작됩니다. 그런 다음 각 반복 내에서:
더 이상 일치하는 항목이 없을 때까지 문자열을 반복하여 모든 단어를 하나씩 출력할 수 있습니다.
위 내용은 C의 `std::regex`를 사용하여 문자열의 여러 단어를 효율적으로 일치시키려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!