2593. 모든 요소를 표시한 후 배열의 점수 찾기
난이도:중
주제: 힙(우선순위 큐), 정렬, 배열, 시뮬레이션, 해시 테이블, Ordered Set, Ordered Map, Greedy, Monotonic Stack, 슬라이딩 윈도우, 두 포인터, 스택, 큐, 비트 조작, 분할 정복, 동적 프로그래밍, 이중 연결 목록, 데이터 스트림, 기수 정렬, 역추적, 비트마스크, 트리, 디자인, 해시 함수, 문자열, 반복자, 계산 정렬, 연결 목록
양의 정수로 구성된 배열 num이 제공됩니다.
점수 = 0부터 시작하여 다음 알고리즘을 적용합니다.
위 알고리즘을 적용하여 얻은 점수를 반환합니다.
예 1:
예 2:
제약조건:
힌트:
해결책:
정렬된 배열이나 우선순위 큐를 사용하여 표시되지 않은 가장 작은 요소를 추적함으로써 표시 프로세스를 효율적으로 시뮬레이션할 수 있습니다. 따라서 다음 접근 방식을 사용할 수 있습니다.
PHP에서 이 솔루션을 구현해 보겠습니다: 2593. 모든 요소를 표시한 후 배열의 점수 찾기
설명:
힙 구성:
- usort 함수는 값을 기준으로 배열을 정렬하고 값이 묶인 경우 인덱스를 기준으로 정렬합니다.
- 이렇게 하면 항상 가장 작은 인덱스로 표시되지 않은 가장 작은 요소를 처리할 수 있습니다.
마킹 로직:
- 표시되지 않은 각 요소에 대해 표시된 배열을 사용하여 해당 요소와 인접 요소를 표시합니다.
- 이렇게 하면 이전에 표시된 요소를 효율적으로 건너뛸 수 있습니다.
시간 복잡성:
- 힙 정렬: O(n log n)
- 힙 처리: O(n)
- 전체: O(n log n), 이는 주어진 제약 조건에 효율적입니다.
공간 복잡성:
- 표시된 배열: O(n)
- 힙: O(n)
- 합계: O(n)
이 솔루션은 제약 조건을 충족하며 대규모 입력에 효율적으로 작동합니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
위 내용은 모든 요소를 표시한 후 배열의 점수 찾기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!