3042. 접두사와 접미사 쌍 계산 I
난이도: 쉬움
주제: 배열, 문자열, Trie, 롤링 해시, 문자열 일치, 해시 함수
인덱스가 0인 문자열 배열 단어가 주어졌습니다.
두 개의 문자열 str1과 str2를 사용하는 부울 함수 isPrefixAndSuffix를 정의해 보겠습니다.
- isPrefixAndSuffix(str1, str2)는 str1이 str2의 접두사1 및 접미사2인 경우 true를 반환하고, 그렇지 않은 경우 false를 반환합니다. 예를 들어, isPrefixAndSuffix("aba", "ababa")는 "aba"가 "ababa"의 접두사이자 접미사이므로 true이지만 isPrefixAndSuffix("abc", "abcd")는 false입니다.
i 번호
를 나타내는 정수를 반환합니다. j, isPrefixAndSuffix(words[i], word[j])는 true입니다.
예 1:
- 입력:
- 단어 = ["a","aba","ababa","aa"] 출력:
- 4 설명:
- 이 예에서 계산된 인덱스 쌍은 다음과 같습니다. i = 0이고 j = 1입니다. isPrefixAndSuffix("a", "aba")가 true이기 때문입니다. i = 0이고 j = 2입니다. isPrefixAndSuffix("a", "ababa")가 true이기 때문입니다. i = 0이고 j = 3입니다. isPrefixAndSuffix("a", "aa")가 true이기 때문입니다. i = 1이고 j = 2입니다. isPrefixAndSuffix("aba", "ababa")가 true이기 때문입니다. 그러므로 답은 4이다.
- 입력:
- 단어 = ["pa","papa","ma","mama"] 출력:
- 2 설명:
- 이 예에서 계산된 인덱스 쌍은 다음과 같습니다. i = 0이고 j = 1입니다. isPrefixAndSuffix("pa", "papa")가 true이기 때문입니다. i = 2이고 j = 3입니다. isPrefixAndSuffix("ma", "mama")가 true이기 때문입니다. 따라서 답은 2입니다.
- 입력:
- 단어 = ["abab","ab"] 출력:
- 0 설명:
- 이 예에서 유일한 유효한 인덱스 쌍은 i = 0 및 j = 1이고 isPrefixAndSuffix("abab", "ab")는 false입니다. 그러므로 답은 0이다.
1
모든 인덱스 쌍(i, j)을 반복하여 i
i
이 솔루션을 PHP로 구현해 보겠습니다: 3042. 접두사와 접미사 쌍 계산 I
<?php /** * @param String[] $words * @return Integer */ function countPrefixAndSuffixPairs($words) { ... ... ... /** * go to ./solution.php */ } /** * Function to check if str1 is both a prefix and a suffix of str2 * * @param $str1 * @param $str2 * @return bool */ function isPrefixAndSuffix($str1, $str2) { ... ... ... /** * go to ./solution.php */ } // Example Test Cases $words1 = ["a", "aba", "ababa", "aa"]; $words2 = ["pa", "papa", "ma", "mama"]; $words3 = ["abab", "ab"]; echo countPrefixAndSuffixPairs($words1) . "\n"; // Output: 4 echo countPrefixAndSuffixPairs($words2) . "\n"; // Output: 2 echo countPrefixAndSuffixPairs($words3) . "\n"; // Output: 0 ?>
설명:
-
countPrefixAndSuffixPairs($words):
- 이 함수는 i
- isPrefixAndSuffix()를 호출하여 단어[i]가 단어[j]의 접두사이자 접미사인지 확인합니다.
- 조건이 true일 경우 카운트를 증가시킵니다.
-
isPrefixAndSuffix($str1, $str2):
- 이 도우미 함수는 str1이 str2의 접두사이자 접미사인지 확인합니다.
- substr()을 사용하여 str2의 접두사와 접미사를 추출하고 이를 str1과 비교합니다.
- 두 조건이 모두 true이면 true를 반환하고, 그렇지 않으면 false를 반환합니다.
시간 복잡도:
- 시간 복잡도는 O(n2 x m)입니다. 여기서 n은 단어 배열의 길이이고 m은 단어 배열의 평균 길이입니다. 배열의 문자열. 이는 중첩 루프와 substr() 작업 때문입니다.
예제 출력:
주어진 입력 배열의 경우:
- ["a", "aba", "ababa", "aa"] -> 출력: 4
- ["아빠", "아빠", "엄마", "엄마"] -> 출력: 2
- ["abab", "ab"] -> 출력: 0
이 솔루션은 주어진 제약 내에서 효율적으로 작동해야 합니다.
연락처 링크
이 시리즈가 도움이 되었다면 GitHub에서 저장소에 별표를 표시하거나 즐겨찾는 소셜 네트워크에서 게시물을 공유해 보세요. 여러분의 지원은 저에게 큰 의미가 될 것입니다!
이렇게 더 유용한 콘텐츠를 원하시면 저를 팔로우해주세요.
- 링크드인
- 깃허브
-
접두사 문자열의 접두사는 문자열의 시작 부분에서 시작하여 문자열 내의 모든 지점까지 확장되는 하위 문자열입니다. ↩
-
접미사 문자열의 접미사는 문자열의 임의 지점에서 시작하여 끝까지 이어지는 하위 문자열입니다. ↩
위 내용은 접두사 및 접미사 쌍 계산 I의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

expendencyInphpisaDesignpatternpattern thatenhances-flexibility, testability 및 maintainabilitable externaldenciestoclasses.itallowsforloosecoupling, easiertesting throughmocking 및 modulardesign, berrequirecarefultructuringtoavoid-inje

PHP 성능 최적화는 다음 단계를 통해 달성 할 수 있습니다. 1) 스크립트 상단에 require_once 또는 include_once를 사용하여 파일로드 수를 줄입니다. 2) 데이터베이스 쿼리 수를 줄이기 위해 전처리 문 및 배치 처리를 사용하십시오. 3) Opcode 캐시에 대한 Opcache 구성; 4) PHP-FPM 최적화 프로세스 관리를 활성화하고 구성합니다. 5) CDN을 사용하여 정적 자원을 배포합니다. 6) 코드 성능 분석을 위해 Xdebug 또는 Blackfire를 사용하십시오. 7) 배열과 같은 효율적인 데이터 구조를 선택하십시오. 8) 최적화 실행을위한 모듈 식 코드를 작성하십시오.

opCodeCachingsIntIficInlyIntImeRimproveSphpperformanceCachingCompileDCode, retingServerLoadandResponsEtimes.1) itStoresCompyledPhpCodeInMemory, BYPASSINGPARSINGCOMPILING.2) UseOpCacheSettingParametersInphP.Ini, likeMoryConsAncme AD

종속성 주입은 PHP의 외부 주입을 통해 객체 종속성을 제공하여 코드의 유지 관리 및 유연성을 향상시킵니다. 구현 방법에는 다음이 포함됩니다. 1. 생성자 주입, 2. 값 주입 세트, 3. 인터페이스 주입. 종속성 주입을 사용하면 분리되어 테스트 성과 유연성을 향상시킬 수 있지만 복잡성과 성능 오버 헤드가 증가 할 가능성에주의를 기울여야합니다.

PHP에서 의존성 주입 (DI) 구현은 수동 주입 또는 DI 컨테이너를 사용하여 수행 할 수 있습니다. 1) 수동 주입은 Userservice 클래스 주입 로거와 같은 생성자를 통해 종속성을 통과합니다. 2) DI 컨테이너를 사용하여 컨테이너 클래스와 같은 종속성을 자동으로 관리하여 로거 및 사용자 서비스를 관리합니다. DI를 구현하면 코드 유연성 및 테스트 가능성을 향상시킬 수 있지만 오버 삽입 및 서비스 로케이터 안티 모드와 같은 트랩에주의를 기울여야합니다.

thedifferencebetweenUnset () andsession_destroy () istssection_destroy () thinatesTheentiresession.1) TEREMOVECIFICESSESSION 'STERSESSIVEBLESSESSIVESTIETSTESTERSALLS'SSOVERSOLLS '를 사용하는 것들

stickysessionsureSureSureRequestSaroutEdToTheSERSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESSESINCENSENCY

phpoffersvarioussessionsaveAndlers : 1) 파일 : 기본, 단순, 단순한 BUTMAYBOTTLENECKONHIGH-TRAFFICSITES.2) MEMCACHED : 고성능, IdealForspeed-CriticalApplications.3) Redis : SimilartomemCached, WithaddedPersistence.4) 데이터베일 : OffforIntegrati


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!

에디트플러스 중국어 크랙 버전
작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

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

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

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경