찾다
백엔드 개발PHP 튜토리얼K 회문 문자열 생성

Construct K Palindrome Strings

1400. K 회문 문자열 구성

난이도:

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

문자열 s와 정수 k가 주어지면 s의 모든 문자를 사용하여 k 회문 문자열을 구성할 수 있으면 true를 반환하고, 그렇지 않으면 false를 반환합니다.

예 1:

  • 입력: s = "annabelle", k = 2
  • 출력: true
  • 설명: s의 모든 문자를 사용하여 두 개의 회문을 구성할 수 있습니다.
    • 가능한 구문 "anna" "elble", "anbna" "elle", "anellena" "b"

예 2:

  • 입력: s = "leetcode", k = 3
  • 출력: false
  • 설명: s의 모든 문자를 사용하여 3개의 회문을 구성하는 것은 불가능합니다.

예 3:

  • 입력: s = "true", k = 4
  • 출력: true
  • 설명: 유일한 해결 방법은 각 문자를 별도의 문자열에 넣는 것입니다.

제약조건:

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

힌트:

  1. s.length
  2. 홀수 개수의 문자 수가 > k이면 우리가 구성할 수 있는 회문 문자열의 최소 개수는 > k이고 대답은 거짓입니다.
  3. 그렇지 않으면 정확히 k 개의 회문 문자열을 구성할 수 있으며 대답은 참입니다(왜?).

해결책:

다음 사항을 고려해야 합니다.

주요 관찰:

  1. 회문 특성:

    • 회문은 앞으로 읽어도 뒤로 읽어도 같은 문자열입니다.
    • 짝수 길이의 회문의 경우 모든 문자가 짝수 번 나타나야 합니다.
    • 홀수 길이의 회문의 경우 하나를 제외한 모든 문자가 짝수 번 나타나야 합니다(홀수 번 나타나는 문자가 중앙에 표시됩니다).
  2. 필요조건:

    • s의 길이가 k보다 작으면 k개의 문자열을 구성하는 것이 불가능하므로 false를 반환합니다.
    • k개의 회문을 형성하려면 홀수 번 나타나는 문자의 총 개수가 최대 k개여야 합니다. 이는 각 회문이 홀수 개수의 문자(홀수 길이 회문의 중심 문자)를 최대 1개까지 가질 수 있기 때문입니다.

접근하다:

  1. 문자열에서 각 문자의 빈도를 계산합니다.
  2. 홀수 빈도의 문자가 몇 개인지 세어보세요.
  3. 홀수 주파수의 개수가 k를 초과하면 false를 반환합니다(k개의 회문을 형성하는 것이 불가능하기 때문입니다).

이 솔루션을 PHP: 1400으로 구현해 보겠습니다. K 회문 문자열 생성

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

// Test cases
var_dump(canConstruct("annabelle", 2)); // Output: true
var_dump(canConstruct("leetcode", 3)); // Output: false
var_dump(canConstruct("true", 4));      // Output: true
?>

설명:

  1. 빈도수: 연관 배열 $freq를 사용하여 문자열에서 각 문자의 발생 횟수를 계산합니다.
  2. 홀수 개수: 홀수 문자가 몇 개나 나오는지 확인합니다. 이는 회문을 형성할 수 있는지 결정하는 데 도움이 됩니다.
  3. 조건 확인: 홀수 빈도의 문자 수가 k보다 크면 k개의 회문을 형성하는 것이 불가능하므로 false를 반환합니다. 그렇지 않으면 true를 반환합니다.

시간 복잡도:

  • 빈도수 계산에는 O(n)이 소요됩니다. 여기서 n은 문자열의 길이입니다.
  • 홀수 빈도를 확인하는 데는 O(m)이 소요됩니다. 여기서 m은 고유 문자 수(영문 소문자의 경우 최대 26자)입니다.
  • 전체 시간 복잡도는 O(n·m)이며, 이 경우 O(n)으로 단순화됩니다.

엣지 케이스:

  1. k가 s의 길이보다 크면 false를 반환합니다.
  2. 모든 문자의 빈도가 짝수이면 항상 회문을 형성할 수 있으므로 결과는 k가 가능한지 여부에 따라 달라집니다.

연락처 링크

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

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

  • 링크드인
  • 깃허브

위 내용은 K 회문 문자열 생성의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
교통량이 많은 웹 사이트를위한 PHP 성능 튜닝교통량이 많은 웹 사이트를위한 PHP 성능 튜닝May 14, 2025 am 12:13 AM

thesecrettokeepingAphp-poweredwebsiterunningsmoothlydlyUnderHeavyloadInvolvesEveralKeyStrategies : 1) ubstractOpCodeCachingWithOpCacheTecescripteExecutionTime, 2) usedatabasequeryCachingwithRedSendatabaseload, 3) LeverAgeCdnslikeCloudforforporerververforporporpin

PHP의 종속성 주입 : 초보자를위한 코드 예제PHP의 종속성 주입 : 초보자를위한 코드 예제May 14, 2025 am 12:08 AM

Code는 코드가 더 명확하고 유지 관리하기 쉽기 때문에 의존성 주입 (DI)에 관심을 가져야합니다. 1) DI는 클래스를 분리하여 더 모듈 식으로 만들고, 2) 테스트 및 코드 유연성의 편의성을 향상시키고, 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하지만 성능 영향 및 순환 종속성에주의를 기울이십시오. 4) 모범 사례는 추상 인터페이스에 의존하여 느슨한 커플 링을 달성하는 것입니다.

PHP 성능 : 응용 프로그램을 최적화 할 수 있습니까?PHP 성능 : 응용 프로그램을 최적화 할 수 있습니까?May 14, 2025 am 12:04 AM

예, PPAPPLICATIONISPOSSIBLEADESLESTION.1) INVERECINGUSINGAPCUTERODUCEDABASELOAD.2) INCODINCEDEXING, ENGICIONEQUERIES 및 CONNECTIONPOULING.3) 향상된 보드 바이어링, 플로 팅 포르코 잉을 피하는 최적화 된 APPCUTERODECEDATABASELOAD.2)

PHP 성능 최적화 : 궁극적 인 가이드PHP 성능 최적화 : 궁극적 인 가이드May 14, 2025 am 12:02 AM

theKeyStrategiesToSINCINTIFILINTINTIFILINTINTHPPORMATIONPERFORMANCEARE : 1) USEOPCODECACHING-CCHACHETEDECUTECUTINGTIME, 2) 최적화 된 ABESINSTEMENTEMENDSTEMENTEMENDSENDSTATEMENTENDS 및 PROPERINDEXING, 3) ConfigureWebSerVERSLIKENGINXXWITHPMFORBETPERMERCORMANCES, 4)

PHP 의존성 주입 컨테이너 : 빠른 시작PHP 의존성 주입 컨테이너 : 빠른 시작May 13, 2025 am 12:11 AM

aphpdectionenceindectioncontainerisatoolthatmanagesclassdependencies, 향상 Codemodularity, testability 및 maintainability.itactAsacentralHubForCreatingAndingDinjectingDingingDingingdecting.

PHP의 종속성 주입 대 서비스 로케이터PHP의 종속성 주입 대 서비스 로케이터May 13, 2025 am 12:10 AM

대규모 응용 프로그램의 경우 SELLENCIONINGESS (DI)를 선택하십시오. ServicElocator는 소규모 프로젝트 또는 프로토 타입에 적합합니다. 1) DI는 생성자 주입을 통한 코드의 테스트 가능성과 모듈성을 향상시킵니다. 2) Servicelocator는 센터 등록을 통해 서비스를 얻습니다. 이는 편리하지만 코드 커플 링이 증가 할 수 있습니다.

PHP 성능 최적화 전략.PHP 성능 최적화 전략.May 13, 2025 am 12:06 AM

phPapplicationSCanBeoptimizedForsPeedandefficiencyby : 1) ENABLEOPCACHEINPHP.INI, 2) PREPAREDSTATEMENTSWITHPDOFORDATABASEQUERIES 사용

PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다PHP 이메일 검증 : 이메일이 올바르게 전송되도록합니다May 13, 2025 am 12:06 AM

phpeMailValidationInvoLvestHreesteps : 1) formatValidationUsingRegularexpressionsTochemailformat; 2) dnsValidationToErethedomainHasaValidMxRecord; 3) smtpvalidation, theSTHOROUGHMETHOD, theCheckSiftheCefTHECCECKSOCCONNECTERTETETETETETETWERTETWERTETWER

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

Video Face Swap

Video Face Swap

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

뜨거운 도구

안전한 시험 브라우저

안전한 시험 브라우저

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

DVWA

DVWA

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

VSCode Windows 64비트 다운로드

VSCode Windows 64비트 다운로드

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

SublimeText3 중국어 버전

SublimeText3 중국어 버전

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

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)