3043。最長の共通プレフィックスの長さを求める
難易度: 中
トピック: 配列、ハッシュ テーブル、文字列、トライ
正の整数 arr1 と arr2 を持つ 2 つの配列が与えられます。
正の整数の 接頭辞 は、左端 の桁から始まる 1 つ以上の桁で形成される整数です。たとえば、123 は整数 12345 の接頭辞ですが、234 は ではありません.
2 つの整数 a と b の共通接頭辞 は整数 c であり、c は a と b の両方の接頭辞になります。たとえば、5655359 と 56554 には共通のプレフィックス 565 がありますが、1223 と 43456 には共通のプレフィックスがありません。 x が arr1 に属し、y が arr2 に属するような、整数のすべてのペア (x, y) の間で
最長の共通プレフィックスの長さを見つける必要があります。 すべてのペアの
最長の共通プレフィックスの長さを返します。それらの間に共通のプレフィックスが存在しない場合は、0. を返します。
例 1:
- 入力:
- arr1 = [1,10,100]、arr2 = [1000] 出力:
- 3 説明:
- 3 つのペア (arr1[i]、arr2[j]) があります。
(1, 1000) の最も長い共通プレフィックスは 1 です。
- (10, 1000) の最も長い共通プレフィックスは 10 です。
- (100, 1000) の最も長い共通プレフィックスは 100 です。
- 最も長い共通プレフィックスは 100、長さは 3 です。
- 入力:
- arr1 = [1,2,3]、arr2 = [4,4,4] 出力:
- 4 説明:
- どのペア (arr1[i]、arr2[j]) にも共通のプレフィックスが存在しないため、0 を返します。
同じ配列の要素間の共通の接頭辞はカウントされないことに注意してください。
1 4
arr1 の各要素の可能なプレフィックスをすべて HashSet に入れます。
- arr2 の各要素のすべての可能なプレフィックスについて、それが HashSet に存在するかどうかを確認します。
HashSet を利用して 1 つの配列からプレフィックスを保存し、2 番目の配列でそれらのプレフィックスをチェックできます。
アプローチ:
- プレフィックスの生成
: arr1 と arr2 の各数値に対して、可能なすべてのプレフィックスを生成します。プレフィックスは、左端の数字から始まる 1 つ以上の数字で形成されます。
- arr1 のプレフィックスをセットに保存する
: HashSet を使用して数値のすべてのプレフィックスを arr1 に保存すると、arr2 からのプレフィックスをチェックするときに高速な検索が保証されます。
- 最長の共通プレフィックスの検索
: arr2 の各番号について、そのプレフィックスを生成し、これらのプレフィックスのいずれかが手順 2 の HashSet に存在するかどうかを確認します。見つかった最長のプレフィックスを追跡します。
- 最長の共通プレフィックスの長さを返す
: 共通プレフィックスが見つかった場合は、その長さを返します。それ以外の場合は 0 を返します。
このソリューションを PHP で実装してみましょう:
<?php /** * @param Integer[] $arr1 * @param Integer[] $arr2 * @return Integer */ function longestCommonPrefix($arr1, $arr2) { ... ... ... /** * go to ./solution.php */ } // Example usage: $arr1 = [1, 10, 100]; $arr2 = [1000]; echo longestCommonPrefix($arr1, $arr2); // Output: 3 $arr1 = [1, 2, 3]; $arr2 = [4, 4, 4]; echo longestCommonPrefix($arr1, $arr2); // Output: 0 ?>
- ハッシュセットの作成
:
最初に連想配列 $prefixSet を作成し、arr1 内の数値の可能なすべての接頭辞を保持します。- arr1 内の各数値を反復処理し、文字列に変換し、substr 関数を使用してそのすべてのプレフィックスを抽出します。各プレフィックスは $prefixSet に保存されます。
- プレフィックスチェック
:
次に、arr2 内の各数値をループし、同様に文字列に変換します。- arr2 の各数値について、考えられるすべてのプレフィックスを再度抽出します。
- $prefixSet にプレフィックスが存在する場合、その長さが現在見つかっている最大長 ($maxLength) より大きいかどうかを確認します。
- 結果を返す
:
最後に、見つかった最も長い共通プレフィックスの長さを返します。
複雑:
- 時間計算量
- : O(n * m) ここで、n と m はそれぞれ arr1 と arr2 の長さです。これは、すべての数値とそのプレフィックスを処理しているためです。 空間複雑度
- : O(p) ここで、p は HashSet に格納されているプレフィックスの総数です。 このソリューションは効率的であり、指定された制約内でうまく機能します。
이 시리즈가 도움이 되었다면 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 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

WebStorm Mac 버전
유용한 JavaScript 개발 도구

드림위버 CS6
시각적 웹 개발 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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