찾다
백엔드 개발PHP 튜토리얼작업 후 문자열의 최소 길이

Minimum Length of String After Operations

3223. 연산 후 문자열의 최소 길이

난이도:

주제: 해시 테이블, 문자열, 계산

문자열 s가 주어졌습니다.

다음 프로세스는 무엇이든 횟수에 관계없이 수행할 수 있습니다.

  • 인덱스 i 왼쪽에 s[i]와 동일한 문자가 최소 한 문자 있고 최소 한 문자가 있도록 문자열에서 인덱스 i를 선택합니다. 오른쪽에는 s[i]와도 같습니다.
  • s[i]와 동일한 인덱스 i의 왼쪽에 있는 가장 가까운 문자를 삭제합니다.
  • s[i]와 동일한 인덱스 i의 오른쪽에 있는 가장 가까운 문자를 삭제합니다.

달성할 수 있는 최종 문자열 s의 최소 길이반환합니다

.

예 1:

  • 입력:
  • s = "abaacbcbb"
  • 출력:
  • 5
  • 설명:
      우리는 다음 작업을 수행합니다.
    • 인덱스 2를 선택한 다음 인덱스 0과 3의 문자를 제거합니다. 결과 문자열은 s = "bacbcbb"입니다.
    • 인덱스 3을 선택한 다음 인덱스 0과 5의 문자를 제거합니다. 결과 문자열은 s = "acbcb"입니다.

예 2:

  • 입력:
  • s = "aa"
  • 출력:
  • 2
  • 설명:
  • 어떠한 연산도 수행할 수 없으므로 원래 문자열의 길이를 반환합니다.

제약조건:

  • 1 5
  • s는 영문 소문자로만 구성됩니다.

힌트:

  1. 최종 답을 찾는 데에는 각 문자의 빈도만이 중요합니다.
  2. 캐릭터가 3회 미만 등장할 경우 해당 캐릭터에 대한 처리가 불가능합니다.
  3. 문자열에 3번 이상 나타나는 문자가 있다고 가정하면 해당 문자가 최대 2번 남을 때까지 이 문자 중 2개를 반복적으로 삭제할 수 있습니다.

해결책:

문자열에서 각 문자의 빈도에 초점을 맞춰야 합니다. 이를 해결하는 방법은 다음과 같습니다.

접근하다:
  1. 문자 빈도 계산

    :
    • 빈도표를 사용하여 문자열에 각 문자가 나타나는 횟수를 계산합니다.
  2. 빈도 >= 3으로 문자 줄이기

    :
    • 한 문자가 3번 이상 나타나면 2번만 남을 때까지 두 번 반복해서 삭제할 수 있습니다.
  3. 최소 길이 계산

    :
    • 빈도를 줄인 후 모든 캐릭터의 남은 수를 합산해 보세요.

이 솔루션을 PHP로 구현해 보겠습니다: 3223. 연산 후 문자열의 최소 길이

<?php /**
 * @param String $s
 * @return Integer
 */
function minimumLength($s) {
    ...
    ...
    ...
    /**
     * go to ./solution.php
     */
}

// Example 1
$s1 = "abaacbcbb";
echo "Input: $s1\n";
echo "Output: " . minimumLength($s1) . "\n";

// Example 2
$s2 = "aa";
echo "Input: $s2\n";
echo "Output: " . minimumLength($s2) . "\n";
?>

설명:

  1. 빈도수:

    • 문자열을 반복하고 각 문자에 대해 $주파수 배열의 개수를 늘립니다.
  2. 문자수 감소:

    • $주파수 배열의 각 문자에 대해 개수가 3 이상인지 확인하세요. 그렇다면 최대 2개로 줄이세요.
  3. 결과 계산:

    • $주파수 배열의 값을 합하여 가능한 최소 문자열 길이를 구합니다.

예제 연습:

예시 1:

  • 입력: s = "abaacbcbb"
  • 빈도: ['a' => 3, 'b' => 4, 'c' => 2]
  • 감소 후:
    • 'a' => 2(3에서 감소),
    • 'b' => 2(4에서 감소),
    • 'ㄷ' => 2(감소 필요 없음).
  • 최소 길이: 2 2 2 = 6.

예 2:

  • 입력: s = "aa"
  • 빈도: ['a' => 2]
  • 3개 이상의 빈도를 갖는 캐릭터가 없으므로 감소가 필요하지 않습니다.
  • 최소 길이: 2.

복잡성:

  1. 시간 복잡성:

    • 빈도 계산: O(n), 여기서 n은 문자열의 길이입니다.
    • 축소: O(1) (소문자는 26개뿐이므로 상수 시간).
    • 합산 주파수: O(1).
    • 전체: O(n).
  2. 공간 복잡성:

    • O(1), 주파수 배열에 최대 26개의 항목이 있기 때문입니다.

이 솔루션은 효율적이며 문제의 제약 내에서 잘 작동합니다.

연락처 링크

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

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

  • 링크드인
  • 깃허브

위 내용은 작업 후 문자열의 최소 길이의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
PHP 로깅 : PHP 로그 분석을위한 모범 사례PHP 로깅 : PHP 로그 분석을위한 모범 사례Mar 10, 2025 pm 02:32 PM

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

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에서 늦은 정적 결합의 개념을 설명하십시오.Mar 21, 2025 pm 01:33 PM

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

프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법.프레임 워크 사용자 정의/확장 : 사용자 정의 기능을 추가하는 방법.Mar 28, 2025 pm 05:12 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를 무료로 생성하십시오.

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

안전한 시험 브라우저는 온라인 시험을 안전하게 치르기 위한 보안 브라우저 환경입니다. 이 소프트웨어는 모든 컴퓨터를 안전한 워크스테이션으로 바꿔줍니다. 이는 모든 유틸리티에 대한 액세스를 제어하고 학생들이 승인되지 않은 리소스를 사용하는 것을 방지합니다.

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음