std::experimental:: boyer_moore_horspool_searcher, std::experimental:: make_boyer_moore_horspool_searcher
|
헤더 파일에 정의됨
<experimental/functional>
|
||
|
template
<
class
RandomIt1,
class
Hash
=
std::
hash
<
typename
std::
iterator_traits
<
RandomIt1
>
::
value_type
>
,
|
(라이브러리 fundamentals TS) | |
std::experimental::search 와 함께 사용하기 적합한 검색기로, Boyer-Moore-Horspool 문자열 검색 알고리즘 을 구현합니다.
boyer_moore_horspool_searcher
는
CopyConstructible
와
CopyAssignable
입니다.
RandomIt1
는
LegacyRandomAccessIterator
요구 사항을 충족해야 합니다.
목차 |
멤버 함수
std::experimental::boyer_moore_horspool_searcher:: boyer_moore_horspool_searcher
|
boyer_moore_horspool_searcher
(
RandomIt1 pat_first,
RandomIt1 pat_last,
|
||
boyer_moore_horspool_searcher
를 생성하며,
pat_first
,
pat_last
,
hf
, 그리고
pred
의 복사본을 저장하고 필요한 내부 데이터 구조를 설정합니다.
RandomIt1
의 값 타입은
DefaultConstructible
,
CopyConstructible
, 그리고
CopyAssignable
이어야 합니다.
타입
std::
iterator_traits
<
RandomIt1
>
::
value_type
의 임의의 두 값
A
와
B
에 대해,
pred
(
A, B
)
==
true
이면,
hf
(
A
)
==
hf
(
B
)
가
true
이어야 합니다.
매개변수
| pat_first, pat_last | - | 검색할 문자열을 지정하는 반복자 쌍 |
| hf | - | 문자열의 요소를 해시하는 데 사용되는 호출 가능 객체 |
| pred | - | 동등성을 결정하는 데 사용되는 호출 가능 객체 |
예외
다음에 의해 발생하는 모든 예외:
-
RandomIt1의 복사 생성자; -
RandomIt1의 값 타입의 기본 생성자, 복사 생성자, 또는 복사 할당 연산자; 또는 -
BinaryPredicate또는Hash의 복사 생성자 또는 함수 호출 연산자.
또한 내부 데이터 구조에 필요한 추가 메모리를 할당할 수 없는 경우 std::bad_alloc 을 던질 수 있습니다.
std::experimental::boyer_moore_horspool_searcher:: operator()
|
template
<
class
RandomIt2
>
RandomIt2 operator ( ) ( RandomIt2 first, RandomIt2 last ) const ; |
(C++17 이전) | |
|
template
<
class
RandomIt2
>
std:: pair < RandomIt2,RandomIt2 > operator ( ) ( RandomIt2 first, RandomIt2 last ) const ; |
(C++17 이후) | |
이 검색기로 검색을 수행하기 위해
std::experimental::search
가 호출하는 멤버 함수입니다.
RandomIt2
는
LegacyRandomAccessIterator
요구사항을 충족해야 합니다.
RandomIt1
과
RandomIt2
는 동일한 값 타입을 가져야 합니다.
매개변수
| first, last | - | 검사할 문자열을 지정하는 반복자 쌍 |
반환 값
|
패턴
그렇지 않으면,
|
(C++17 이전) |
|
패턴
그렇지 않으면,
|
(C++17 이후) |
헬퍼 함수
|
template
<
class
RandomIt,
class
Hash
=
std::
hash
<
typename
std::
iterator_traits
<
RandomIt
>
::
value_type
>
,
|
(라이브러리 fundamentals TS) | |
템플릿 인자 추론을 사용하여
std::experimental::boyer_moore_horspool_searcher
를 구성하는 헬퍼 함수입니다. 다음 코드와 동일합니다:
return
boyer_moore_horspool_searcher
<
RandomIt, Hash, BinaryPredicate
>
(
pat_first, pat_last, hf, pred
)
;
매개변수
| pat_first, pat_last | - | 검색할 문자열을 지정하는 한 쌍의 반복자 |
| hf | - | 문자열의 요소를 해시하는 데 사용되는 호출 가능 객체 |
| pred | - | 동등성을 결정하는 데 사용되는 호출 가능 객체 |
반환값
boyer_moore_horspool_searcher
가 인수
pat_first
,
pat_last
,
hf
, 그리고
pred
로 생성된 경우.
예제
#include <experimental/algorithm> #include <experimental/functional> #include <iostream> #include <string> int main() { std::string in = "Lorem ipsum dolor sit amet, consectetur adipiscing elit," " sed do eiusmod tempor incididunt ut labore et dolore magna aliqua"; std::string needle = "pisci"; auto it = std::experimental::search(in.begin(), in.end(), std::experimental::make_boyer_moore_horspool_searcher( needle.begin(), needle.end())); if (it != in.end()) std::cout << "The string " << needle << " found at offset " << it - in.begin() << '\n'; else std::cout << "The string " << needle << " not found\n"; }
출력:
The string pisci found at offset 43
참고 항목
|
요소 범위의 첫 번째 발생을 검색합니다
(function template) |