プログラマーの皆さん!元気でいることを願っています。 LeetCode-75 シリーズのソリューションを共有できることを嬉しく思います。このシリーズでは、コーディング面接の準備に役立つ 75 の重要な問題が取り上げられています。
各投稿では、私のアプローチの詳細な説明とともに、私の解決策を紹介します。ご質問や改善のための提案がございましたら、お気軽にコメントに残してください。あなたと協力し、議論できることを楽しみにしています!コーディングを楽しんでください!
問題のリンクをここに追加しました: 文字列を交互に結合
問題の説明
2 つの文字列 word1 と word2 が与えられています。 word1 から始めて交互に文字を追加して、文字列を結合します。ある文字列が他の文字列より長い場合は、マージされた文字列の末尾に追加の文字を追加します。
マージされた文字列を返します。
*例 1: *
入力: word1 = "abc"、word2 = "pqr"
出力: "apbqcr"
説明: マージされた文字列は次のようにマージされます:
word1: a b c
word2: p q r
マージ: a p b q c r
例 2:
入力: word1 = "ab"、word2 = "pqrs"
出力: "apbqrs"
説明: word2 が長いため、最後に「rs」が追加されることに注意してください。
word1: a b
word2: p q r s
マージ: a p b q r s
** 例 3:**
入力: word1 = "abcd"、word2 = "pq"
出力: "apbqcd"
説明: word1 が長いため、最後に「cd」が追加されることに注意してください。
word1: a b c d
word2: p q
マージ: a p b q c d
解決
直感
2 つの文字列が与えられた場合、各文字列の文字を交互に並べて結合する必要があります。両方の文字列の長さが同じであれば、解決策は簡単ですが、異なる長さを持つこともできます。ポインターを使用して両方の文字列を反復処理し、両方のポインターが最後に到達するまで結果に文字を追加します。
アプローチ
- 両方の文字列の代替文字を保存する StringBuilder を作成します。
- 各文字列の現在位置を追跡するために 2 つのポインターを作成します。
- 両方のポインターがそれぞれの文字列の末尾に到達するまで、両方の文字列を繰り返します。
- 文字列が空でない場合は StringBuilder に要素を追加し、ポインタをインクリメントします
- StringBuilder を返す
複雑
時間計算量:
時間計算量は O(n) です。n は、文字列を反復処理するときの長い文字列の長さです。空間の複雑さ:
StringBuilder といくつかの変数を使用するため、時間計算量は 0(1) です。
コード
public String mergeAlternately (String word1, String word2) { // ? Create a StringBuilder to build the result string efficiently StringBuilder completeWord = new StringBuilder(); // ? Initialize two pointers to traverse both strings int p1 = 0; int p2 = 0; // ? Iterate through both strings until both pointers reach the end of their resépectives strings while (p1
以上が文字列を交互に結合するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します


ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

ZendStudio 13.5.1 Mac
強力な PHP 統合開発環境

PhpStorm Mac バージョン
最新(2018.2.1)のプロフェッショナル向けPHP統合開発ツール

SecLists
SecLists は、セキュリティ テスターの究極の相棒です。これは、セキュリティ評価中に頻繁に使用されるさまざまな種類のリストを 1 か所にまとめたものです。 SecLists は、セキュリティ テスターが必要とする可能性のあるすべてのリストを便利に提供することで、セキュリティ テストをより効率的かつ生産的にするのに役立ちます。リストの種類には、ユーザー名、パスワード、URL、ファジング ペイロード、機密データ パターン、Web シェルなどが含まれます。テスターはこのリポジトリを新しいテスト マシンにプルするだけで、必要なあらゆる種類のリストにアクセスできるようになります。

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

VSCode Windows 64 ビットのダウンロード
Microsoft によって発売された無料で強力な IDE エディター
