検索
ホームページJava&#&チュートリアルJava でのバイナリ ツリーの反転

最近、アルゴリズム/データ構造のスキルを向上させるために、LeetCode の演習をいくつか練習し始めました。このプラットフォームは、他の開発者と複数のプログラミング言語でソリューションを練習して学習したり、他の開発者とソリューションを議論したり共有したり、大企業から要求されたコードの課題を練習したりするのに適した環境を提供していると言えます。

LeetCodeとは何ですか?

Inverting a binary tree in Java

LeetCode は、候補者がコーディング面接の準備をするのに役立つ Web サイトです。ユーザーは、候補者の解決策に対する事前定義されたテストとともに、プラットフォームのコーディングおよびアルゴリズムの問​​題を使用して課題を練習できます。 LeetCode は、HackerRank と並んで、技術面接やコーディング コンテストの人気リソースとなっています。

私のルーチンの問題解決

私は 1 日に少なくとも 3 つの課題を解決するという目標を掲げており、解決策の考え方には iPad、画面用のペン、Freeform アプリを使用しています。私は解決策を描いて考えるようにしていますが、これはコードの提出に大いに役立っています。多くの課題は一見すると難しそうに見えますが、数分で解決策を考え、設計することができます (思考プロセスを書き留めることをお勧めします)。 30 分以内に適切な解決策が見つからない場合は、他の開発者からの提出物を見て、自分の間違い (コード内で忘れていた小さなステップ) がどこにあるのかを見つけます。あなたのソリューションが十分に優れている場合でも、他の人が提出したものを見て、その問題を解決する別の方法 (多かれ少なかれ効率的) を考えることを強くお勧めします。

逆二分木問題

Inverting a binary tree in Java
数日前、私は LeetCode で Invert Binary Tree 問題に直面しました。これはいくつかのインタビューで要求されたよく知られた課題であり、大学でデータ構造/アルゴリズムのクラスを受講したときに見た問題でもありました。私は面接でこのような課題に直面したことはなく、仕事で二分木を明示的に反転したこともありませんでしたが、二分木を反転する方法を知ることで、DS、ツリー、アルゴリズムの考え方についてより多くの経験を積むことができ、再帰などのいくつかのテクニックを練習することができました。
この記事の残りを読む前に、この問題を解決してみることをお勧めします

解決策

二分木の反転問題では、「二分木のルートが与えられた場合、その木を反転し、そのルートを返す」ように求められました。 (言い換えれば、ツリーを「ミラーリング」する必要があります)。 Java プログラミング言語を使用してソリューションを送信しましたが、手順は他の言語でも同じです (構文が少し変更されています)。入力例と予想される出力を以下に示します。

Inverting a binary tree in Java

Input: root = [4,2,7,1,3,6,9]
Output: [4,7,2,9,6,3,1]

再帰手法を使用して invertTree() メソッドを再帰的に呼び出し、ツリーのある側面をルートとして渡します。したがって、すべての再帰で要求されるように、再帰スタックが終了して再帰呼び出しのそれぞれの結果を返す停止条件を定義する必要があります。その後、ツリーの側面を反転して、root.right をパラメータとして渡す再帰によって返された値を root.left に割り当て、同じことを root.right に行い、root.left 再帰結果の値を割り当てます。 元の値を変更しているため、root.left の元の結果を保存するための補助変数が必要です (おそらく大学でこのようなコードを実装し、swap() メソッドと呼んでいたでしょう。

最後に、ノードを反転したルートを返します。以下のコードを確認できます:

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public TreeNode invertTree(TreeNode root) {
        if(root == null) {
            return null;
        }

        TreeNode aux = root.left;
        root.left = invertTree(root.right);
        root.right = invertTree(aux);

        return root;
    }
}

さまざまな問題に対してさまざまな解決策が存在する可能性があることを覚えておいてください。それは素晴らしいことです。誰もが考え方やプログラム、データ構造ドメインなどを持っています。この問題を解決するためにまったく同じコードに従う必要はありませんが、アルゴリズムの複雑さに注意を払う必要があります (問題を解決するには 3 つのネストを使用できます)ただし、これは 1 を使用するよりもパフォーマンスが低くなります。

以上がJava でのバイナリ ツリーの反転の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
JVMのクラスローダーサブシステムは、プラットフォームの独立性にどのように貢献していますか?JVMのクラスローダーサブシステムは、プラットフォームの独立性にどのように貢献していますか?Apr 23, 2025 am 12:14 AM

クラスローダーは、統一されたクラスファイル形式、動的読み込み、親代表団モデル、プラットフォーム非依存バイトコードを通じて、さまざまなプラットフォーム上のJavaプログラムの一貫性と互換性を保証し、プラットフォームの独立性を実現します。

Javaコンパイラはプラットフォーム固有のコードを作成しますか?説明する。Javaコンパイラはプラットフォーム固有のコードを作成しますか?説明する。Apr 23, 2025 am 12:09 AM

Javaコンパイラによって生成されたコードはプラットフォームに依存しませんが、最終的に実行されるコードはプラットフォーム固有です。 1。Javaソースコードは、プラットフォームに依存しないバイトコードにコンパイルされます。 2。JVMは、特定のプラットフォームのバイトコードをマシンコードに変換し、クロスプラットフォーム操作を保証しますが、パフォーマンスは異なる場合があります。

JVMは、さまざまなオペレーティングシステムでマルチスレッドをどのように処理しますか?JVMは、さまざまなオペレーティングシステムでマルチスレッドをどのように処理しますか?Apr 23, 2025 am 12:07 AM

マルチスレッドは、プログラムの応答性とリソースの利用を改善し、複雑な同時タスクを処理できるため、最新のプログラミングで重要です。 JVMは、スレッドマッピング、スケジューリングメカニズム、同期ロックメカニズムを介して、異なるオペレーティングシステム上のマルチスレッドの一貫性と効率を保証します。

Javaの文脈では、「プラットフォームの独立」とはどういう意味ですか?Javaの文脈では、「プラットフォームの独立」とはどういう意味ですか?Apr 23, 2025 am 12:05 AM

Javaのプラットフォームの独立性とは、書かれたコードがJVMが変更なしでインストールされた任意のプラットフォームで実行できることを意味します。 1)JavaソースコードはBytecodeにコンパイルされ、2)BytecodeはJVMによって解釈および実行されます、3)JVMは、プログラムが異なるオペレーティングシステムで実行されることを確認するために、メモリ管理とガベージコレクション機能を提供します。

Javaアプリケーションは、プラットフォーム固有のバグや問題に遭遇する可能性がありますか?Javaアプリケーションは、プラットフォーム固有のバグや問題に遭遇する可能性がありますか?Apr 23, 2025 am 12:03 AM

JavaApplicationScanIndEDENCOUNTIONPLATFORM-SPECISTESUESUSESEJVM'SABSTRACTION.REASONSINCLUDE:1)NativeCodeandLibraries、2)OperatingSystemDifferences、3)JVMimplementationVariations、および4)HardweardePencies.TomiteTETETETESES、DEVELAPERSHOULD:1)

クラウドコンピューティングは、Javaのプラットフォーム独立の重要性にどのような影響を与えますか?クラウドコンピューティングは、Javaのプラットフォーム独立の重要性にどのような影響を与えますか?Apr 22, 2025 pm 07:05 PM

クラウドコンピューティングにより、Javaのプラットフォームの独立性が大幅に向上します。 1)JavaコードはBytecodeにコンパイルされ、異なるオペレーティングシステムでJVMによって実行され、クロスプラットフォーム操作が確保されます。 2)DockerとKubernetesを使用してJavaアプリケーションを展開して、携帯性とスケーラビリティを向上させます。

Javaのプラットフォームの独立性は、その広範な採用においてどのような役割を果たしましたか?Javaのプラットフォームの独立性は、その広範な採用においてどのような役割を果たしましたか?Apr 22, 2025 pm 06:53 PM

java'splatformendenceallowsdevelopersowritecodeodeonceanceandonitondeviceoros withajvm.

コンテナ化テクノロジー(Dockerなど)は、Javaのプラットフォーム独立性の重要性にどのように影響しますか?コンテナ化テクノロジー(Dockerなど)は、Javaのプラットフォーム独立性の重要性にどのように影響しますか?Apr 22, 2025 pm 06:49 PM

Dockerなどのコンテナ化技術は、Javaのプラットフォームの独立性を置き換えるのではなく、強化します。 1)環境全体の一貫性を確保し、2)特定のJVMバージョンを含む依存関係を管理する、3)展開プロセスを簡素化して、Javaアプリケーションをより順応性と管理しやすくする。

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 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

SublimeText3 Linux 新バージョン

SublimeText3 Linux 新バージョン

SublimeText3 Linux 最新バージョン

VSCode Windows 64 ビットのダウンロード

VSCode Windows 64 ビットのダウンロード

Microsoft によって発売された無料で強力な IDE エディター

MinGW - Minimalist GNU for Windows

MinGW - Minimalist GNU for Windows

このプロジェクトは osdn.net/projects/mingw に移行中です。引き続きそこでフォローしていただけます。 MinGW: GNU Compiler Collection (GCC) のネイティブ Windows ポートであり、ネイティブ Windows アプリケーションを構築するための自由に配布可能なインポート ライブラリとヘッダー ファイルであり、C99 機能をサポートする MSVC ランタイムの拡張機能が含まれています。すべての MinGW ソフトウェアは 64 ビット Windows プラットフォームで実行できます。

Dreamweaver Mac版

Dreamweaver Mac版

ビジュアル Web 開発ツール

DVWA

DVWA

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