>백엔드 개발 >C++ >C의 `std::regex`를 사용하여 문자열의 여러 단어를 효율적으로 일치시키려면 어떻게 해야 합니까?

C의 `std::regex`를 사용하여 문자열의 여러 단어를 효율적으로 일치시키려면 어떻게 해야 합니까?

DDD
DDD원래의
2024-11-29 12:51:11395검색

How Can I Efficiently Match Multiple Words in a String Using C  's `std::regex`?

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 반복자를 문자열의 시작 부분으로 설정하여 시작됩니다. 그런 다음 각 반복 내에서:

  1. regex_search 함수는 searchStart에서 시작하는 하위 문자열 내에서 패턴이 처음 나타나는 것을 검색합니다.
  2. 일치하는 항목이 발견되면 일치하는 단어를 인쇄합니다. .
  3. 일치된 항목 이후에 검색을 시작하도록 searchStart 반복자를 업데이트합니다. word.

더 이상 일치하는 항목이 없을 때까지 문자열을 반복하여 모든 단어를 하나씩 출력할 수 있습니다.

위 내용은 C의 `std::regex`를 사용하여 문자열의 여러 단어를 효율적으로 일치시키려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.