찾다
백엔드 개발PHP 튜토리얼모든 요소를 ​​표시한 후 배열의 점수 찾기

Find Score of an Array After Marking All Elements

2593. 모든 요소를 ​​표시한 후 배열의 점수 찾기

난이도:

주제: 힙(우선순위 큐), 정렬, 배열, 시뮬레이션, 해시 테이블, Ordered Set, Ordered Map, Greedy, Monotonic Stack, 슬라이딩 윈도우, 두 포인터, 스택, 큐, 비트 조작, 분할 정복, 동적 프로그래밍, 이중 연결 목록, 데이터 스트림, 기수 정렬, 역추적, 비트마스크, 트리, 디자인, 해시 함수, 문자열, 반복자, 계산 정렬, 연결 목록

양의 정수로 구성된 배열 num이 제공됩니다.

점수 = 0부터 시작하여 다음 알고리즘을 적용합니다.

  • 표시되지 않은 배열 중 가장 작은 정수를 선택하세요. 동점인 경우 지수가 가장 작은 것을 선택하세요.
  • 선택한 정수 값을 점수에 추가하세요.
  • 선택한 요소와 인접한 두 요소(존재하는 경우)를 표시합니다.
  • 모든 배열 요소가 표시될 때까지 반복합니다.

위 알고리즘을 적용하여 얻은 점수를 반환합니다.

예 1:

  • 입력: 숫자 = [2,1,3,4,5,2]
  • 출력: 7
  • 설명: 요소를 다음과 같이 표시합니다.
    • 1은 표시되지 않은 가장 작은 요소이므로 이 요소와 인접한 두 요소인 [2,1,3,4,5,2]로 표시합니다.
    • 2는 표시되지 않은 가장 작은 요소이므로 이 요소와 왼쪽 인접 요소인 [2,1,3,4,5,2]로 표시합니다.
    • 4는 표시되지 않은 유일한 요소이므로 [2,1,3,4,5,2]로 표시합니다.
    • 저희 점수는 1 2 4 = 7입니다.

예 2:

  • 입력: 숫자 = [2,3,5,1,3,2]
  • 출력: 5
  • 설명: 요소를 다음과 같이 표시합니다.
    • 1은 표시되지 않은 가장 작은 요소이므로 이 요소와 인접한 두 요소인 [2,3,5,1,3,2]로 표시합니다.
    • 2는 표시되지 않은 가장 작은 요소입니다. 두 개가 있으므로 가장 왼쪽에 있는 것을 선택하여 인덱스 0에 있는 것을 표시하고 오른쪽에 인접한 요소인 [2,3,5,1,3, 2].
    • 2는 표시되지 않은 유일한 요소이므로 [2,3,5,1,3,2]로 표시합니다.
    • 저희 점수는 1 2 2 = 5입니다.

제약조건:

  • 1 5
  • 1 6

힌트:

  1. 요소와 인접 요소를 표시하는 과정을 시뮬레이션해 보세요.
  2. 이미 표시된 요소가 있으면 건너뛰세요.

해결책:

정렬된 배열이나 우선순위 큐를 사용하여 표시되지 않은 가장 작은 요소를 추적함으로써 표시 프로세스를 효율적으로 시뮬레이션할 수 있습니다. 따라서 다음 접근 방식을 사용할 수 있습니다.

계획:

  1. 입력 구문 분석: 배열 번호를 읽고 점수 및 채점 상태에 대한 변수를 초기화합니다.
  2. 힙(우선순위 대기열):
    • 최소 힙을 사용하여 각 단계에서 표시되지 않은 가장 작은 요소를 효율적으로 추출합니다.
    • 각 요소를 인덱스(값, 인덱스)와 함께 힙에 삽입하여 가장 작은 인덱스를 기준으로 연결을 관리합니다.
  3. 마킹 요소:
    • 표시된 배열을 유지하여 요소와 인접한 요소가 표시되었는지 추적합니다.
    • 힙의 요소를 처리할 때 이미 표시된 요소는 건너뜁니다.
    • 현재 요소와 두 개의 인접 요소(존재하는 경우)를 표시합니다.
    • 현재 요소의 값을 점수에 추가합니다.
  4. 반복: 모든 요소가 표시될 때까지 계속합니다.
  5. 출력: 누적 점수를 반환합니다.

PHP에서 이 솔루션을 구현해 보겠습니다: 2593. 모든 요소를 ​​표시한 후 배열의 점수 찾기

<?php /**
 * @param Integer[] $nums
 * @return Integer
 */
function findScore($nums) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example usage:
$nums1 = [2, 1, 3, 4, 5, 2];
$nums2 = [2, 3, 5, 1, 3, 2];

echo findScore($nums1) . "\n"; // Output: 7
echo findScore($nums2) . "\n"; // Output: 5
?>

설명:

  1. 힙 구성:

    • usort 함수는 값을 기준으로 배열을 정렬하고 값이 묶인 경우 인덱스를 기준으로 정렬합니다.
    • 이렇게 하면 항상 가장 작은 인덱스로 표시되지 않은 가장 작은 요소를 처리할 수 있습니다.
  2. 마킹 로직:

    • 표시되지 않은 각 요소에 대해 표시된 배열을 사용하여 해당 요소와 인접 요소를 표시합니다.
    • 이렇게 하면 이전에 표시된 요소를 효율적으로 건너뛸 수 있습니다.
  3. 시간 복잡성:

    • 힙 정렬: O(n log n)
    • 힙 처리: O(n)
    • 전체: O(n log n), 이는 주어진 제약 조건에 효율적입니다.
  4. 공간 복잡성:

    • 표시된 배열: O(n)
    • 힙: O(n)
    • 합계: O(n)

이 솔루션은 제약 조건을 충족하며 대규모 입력에 효율적으로 작동합니다.

연락처 링크

이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!

이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.

  • 링크드인
  • 깃허브

위 내용은 모든 요소를 ​​표시한 후 배열의 점수 찾기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

Laravel은 직관적 인 플래시 방법을 사용하여 임시 세션 데이터 처리를 단순화합니다. 응용 프로그램에 간단한 메시지, 경고 또는 알림을 표시하는 데 적합합니다. 데이터는 기본적으로 후속 요청에만 지속됩니다. $ 요청-

PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법PHP의 컬 : REST API에서 PHP Curl Extension 사용 방법Mar 14, 2025 am 11:42 AM

PHP 클라이언트 URL (CURL) 확장자는 개발자를위한 강력한 도구이며 원격 서버 및 REST API와의 원활한 상호 작용을 가능하게합니다. PHP CURL은 존경받는 다중 프로모토콜 파일 전송 라이브러리 인 Libcurl을 활용하여 효율적인 execu를 용이하게합니다.

Laravel 테스트에서 단순화 된 HTTP 응답 조롱Laravel 테스트에서 단순화 된 HTTP 응답 조롱Mar 12, 2025 pm 05:09 PM

Laravel은 간결한 HTTP 응답 시뮬레이션 구문을 제공하여 HTTP 상호 작용 테스트를 단순화합니다. 이 접근법은 테스트 시뮬레이션을보다 직관적으로 만들면서 코드 중복성을 크게 줄입니다. 기본 구현은 다양한 응답 유형 단축키를 제공합니다. Illuminate \ support \ Facades \ http를 사용하십시오. http :: 가짜 ([ 'google.com'=> ​​'Hello World', 'github.com'=> ​​[ 'foo'=> 'bar'], 'forge.laravel.com'=>

Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Codecanyon에서 12 개의 최고의 PHP 채팅 스크립트Mar 13, 2025 pm 12:08 PM

고객의 가장 긴급한 문제에 실시간 인스턴트 솔루션을 제공하고 싶습니까? 라이브 채팅을 통해 고객과 실시간 대화를 나누고 문제를 즉시 해결할 수 있습니다. 그것은 당신이 당신의 관습에 더 빠른 서비스를 제공 할 수 있도록합니다.

PHP 로깅 : PHP 로그 분석을위한 모범 사례PHP 로깅 : PHP 로그 분석을위한 모범 사례Mar 10, 2025 pm 02:32 PM

PHP 로깅은 웹 애플리케이션을 모니터링하고 디버깅하고 중요한 이벤트, 오류 및 런타임 동작을 캡처하는 데 필수적입니다. 시스템 성능에 대한 귀중한 통찰력을 제공하고 문제를 식별하며 더 빠른 문제 해결을 지원합니다.

PHP에서 늦은 정적 결합의 개념을 설명하십시오.PHP에서 늦은 정적 결합의 개념을 설명하십시오.Mar 21, 2025 pm 01:33 PM

기사는 PHP 5.3에 도입 된 PHP의 LSB (Late STATIC BING)에 대해 논의하여 정적 방법의 런타임 해상도가보다 유연한 상속을 요구할 수있게한다. LSB의 실제 응용 프로그램 및 잠재적 성능

프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법.프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법.Mar 28, 2025 pm 05:12 PM

이 기사에서는 프레임 워크에 사용자 정의 기능 추가, 아키텍처 이해, 확장 지점 식별 및 통합 및 디버깅을위한 모범 사례에 중점을 둡니다.

프레임 워크 보안 기능 : 취약점 보호.프레임 워크 보안 기능 : 취약점 보호.Mar 28, 2025 pm 05:11 PM

기사는 입력 유효성 검사, 인증 및 정기 업데이트를 포함한 취약점을 방지하기 위해 프레임 워크의 필수 보안 기능을 논의합니다.

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 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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

DVWA

DVWA

DVWA(Damn Vulnerable Web App)는 매우 취약한 PHP/MySQL 웹 애플리케이션입니다. 주요 목표는 보안 전문가가 법적 환경에서 자신의 기술과 도구를 테스트하고, 웹 개발자가 웹 응용 프로그램 보안 프로세스를 더 잘 이해할 수 있도록 돕고, 교사/학생이 교실 환경 웹 응용 프로그램에서 가르치고 배울 수 있도록 돕는 것입니다. 보안. DVWA의 목표는 다양한 난이도의 간단하고 간단한 인터페이스를 통해 가장 일반적인 웹 취약점 중 일부를 연습하는 것입니다. 이 소프트웨어는

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.