> 백엔드 개발 > C++ > C++의 이중 순환 연결 리스트에서 요소 검색

C++의 이중 순환 연결 리스트에서 요소 검색

PHPz
풀어 주다: 2023-08-30 15:49:06
앞으로
1341명이 탐색했습니다.

C++의 이중 순환 연결 리스트에서 요소 검색

이중 원형 연결 목록과 키워드가 주어지면 연결 목록에서 키워드를 검색하고 발견되면 적절한 메시지를 제공해야 합니다. 특정 문자가 포함된 연결 목록이 있고 그 안의 요소를 검색해야 한다고 가정해 보겠습니다. 그럼 아래 링크 목록부터 시작해 보겠습니다 -

5 9 4 주어진 문제에 대한 해결책을 찾기 위해 4를 열쇠로 사용하겠습니다. 이중 연결 목록에는 고정된 헤드가 없으므로 모든 노드에서 시작하여 헤드를 다시 만날 때까지 해당 노드를 헤드로 표시합니다. 여기서 연결 목록에 대한 선형 검색을 수행하고 키워드를 검색합니다.

몇 가지 입력 및 출력 시나리오를 살펴보겠습니다. -

5개 노드 4 5 7을 포함하는 양방향 순환 연결 목록이 있다고 가정합니다. 발견된 것은 6이다.

으아아아

이중 순환 연결 리스트에서 검색할 요소가 없는 또 다른 경우를 고려해 보겠습니다.

으아아아

알고리즘

친해지기 위한 단계는 다음과 같습니다.

    연결된 목록을 구현하고 연결 목록의 각 노드에 전달 노드를 할당하여 값을 전달합니다.
  • 노드의 이전 부분을 마지막 노드의 다음 부분에 할당합니다.
  • 노드의 이전 부분을 노드의 다음 부분에 할당합니다.
  • 이중 순환 연결 목록에 존재하는지 확인하는 키 요소에 키 요소를 전달합니다.
  • 키가 이중 순환 연결 목록에 있으면 true를 반환합니다.
  • 그렇지 않으면 false를 반환합니다.
  • Example
의 중국어 번역은 다음과 같습니다:

Example

다음은 이중 연결 리스트에서 검색 작업을 수행하기 위한 C++ 구현 코드입니다.

으아아아

출력

으아아아

Explanation

의 중국어 번역은

Explanation

입니다.

키워드 4가 이중 연결 리스트에 존재합니다.

결론

이중 순환 연결 리스트에서는 고정된 머리와 꼬리가 없기 때문에 어떤 위치에서든 시작할 수 있습니다. 위의 방법에는 의사 헤드인 "헤드"가 있으며 여기서부터 검색을 시작합니다. 위 알고리즘의 시간 복잡도는 선형 탐색이므로 O(n)입니다.

위 내용은 C++의 이중 순환 연결 리스트에서 요소 검색의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:tutorialspoint.com
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿