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는 영문 소문자로만 구성됩니다.
힌트:
- 최종 답을 찾는 데에는 각 문자의 빈도만이 중요합니다.
- 캐릭터가 3회 미만 등장할 경우 해당 캐릭터에 대한 처리가 불가능합니다.
- 문자열에 3번 이상 나타나는 문자가 있다고 가정하면 해당 문자가 최대 2번 남을 때까지 이 문자 중 2개를 반복적으로 삭제할 수 있습니다.
해결책:
문자열에서 각 문자의 빈도에 초점을 맞춰야 합니다. 이를 해결하는 방법은 다음과 같습니다.
접근하다:
-
문자 빈도 계산
:- 빈도표를 사용하여 문자열에 각 문자가 나타나는 횟수를 계산합니다.
-
빈도 >= 3으로 문자 줄이기
:- 한 문자가 3번 이상 나타나면 2번만 남을 때까지 두 번 반복해서 삭제할 수 있습니다.
-
최소 길이 계산
:- 빈도를 줄인 후 모든 캐릭터의 남은 수를 합산해 보세요.
이 솔루션을 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"; ?>
설명:
-
빈도수:
- 문자열을 반복하고 각 문자에 대해 $주파수 배열의 개수를 늘립니다.
-
문자수 감소:
- $주파수 배열의 각 문자에 대해 개수가 3 이상인지 확인하세요. 그렇다면 최대 2개로 줄이세요.
-
결과 계산:
- $주파수 배열의 값을 합하여 가능한 최소 문자열 길이를 구합니다.
예제 연습:
예시 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.
복잡성:
-
시간 복잡성:
- 빈도 계산: O(n), 여기서 n은 문자열의 길이입니다.
- 축소: O(1) (소문자는 26개뿐이므로 상수 시간).
- 합산 주파수: O(1).
- 전체: O(n).
-
공간 복잡성:
- O(1), 주파수 배열에 최대 26개의 항목이 있기 때문입니다.
이 솔루션은 효율적이며 문제의 제약 내에서 잘 작동합니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
위 내용은 작업 후 문자열의 최소 길이의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

의존성 (di) inphpenhancescodeflexibility 및 testability는 decouplingdependencycreation fromusage.toimplementDieffectically : 1) addicontainersjudicuelyToavoidover-Engineering.2) indhe. 3) adhe

toimproveyourphpwebsite의 성능, UsetheseStrospations : 1) ubstractOpCodeCachingWithOpCaceToSpeedUpscriptScriptIngretation.2) 최적화 된 AabaseQueriesBysElectingOnlynecessaryFields.3) UsecachingsystemsLikeredSormcedUcedUcedUcedALOW

예, itispossibletosendmassemailswithphp.1) uselibraries -lifephpmailerorswiftmailerforfficialemailsending.2) emubledelaysbetemailstoavoidspamflags.3) personalizeemailsingdynamiccontenttoimproveengement.4) usequeuesystemslikerbitmbitmquredisb

의존성 (di) inphpisadesignpatternthatachievesinversionofcontrol (ioc) by ancelociestobeinjectedintoclasses, 향상 모듈 성, 테스트 가능성 및 flexibility.didecouplesssclassessfromspecificimplementations, codemoremanageableandadapt

PHP를 사용하여 이메일을 보내는 가장 좋은 방법은 다음과 같습니다. 1. 기본 전송에 Php 's Mail () 함수를 사용합니다. 2. phpmailer 라이브러리를 사용하여 더 복잡한 HTML 메일을 보내십시오. 3. Sendgrid와 같은 트랜잭션 메일 서비스를 사용하여 신뢰성 및 분석 기능을 향상시킵니다. 이러한 방법을 사용하면 이메일이받은 편지함에 도달 할뿐만 아니라 수신자를 유치 할 수 있습니다.

PHP 다차원 어레이에서 총 요소 수를 계산하는 것은 재귀 적 또는 반복적 인 방법을 사용하여 수행 할 수 있습니다. 1. 재귀 방법은 배열을 가로 지르고 중첩 배열을 재귀 적으로 처리함으로써 계산됩니다. 2. 반복 방법은 스택을 사용하여 깊이 문제를 피하기 위해 재귀를 시뮬레이션합니다. 3. Array_Walk_Recursive 함수도 구현할 수 있지만 수동 계산이 필요합니다.

PHP에서, do-while 루프의 특성은 루프 본체가 적어도 한 번 실행되도록하고 조건에 따라 루프를 계속할지 여부를 결정하는 것입니다. 1) 조건부 점검 전에 루프 본체를 실행하며, 사용자 입력 확인 및 메뉴 시스템과 같이 작업을 적어도 한 번 수행 해야하는 시나리오에 적합합니다. 2) 그러나, do-while 루프의 구문은 초보자들 사이에서 혼란을 야기 할 수 있으며 불필요한 성능 오버 헤드를 추가 할 수 있습니다.

PHP의 효율적인 해싱 스트링은 다음 방법을 사용할 수 있습니다. 1. 빠른 해싱에 MD5 기능을 사용하지만 비밀번호 저장에는 적합하지 않습니다. 2. SHA256 기능을 사용하여 보안을 향상시킵니다. 3. Password_hash 함수를 사용하여 비밀번호를 처리하여 최고 보안과 편의성을 제공하십시오.


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경

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

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

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

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.