1671. 산 배열을 만들기 위한 최소 제거 수
난이도:어려움
주제: 배열, 이진 검색, 동적 프로그래밍, Greedy
다음과 같은 경우에만 배열 arr이 산형 배열임을 기억하실 수 있습니다.
- arr.length >= 3
- 0 arr[0]
- arr[i] > arr[i 1] > ... > arr[arr.length - 1]
산 배열으로 만들기 위해 제거할 최소 요소 수를 반환합니다.
예 1:
- 입력:
- 숫자 = [1,3,1] 출력:
- 0 설명:
- 배열 자체가 산 배열이므로 어떤 요소도 제거할 필요가 없습니다.
- 입력:
- 숫자 = [2,1,1,5,6,2,3,1] 출력:
- 3 설명:
- 한 가지 해결책은 인덱스 0, 1, 5의 요소를 제거하여 배열 nums = [1,5,6,3,1]을 만드는 것입니다.
3
최대 산 하위 시퀀스를 제거하려면 최소 요소 대신 반대 방향을 생각하세요
- LIS를 생각하면 좀 가까운 것 같아요
제거할 요소를 직접 계산하는 대신
최대 산 부분 수열을 찾는 아이디어로 동적 프로그래밍 접근 방식을 사용할 수 있습니다. 이 접근 방식은 배열의 각 위치에 대해 두 개의 LIS(최장 증가 부분 시퀀스)를 찾는 것을 기반으로 합니다. 하나는 왼쪽에서 오른쪽으로 가고 다른 하나는 오른쪽에서 떠났다. 가능한 가장 긴 산 하위 시퀀스가 있으면 원래 배열 길이와 이 하위 시퀀스 길이의 차이로 제거할 최소 요소가 제공됩니다. 솔루션 개요
- 증가하는 하위 시퀀스 길이 식별
:
leftLIS 배열을 계산합니다. 여기서 leftLIS[i]는 i에서 끝나는(왼쪽에서 오른쪽으로) 가장 긴 증가 부분 수열의 길이를 나타냅니다. - 감소하는 하위 시퀀스 길이 식별
:
- rightLIS 배열을 계산합니다. 여기서 rightLIS[i]는 i에서 시작하여(오른쪽에서 왼쪽으로) 가장 긴 감소 부분 수열의 길이를 나타냅니다.
-
최대 산 길이 계산:
- 각 인덱스 i에 대해 0 1 및 rightLIS[i] > 1). i에서 산의 길이를 leftLIS[i] rightLIS[i] - 1로 계산합니다.
-
최소한의 제거를 받으세요:
- 제거할 최소 요소는 원래 배열 길이에서 발견된 가장 긴 산 길이를 뺀 값입니다.
PHP에서 이 솔루션을 구현해 보겠습니다: 1671. 산 배열을 만들기 위한 최소 제거 수
<?php /** * @param Integer[] $nums * @return Integer */ function minimumMountainRemovals($nums) { ... ... ... /** * go to ./solution.php */ } // Example usage $nums1 = [1, 3, 1]; echo minimumMountainRemovals($nums1); // Output: 0 $nums2 = [2, 1, 1, 5, 6, 2, 3, 1]; echo minimumMountainRemovals($nums2); // Output: 3 ?>
설명:
-
왼쪽 LIS 계산:
- leftLIS[i]는 i에서 끝나는 증가하는 부분 수열의 최대 길이를 저장합니다. 각 i를 반복하고, 각 i에 대해 0부터 i-1까지 반복하여 i에서 끝나는 가장 긴 하위 시퀀스를 찾습니다.
-
올바른 LIS 계산:
- rightLIS[i]는 i에서 시작하여 감소하는 부분 수열의 최대 길이를 저장합니다. n-2에서 0까지 역방향으로 반복하고, 각 i에 대해 n-1에서 i 1까지 반복하여 i에서 시작하는 가장 긴 부분 수열을 찾습니다.
-
산 계산:
- 인덱스 i의 유효한 피크는 왼쪽LIS[i] > 1이고 오른쪽LIS[i] > 1. i에 봉우리가 있는 산의 길이는 왼쪽LIS[i] 오른쪽LIS[i] - 1.
-
최종 계산:
- 필요한 최소 제거량은 원래 배열 길이와 발견된 최대 산 길이의 차이입니다.
복잡성 분석
- 시간 복잡도: O(n2), LIS 계산의 이중 루프로 인해 발생합니다.
- 공간 복잡성: O(n), leftLIS 및 rightLIS 배열 저장용.
이 솔루션을 사용하면 최대 산 하위 순서를 찾고 산 배열을 달성하는 데 필요한 최소 제거량을 계산할 수 있습니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 마운틴 배열을 만들기 위한 최소 제거 수의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

종종 키워드와 추적 매개 변수로 혼란스러워하는 긴 URL은 방문자를 방해 할 수 있습니다. URL 단축 스크립트는 솔루션을 제공하여 소셜 미디어 및 기타 플랫폼에 이상적인 간결한 링크를 만듭니다. 이 스크립트는 개별 웹 사이트 a에 유용합니다

Instagram은 2012 년 Facebook에서 유명한 인수에 이어 타사 사용을 위해 두 개의 API 세트를 채택했습니다. Instagram Graph API 및 Instagram Basic Display API입니다. 개발자는

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

이것은 Laravel 백엔드가있는 React Application을 구축하는 데있어 시리즈의 두 번째이자 마지막 부분입니다. 이 시리즈의 첫 번째 부분에서는 기본 제품 목록 응용 프로그램을 위해 Laravel을 사용하여 편안한 API를 만들었습니다. 이 튜토리얼에서는 Dev가 될 것입니다

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

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

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

2025 PHP Landscape Survey는 현재 PHP 개발 동향을 조사합니다. 개발자와 비즈니스에 대한 통찰력을 제공하는 프레임 워크 사용, 배포 방법 및 과제를 탐색합니다. 이 조사는 현대 PHP Versio의 성장을 예상합니다


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

Dreamweaver Mac版
시각적 웹 개발 도구

PhpStorm 맥 버전
최신(2018.2.1) 전문 PHP 통합 개발 도구

SecList
SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.
