>  기사  >  백엔드 개발  >  C++_STL의 공통 컨테이너 요약: 연관 컨테이너와 순차 컨테이너 쌍

C++_STL의 공통 컨테이너 요약: 연관 컨테이너와 순차 컨테이너 쌍

php是最好的语言
php是最好的语言원래의
2018-07-28 11:31:122317검색

pair pair

이 부분에서는 먼저 연관 컨테이너와 시퀀스 컨테이너의 공통 기능을 소개합니다. pair pair 작업을 수행한 다음 일반적으로 사용되는 몇 가지 특정 관련 컨테이너를 소개합니다.

1. 연관 컨테이너

연관 컨테이너는 키별 효율적인 쿼리를 지원하는 일종의 저장소 객체 컬렉션입니다. 연관 컨테이너의 동작 대부분은 순차 컨테이너의 동작과 동일합니다. 둘 사이의 본질적인 차이점은 연관 컨테이너는 키별로 요소를 저장하고 읽는 반면 순차 컨테이너는 컨테이너의 위치에 따라 요소를 순차적으로 저장하고 액세스한다는 것입니다.
연관 컨테이너의 각 요소에는 키와 값이 포함되어 있습니다. 요소가 연관 컨테이너에 삽입되면 컨테이너의 내부 데이터 구조는 키 값의 크기를 기반으로 하는 특정 규칙에 따라 요소를 적절한 위치에 배치합니다. 연관 컨테이너에는 소위 헤드와 테일이 없으며 가장 큰 요소와 가장 작은 요소만 있습니다. 연관 컨테이너는 front, push_front, pop_front, back, push_back 및 pop_back 작업을 제공하지 않습니다.
표준 STL 연관 컨테이너는 집합(집합)과 지도(매핑)의 두 가지 범주와 그 파생물인 다중 집합(다중 키 집합)과 다중 맵(다중 키 매핑 테이블)으로 나뉩니다. 이러한 컨테이너의 기본 메커니즘은 모두 RB-트리(레드-블랙 트리)로 구현됩니다.

2. 연관 컨테이너와 순차 컨테이너의 일반적인 작업

1. 연관 컨테이너와 순차 컨테이너가 공유하는 생성자

연관 컨테이너는 다음을 가장 많이 공유합니다. 순차적인 연관 컨테이너에는 세 가지 생성자를 사용할 수 있습니다. 🎜🎜#c라는 이름의 빈 컨테이너를 만듭니다. C는 벡터와 같은 컨테이너 유형 이름이고 T는 int 또는 string과 같은 요소 유형입니다. 모든 컨테이너에서 작동합니다.

C<T> c;
  • 1

컨테이너 c2의 복사본 c를 생성합니다. c와 c2는 동일한 컨테이너를 가져야 합니다. type , 동일한 유형의 요소를 저장합니다. 모든 컨테이너에서 작동합니다.

C<T> c(c2);
  • 1

요소가 반복자 b와 e로 표시된 범위의 요소인 c를 만듭니다. 사본. 모든 컨테이너에서 작동합니다.

    2. 연관 컨테이너와 순차 컨테이너가 공유하는 기타 기능
  • 연관 컨테이너는 컨테이너의 크기로 정의할 수 없습니다. 키에 해당하는 값이 무엇인지 알 수 없습니다.

연관 컨테이너는 순차 컨테이너의 일부 관계 연산자를 지원합니다.

  1. 연결된 컨테이너는 시작, 종료, rbegin 및 rend 작업을 지원합니다.

  2. 연관 컨테이너는 교체 및 할당 작업을 지원하지만 할당 기능을 제공하지 않습니다.

  3. Associated 컨테이너는 지우기 및 지우기 기능을 지원하지만 연관된 컨테이너의 지우기 작업은 void 유형을 반환합니다.

  4. Associated 컨테이너는 컨테이너 크기 작업으로 size(), max_size() 및empty() 함수를 지원하지만 resize() 함수는 지원하지 않습니다.

  5. 3. 쌍 쌍 유형으로 제공되는 작업

  6. 쌍 쌍에는 두 개의 데이터 값이 포함됩니다. 구체적인 사용법은 다음과 같습니다:
  7. C<T> c(b, e);

  8. 1

빈 쌍 객체를 생성합니다. 요소는 각각 T1 및 T2 유형이며 값으로 초기화됩니다.

pair<T1, T2> p1;
  • 1

두 요소가 각각 T1 및 T2 유형인 쌍 개체를 만듭니다. 여기서 첫 번째 멤버는 v1로 초기화되고 두 번째 멤버는 v2로 초기화됩니다.

pair<T1, T2> p1(v1, v2);
  • 1

v1 및 v2 값, 요소 유형을 사용하여 새 쌍 개체를 만듭니다. 이들은 각각 v1과 v2의 유형입니다.

make_pair(v1, v2);
  • 1

두 쌍 개체 간의 작음 연산은 사전식 순서를 따릅니다.

, true를 반환합니다.
    p1 < p2;
  • 1

p1.first36fb3c42f54c481af0f3117584bf5aa7 object Name;여러 개의 동일한 쌍 객체를 사용하는 경우 typedef를 사용하여 선언을 단순화할 수도 있습니다. <p><pre class="brush:css;toolbar:false;">p.first、p.second;</pre></p> <h2></h2>1# 🎜🎜## 🎜🎜#<p><br>2</p> <p></p> <ul class=" list-paddingleft-2">페어 클래스의 경우 해당 데이터 멤버에 직접 액세스할 수 있습니다. 점 연산자를 사용하여 액세스할 수 있는 첫 번째 멤버와 두 번째 멤버로 명명됩니다. <li><p>관련 기사: </p></li> <li>c++ STL 표준 컨테이너의 반복자 사용<p></p> </li> </ul>c++ 검토 요점 12개 요약 z——STL 문자열<p></p> <p>관련 동영상: </p> <p><a href="http://www.php.cn/course/84.html" target="_self">C# 튜토리얼</a></p>

위 내용은 C++_STL의 공통 컨테이너 요약: 연관 컨테이너와 순차 컨테이너 쌍의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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