1422。文字列分割後の最大スコア
難易度: 簡単
トピック: 文字列、プレフィックス合計
0 と 1 の文字列 s を指定すると、文字列を 2 つの 空でない 部分文字列 (つまり、left 部分文字列と right 部分文字列).
文字列を分割した後のスコアは、左部分文字列のゼロの数と、右の1の数を足したものです。部分文字列。
例 1:
- 入力: s = "011101"
- 出力: 5
- 説明: s を 2 つの空ではない部分文字列に分割する可能なすべての方法は次のとおりです。
- 左 = "0"、右 = "11101"、スコア = 1 4 = 5
- 左 = "01" および右 = "1101"、スコア = 1 3 = 4
- 左 = "011" および右 = "101"、スコア = 1 2 = 3
- 左 = "0111" および右 = "01"、スコア = 1 1 = 2
- 左 = "01110" および右 = "1"、スコア = 2 1 = 3
例 2:
- 入力: s = "00111"
- 出力: 5
- 説明: 左 = "00"、右 = "111" の場合、最大スコア = 2 3 = 5 が得られます
例 3:
- 入力: s = "1111"
- 出力: 3
制約:
- 2
文字列 s は文字「0」と「1」のみで構成されます。
ヒント:
- 1 のプレフィックス合計 ('1') を事前計算します。
- 左から右にゼロ (「0」) の数を数えて反復し、事前に計算されたプレフィックスの合計を使用して 1 (「1」) を数えます。答えを更新します。
解決策:
文字列内の 1 のプレフィックス合計 ('1') を事前計算することで提供されるヒントを利用できます。解決策を詳しく説明します:手順:
- 1 のプレフィックス合計: 文字列内のインデックス i の各要素にインデックス i までの 1 の数 (「1」) が含まれる配列を事前計算します。
-
文字列を反復処理します: 各位置 i について、0 から i までの部分文字列を「左」部分文字列として扱い、i 1 から文字列の末尾までを「右」部分文字列として扱います。
- 反復中に単純にカウントすることで、左側の部分文字列内のゼロを数えます。
- 接頭辞の合計を使用して、右側の部分文字列内の 1 をカウントします (文字列内の 1 の合計数から分割点の接頭辞の合計を減算します)。
- スコアを計算する: 可能な分割ごとに、左側の部分文字列のゼロの数と右側の部分文字列の 1 の数を加算してスコアを計算します。
- 最大スコアを返します。
1422。文字列分割後の最大スコア
<?php /** * @param String $s * @return Integer */ function maxScore($s) { ... ... ... /** * go to ./solution.php */ } // Test cases $s1 = "011101"; $s2 = "00111"; $s3 = "1111"; echo "Input: $s1, Output: " . maxScore($s1) . PHP_EOL; // Output: 5 echo "Input: $s2, Output: " . maxScore($s2) . PHP_EOL; // Output: 5 echo "Input: $s3, Output: " . maxScore($s3) . PHP_EOL; // Output: 3 ?>説明:
-
プレフィックス合計の計算: 配列 $prefixOneCount 内の 1 のプレフィックス合計を計算します。ここで、各インデックスは、その時点までの 1 の累積カウントを保持します。
-
可能な分割の反復: 各インデックス i (0 から n-2) の反復を開始します。ここで、文字列は左側の部分 (0 から i) と右側の部分 ( i 1 から n-1 まで)。
- 分割ごとに、左側の部分文字列 ($zeroCountLeft) のゼロを数えます。
- 事前に計算された $prefixOneCount を使用して、正しい部分文字列に 1 がいくつあるかを計算します。
-
スコア計算: 各スプリットのスコアは、左側の部分の 0 と右側の部分の 1 の合計として計算されます。この反復中に発生した最大スコアを更新します。
-
最終結果: この関数は、すべての分割中に見つかった最大スコアを返します。
-
時間計算量: O(n)
- プレフィックス合計の事前計算と文字列の反復処理はどちらも
- O(n) を要します。 スコアを計算するために文字列を反復処理する場合も O(n) かかります。
- したがって、合計時間計算量は O(n) となり、指定された入力サイズ (n ≤ 500) に対して効率的です。
-
空間の複雑さ: O(n)
- プレフィックス合計配列には、
- O(n) の追加スペースが必要です。
echo maxScore("011101"); // Output: 5 echo maxScore("00111"); // Output: 5 echo maxScore("1111"); // Output: 3このソリューションは最適であり、制約内で問題を処理します。
連絡先リンク
このシリーズが役立つと思われた場合は、GitHub でリポジトリ にスターを付けるか、お気に入りのソーシャル ネットワークで投稿を共有することを検討してください。あなたのサポートは私にとって大きな意味を持ちます!
このような役立つコンテンツがさらに必要な場合は、お気軽にフォローしてください:
- GitHub
以上が文字列分割後の最大スコアの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

TooptimizePHPcodeforreducedmemoryusageandexecutiontime,followthesesteps:1)Usereferencesinsteadofcopyinglargedatastructurestoreducememoryconsumption.2)LeveragePHP'sbuilt-infunctionslikearray_mapforfasterexecution.3)Implementcachingmechanisms,suchasAPC

PhpisusedForsedingEmailsDueToitsIttegration withServerMailServicesAndExternalSmtpproviders、自動化とMarketingCampaign.1)SetupYourphpenvironment withebeBironment witheBiserverandphp、保証

メールを送信する最良の方法は、PHPMailerライブラリを使用することです。 1)Mail()関数を使用することはシンプルですが信頼できないため、電子メールがスパムを入力するか、配信できない場合があります。 2)PHPMailerは、より良い制御と信頼性を提供し、HTMLメール、添付ファイル、SMTP認証をサポートします。 3)SMTP設定が正しく構成されていることを確認し、暗号化(StartTLSやSSL/TLSなど)を使用してセキュリティを強化します。 4)大量の電子メールについては、メールキューシステムを使用してパフォーマンスを最適化することを検討してください。

customedersandaddadvancedfeaturesinphpemailentalitylivainability.1)customederadddetadata fortrackingandcategorization.2)htmLemailsallowStingtintintintintintinteractivity.3)添付物質の添付物質の添付

PHPとSMTPを使用してメールを送信することは、PHPMailerライブラリを介して実現できます。 1)PHPMailerをインストールして構成する、2)SMTPサーバーの詳細を設定する、3)電子メールコンテンツを定義し、4)メールを送信してエラーを処理します。この方法を使用して、電子メールの信頼性とセキュリティを確保します。

BestappRoachforseminginphpisusingthephpmailerlibrarydueToitsReliability、featurrichness、andeaseofuse.phpmailerSupportssmtpは、detairederorhandlingを提供します

依存関係注射(DI)を使用する理由は、コードのゆるい結合、テスト可能性、および保守性を促進するためです。 1)コンストラクターを使用して依存関係を注入します。2)サービスロケーターの使用を避け、3)依存関係噴射コンテナを使用して依存関係を管理する、4)依存関係を注入することでテスト可能性を向上させる、5)注入依存性を回避、6)パフォーマンスに対するDIの影響を考慮します。

phpperformancetuningisucial cuseenhancess andandandadsand。


ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

Video Face Swap
完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

人気の記事

ホットツール

SublimeText3 中国語版
中国語版、とても使いやすい

Safe Exam Browser
Safe Exam Browser は、オンライン試験を安全に受験するための安全なブラウザ環境です。このソフトウェアは、あらゆるコンピュータを安全なワークステーションに変えます。あらゆるユーティリティへのアクセスを制御し、学生が無許可のリソースを使用するのを防ぎます。

DVWA
Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、

mPDF
mPDF は、UTF-8 でエンコードされた HTML から PDF ファイルを生成できる PHP ライブラリです。オリジナルの作者である Ian Back は、Web サイトから「オンザフライ」で PDF ファイルを出力し、さまざまな言語を処理するために mPDF を作成しました。 HTML2FPDF などのオリジナルのスクリプトよりも遅く、Unicode フォントを使用すると生成されるファイルが大きくなりますが、CSS スタイルなどをサポートし、多くの機能強化が施されています。 RTL (アラビア語とヘブライ語) や CJK (中国語、日本語、韓国語) を含むほぼすべての言語をサポートします。ネストされたブロックレベル要素 (P、DIV など) をサポートします。

MantisBT
Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。
