特定のスタックの上部と下部の要素を見つけるためのJavaプログラム
このチュートリアルでは、Javaを使用して特定のスタックの上部と下部要素を見つける方法を説明します。
スタックは、最初のout(lifo)原理の最後のに続く線形データセットを表します。したがって、同じ場所で要素が追加および削除されます。さらに、特定のスタックの上部と下部の要素を見つけるための2つの方法を探ります。つまり、および
n要素を含むスタックアレイが取得されます。タスクは、スタックの1番目とn番目の要素を何らかの形で破壊することなく見つけることです。したがって、元のスタックが変更されていないことを確認するには、カスタムスタックで
反復方法および再帰的方法を使用する必要があります。
1を入力します
<code>stack = [5, 10, 15, 20, 25, 30]</code>
<code>堆栈中的顶部元素是 --> 30 堆栈中的底部元素是 --> 5</code>
<code>stack = [1000, 2000, 3000, 4000, 5000]</code>
上部および下部要素を見つけるための反復方法
最初の方法では、スタックとして使用される配列を定義し、スタック操作を定義して、反復方法で目的の要素を取得します。特定のスタックの上部と下部要素を見つけるための手順は次のとおりです。<code>堆栈元素:5000 4000 3000 2000 1000 底部元素:1000 顶部元素:5000</code>
a
maxsize
値が6に等しく、上部を-1に設定してスタックを初期化します(空の配列を表します)。- 要素5、10、15、20、25、および30を押して30プッシュ()操作でスタックに押し込み、StackArray [TOP]で最高値を増やします。 スタックが空であるかどうかを確認します。次に、 peek()
- を使用して、StackArray [Top]を返すことで上部要素を見つけます。
最後に、
bottom()関数 - を使用します。 最終的な上部と下の値を出力します。
- 例
以下は、反復方法を使用して特定のスタックの上部と下部要素を見つけるJavaプログラムです。
時間の複雑さ:スタック形成中の
o(n)は、各要素が配列の端に追加され、インデックスはサイズnまで毎回1ずつ増加するためです。 o(1)は、覗き式および下部操作中に、stackarray [top]とstackarray [0]を返すためです。class MyStack { private int maxSize; private int[] stackArray; private int top; // 使用MyStack构造函数初始化堆栈 public MyStack(int size) { this.maxSize = size; this.stackArray = new int[maxSize]; // 将Top变量初始化为-1,表示空堆栈 this.top = -1; } // 将元素添加到stackArray中 public void push(int value) { if (top < maxSize -1) { stackArray[++top] = value; } else { System.out.println("堆栈已满"); } } // 使用peek()查找顶部元素 public int peek() { if (top >= 0) { return stackArray[top]; } else { System.out.println("堆栈为空。"); return -1; } } // 使用bottom()查找堆栈数组中的底部元素(第一个添加的值) public int bottom() { if (top >= 0) { return stackArray[0]; } else { System.out.println("堆栈为空。"); return -1; } } } public class Main { public static void main(String[] args) { MyStack stack = new MyStack(6); // 创建大小为6的堆栈 // 将元素压入堆栈 stack.push(5); stack.push(10); stack.push(15); stack.push(20); stack.push(25); stack.push(30); // 检索顶部和底部元素 int topElement = stack.peek(); int bottomElement = stack.bottom(); // 打印最终输出 System.out.println("堆栈中的顶部元素是 --> " + topElement); System.out.println("堆栈中的底部元素是 --> " + bottomElement); } }
<code>堆栈中的顶部元素是 --> 30 堆栈中的底部元素是 --> 5</code>
上部および下部の要素を見つけるための再帰的な方法
このアプローチでは、再帰を使用して、スタック内の上部と下部の要素を見つけます。スタックは初期化され、push()操作を使用して形成され、必要な要素を再帰的に抽出します。特定のスタックの上部と下部要素を見つけるための手順は次のとおりです。 以下は、再帰的な方法を使用して特定のスタックの上部と下部要素を見つけるJavaプログラムです。
時間の複雑さ:合計はO(n)です。これは、要素がサイズnのスタック形成中にo(1)操作にo(1)を費やすためです。最悪の場合、再帰操作コストo(n)。
空間的な複雑さ:再帰コールスタックのため、再帰的にはO(n)です。アレイ自体は、o(n)を使用してn要素を保存します。
結論 以上が特定のスタックの上部と下部の要素を見つけるためのJavaプログラムの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。
例
<code>stack = [5, 10, 15, 20, 25, 30]</code>
<code>堆栈中的顶部元素是 --> 30
堆栈中的底部元素是 --> 5</code>

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

PHPは、サーバー側で広く使用されているスクリプト言語で、特にWeb開発に適しています。 1.PHPは、HTMLを埋め込み、HTTP要求と応答を処理し、さまざまなデータベースをサポートできます。 2.PHPは、ダイナミックWebコンテンツ、プロセスフォームデータ、アクセスデータベースなどを生成するために使用され、強力なコミュニティサポートとオープンソースリソースを備えています。 3。PHPは解釈された言語であり、実行プロセスには語彙分析、文法分析、編集、実行が含まれます。 4.PHPは、ユーザー登録システムなどの高度なアプリケーションについてMySQLと組み合わせることができます。 5。PHPをデバッグするときは、error_reporting()やvar_dump()などの関数を使用できます。 6. PHPコードを最適化して、キャッシュメカニズムを使用し、データベースクエリを最適化し、組み込み関数を使用します。 7

PHP and Python each have their own advantages, and the choice should be based on project requirements. 1.PHPは、シンプルな構文と高い実行効率を備えたWeb開発に適しています。 2。Pythonは、簡潔な構文とリッチライブラリを備えたデータサイエンスと機械学習に適しています。

PHPは、特に迅速な開発や動的なコンテンツの処理に適していますが、データサイエンスとエンタープライズレベルのアプリケーションには良くありません。 Pythonと比較して、PHPはWeb開発においてより多くの利点がありますが、データサイエンスの分野ではPythonほど良くありません。 Javaと比較して、PHPはエンタープライズレベルのアプリケーションでより悪化しますが、Web開発により柔軟性があります。 JavaScriptと比較して、PHPはバックエンド開発により簡潔ですが、フロントエンド開発のJavaScriptほど良くありません。

PHPとPythonにはそれぞれ独自の利点があり、さまざまなシナリオに適しています。 1.PHPはWeb開発に適しており、組み込みのWebサーバーとRich Functionライブラリを提供します。 2。Pythonは、簡潔な構文と強力な標準ライブラリを備えたデータサイエンスと機械学習に適しています。選択するときは、プロジェクトの要件に基づいて決定する必要があります。

カプセルは3次元の幾何学的図形で、両端にシリンダーと半球で構成されています。カプセルの体積は、シリンダーの体積と両端に半球の体積を追加することで計算できます。このチュートリアルでは、さまざまな方法を使用して、Javaの特定のカプセルの体積を計算する方法について説明します。 カプセルボリュームフォーミュラ カプセルボリュームの式は次のとおりです。 カプセル体積=円筒形の体積2つの半球体積 で、 R:半球の半径。 H:シリンダーの高さ(半球を除く)。 例1 入力 RADIUS = 5ユニット 高さ= 10単位 出力 ボリューム= 1570.8立方ユニット 説明する 式を使用してボリュームを計算します。 ボリューム=π×R2×H(4

PHPが多くのWebサイトよりも優先テクノロジースタックである理由には、その使いやすさ、強力なコミュニティサポート、広範な使用が含まれます。 1)初心者に適した学習と使用が簡単です。 2)巨大な開発者コミュニティと豊富なリソースを持っています。 3)WordPress、Drupal、その他のプラットフォームで広く使用されています。 4)Webサーバーとしっかりと統合して、開発の展開を簡素化します。

Java は、初心者と経験豊富な開発者の両方が学習できる人気のあるプログラミング言語です。このチュートリアルは基本的な概念から始まり、高度なトピックに進みます。 Java Development Kit をインストールしたら、簡単な「Hello, World!」プログラムを作成してプログラミングを練習できます。コードを理解したら、コマンド プロンプトを使用してプログラムをコンパイルして実行すると、コンソールに「Hello, World!」と出力されます。 Java の学習はプログラミングの旅の始まりであり、習熟が深まるにつれて、より複雑なアプリケーションを作成できるようになります。
