찾다
백엔드 개발C++이진 트리의 이등변삼각형 수

이진 트리의 이등변삼각형 수

Sep 05, 2023 am 09:41 AM
수량이진 트리이등변삼각형

이진 트리는 각 노드가 최대 2개의 하위 노드를 가질 수 있는 데이터 구조입니다. 이 아이들을 각각 왼쪽 아이들, 오른쪽 아이들이라고 부릅니다. 부모 배열 표현이 주어졌다고 가정하면 이를 사용하여 이진 트리를 만들어야 합니다. 이진 트리에는 여러 개의 이등변삼각형이 있을 수 있습니다. 우리는 이 이진 트리에서 가능한 이등변삼각형의 총 개수를 찾아야 합니다.

이 기사에서는 C++에서 이 문제를 해결하기 위한 몇 가지 기술을 살펴보겠습니다.

문제 이해하기

상위 배열을 제공합니다. 배열 인덱스가 트리 노드의 값을 형성하고 배열의 값이 해당 특정 인덱스의 상위 노드를 제공하도록 이진 트리 형식으로 표현해야 합니다.

-1은 항상 루트 상위 노드라는 점에 유의하세요. 아래에는 배열과 이진 트리 표현이 나와 있습니다.

으아아아

이진 트리 -

이진 트리의 이등변삼각형 수

모든 이진 트리에는 세 가지 유형의 이등변삼각형이 있을 수 있습니다. -

  • 왼쪽 이등변 삼각형 이 삼각형에서 꼭지점은 왼쪽 부모 노드의 자식 노드이고 밑변(이등변삼각형의 양쪽)을 이루는 꼭지점은 왼쪽입니다. 자식 노드. 하위 노드는 직접적이거나 간접적일 수 있습니다. 위 트리에는 (2, 6, 3), (3, 7, 1)이라는 두 개의 이등변삼각형이 있습니다.

  • 오른쪽 이등변삼각형 이 삼각형에서 꼭짓점은 부모의 오른쪽 자식이고, 밑면을 구성하는 꼭짓점은 꼭짓점의 오른쪽 자식입니다. 어린이는 직접적일 수도 있고 간접적일 수도 있습니다. 위의 트리에는 이등변삼각형(4, 1, 8)이 하나만 있습니다.

  • Balanced Isosceles Triangle 이 삼각형에서 밑면을 이루는 꼭짓점은 꼭짓점 노드의 왼쪽 및 오른쪽 자식 노드입니다. 위 트리에는 (1, 3, 4), (3, 2, 7), (4, 8, 9), (2, 5, 6), (1, 2, 9)와 같은 이등변삼각형 5개가 있습니다.

위의 이진 트리에는 총 8개의 이등변삼각형이 있습니다.

깊이 우선 탐색을 사용한 순회

깊이 우선 탐색(DFS)은 트리의 모든 노드를 깊이 있게 탐색하는 방법입니다. 루트 노드에서 시작하여 각 분기로 이동한 다음 역추적합니다.

  • 먼저 DFS를 사용하여 이진 트리의 각 노드를 순회하고 각 노드가 서로 인접한 것으로 표시되도록 그래프로 변환합니다. 이렇게 하면 탐색이 더 쉬워집니다.

  • 각 노드에 대해 하위 노드가 있는지 확인합니다. 확인한 후 sort(node[x].begin(), node[x].end()) 함수를 사용하여 정렬합니다.

  • 다음으로 현재 노드가 해당 상위 노드의 왼쪽 또는 오른쪽 후속 노드인지 확인합니다. 우리는 이진 트리의 모든 노드에서 DFS 함수를 재귀적으로 사용합니다.

  • 현재 노드에 두 개의 자식(직접 또는 간접)이 있는 경우 두 자식 사이의 모서리를 계산하여 이등변삼각형이 존재할 가능성을 확인합니다. 아래 코드에 제공된 graph 함수를 통해 그들 사이의 가장자리를 찾을 것입니다.

  • 마지막으로 서로 다른 위치에 있는 가능한 모든 삼각형을 더하여 이등변삼각형의 총 개수를 계산합니다.

으아아아

출력

으아아아

결론

부모 배열이 주어졌을 때 이진 트리에서 정삼각형의 총 개수를 찾는 방법을 논의했습니다. 우리는 이진 트리를 탐색할 수 있는 깊이 우선 탐색을 사용하여 이를 달성할 수 있습니다.

위 내용은 이진 트리의 이등변삼각형 수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 tutorialspoint에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
C의 XML : 복잡한 데이터 구조 처리C의 XML : 복잡한 데이터 구조 처리May 02, 2025 am 12:04 AM

C에서 XML 데이터 구조로 작업하면 tinyxml 또는 pugixml 라이브러리를 사용할 수 있습니다. 1) pugixml 라이브러리를 사용하여 XML 파일을 구문 분석하고 생성하십시오. 2) 책 정보와 같은 복잡한 중첩 XML 요소를 처리합니다. 3) XML 처리 코드를 최적화하면 효율적인 라이브러리 및 스트리밍 구문 분석을 사용하는 것이 좋습니다. 이러한 단계를 통해 XML 데이터를 효율적으로 처리 할 수 ​​있습니다.

C 및 성능 : 여전히 지배적 인 곳C 및 성능 : 여전히 지배적 인 곳May 01, 2025 am 12:14 AM

C는 낮은 수준의 메모리 관리 및 효율적인 실행 기능으로 인해 게임 개발, 금융 거래 시스템 및 임베디드 시스템에 없어서는 안될 것이기 때문에 여전히 성능 최적화를 지배합니다. 구체적으로, 그것은 다음과 같이 나타납니다. 1) 게임 개발에서 C의 저수준 메모리 관리 및 효율적인 실행 기능은 게임 엔진 개발에 선호되는 언어가됩니다. 2) 금융 거래 시스템에서 C의 성능 장점은 대기 시간이 매우 낮고 처리량이 높음을 보장합니다. 3) 임베디드 시스템에서 C의 저수준 메모리 관리 및 효율적인 실행 기능은 자원 제약 환경에서 매우 인기가 있습니다.

C XML 프레임 워크 : 올바른 프레임 워크 선택C XML 프레임 워크 : 올바른 프레임 워크 선택Apr 30, 2025 am 12:01 AM

C XML 프레임 워크의 선택은 프로젝트 요구 사항을 기반으로해야합니다. 1) TinyXML은 자원으로 제한된 환경에 적합합니다. 2) PugixML은 고성능 요구 사항에 적합합니다. 3) XERCES-C는 복잡한 XMLSCHEMA 검증 및 성능, 사용 편의성 및 라이센스를 고려해야합니다.

C# vs. C : 프로젝트에 적합한 언어 선택C# vs. C : 프로젝트에 적합한 언어 선택Apr 29, 2025 am 12:51 AM

C#은 개발 효율성과 유형 안전이 필요한 프로젝트에 적합한 반면 C#은 고성능 및 하드웨어 제어가 필요한 프로젝트에 적합합니다. 1) C#은 기업 애플리케이션 및 Windows 개발에 적합한 가비지 컬렉션 및 LINQ를 제공합니다. 2) C는 고성능 및 기본 제어로 유명하며 게임 및 시스템 프로그래밍에 널리 사용됩니다.

코드를 최적화하는 방법코드를 최적화하는 방법Apr 28, 2025 pm 10:27 PM

C 코드 최적화는 다음 전략을 통해 달성 할 수 있습니다. 1. 최적화 사용을 위해 메모리를 수동으로 관리합니다. 2. 컴파일러 최적화 규칙을 준수하는 코드를 쓰십시오. 3. 적절한 알고리즘 및 데이터 구조를 선택하십시오. 4. 인라인 함수를 사용하여 통화 오버 헤드를 줄입니다. 5. 템플릿 메타 프로 그램을 적용하여 컴파일 시간에 최적화하십시오. 6. 불필요한 복사를 피하고 움직이는 의미와 참조 ​​매개 변수를 사용하십시오. 7. Const를 올바르게 사용하여 컴파일러 최적화를 돕습니다. 8. std :: 벡터와 같은 적절한 데이터 구조를 선택하십시오.

C의 휘발성 키워드를 이해하는 방법은 무엇입니까?C의 휘발성 키워드를 이해하는 방법은 무엇입니까?Apr 28, 2025 pm 10:24 PM

C의 휘발성 키워드는 변수 값이 코드 제어 외부에서 변경 될 수 있으므로 최적화 할 수 없음을 컴파일러에게 알리는 데 사용됩니다. 1) 종종 센서 상태와 같은 하드웨어 또는 인터럽트 서비스 프로그램에 의해 수정 될 수있는 변수를 읽는 데 사용됩니다. 2) 휘발성은 멀티 스레드 안전을 보장 할 수 없으며 뮤텍스 잠금 장치 또는 원자 작업을 사용해야합니다. 3) 휘발성을 사용하면 성능이 약간 줄어들 수 있지만 프로그램 정확성을 보장 할 수 있습니다.

C에서 스레드 성능을 측정하는 방법?C에서 스레드 성능을 측정하는 방법?Apr 28, 2025 pm 10:21 PM

C에서 스레드 성능을 측정하면 표준 라이브러리에서 타이밍 도구, 성능 분석 도구 및 사용자 정의 타이머를 사용할 수 있습니다. 1. 라이브러리를 사용하여 실행 시간을 측정하십시오. 2. 성능 분석을 위해 GPROF를 사용하십시오. 단계에는 컴파일 중에 -pg 옵션 추가, GMON.out 파일을 생성하기 위해 프로그램을 실행하며 성능 보고서를 생성하는 것이 포함됩니다. 3. Valgrind의 Callgrind 모듈을 사용하여보다 자세한 분석을 수행하십시오. 단계에는 Callgrind.out 파일을 생성하고 Kcachegrind를 사용하여 결과를보기위한 프로그램 실행이 포함됩니다. 4. 사용자 정의 타이머는 특정 코드 세그먼트의 실행 시간을 유연하게 측정 할 수 있습니다. 이 방법은 스레드 성능을 완전히 이해하고 코드를 최적화하는 데 도움이됩니다.

C에서 Chrono 라이브러리를 사용하는 방법?C에서 Chrono 라이브러리를 사용하는 방법?Apr 28, 2025 pm 10:18 PM

C에서 Chrono 라이브러리를 사용하면 시간과 시간 간격을보다 정확하게 제어 할 수 있습니다. 이 도서관의 매력을 탐구합시다. C의 크로노 라이브러리는 표준 라이브러리의 일부로 시간과 시간 간격을 다루는 현대적인 방법을 제공합니다. 시간과 C 시간으로 고통받는 프로그래머에게는 Chrono가 의심 할 여지없이 혜택입니다. 코드의 가독성과 유지 가능성을 향상시킬뿐만 아니라 더 높은 정확도와 유연성을 제공합니다. 기본부터 시작합시다. Chrono 라이브러리에는 주로 다음 주요 구성 요소가 포함됩니다. std :: Chrono :: System_Clock : 현재 시간을 얻는 데 사용되는 시스템 클럭을 나타냅니다. STD :: 크론

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

Video Face Swap

Video Face Swap

완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

뜨거운 도구

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

Microsoft에서 출시한 강력한 무료 IDE 편집기

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

SublimeText3 Linux 새 버전

SublimeText3 Linux 새 버전

SublimeText3 Linux 최신 버전