国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目次
スミス番號(hào)の背後にあるロジック
Java でスミス番號(hào)を確認(rèn)する方法?
例 #2
結(jié)論

Javaのスミス番號(hào)

Aug 30, 2024 pm 04:28 PM
java

Java には異なる種類(lèi)の機(jī)能があります。スミス番號(hào)は、ユーザーに提供される機(jī)能の 1 種類(lèi)です?;镜膜恕ⅴ攻撺箶?shù)は、すべての桁の加算がそのすべての素因數(shù) (1 を除く) のすべての桁の加算に等しい合成數(shù) (整數(shù)體系では底が 10) に他なりません。これはスミスとして知られています。番號(hào)。スミスナンバーの別名はジョークナンバーです。定義上、條件を満たせばすべての素?cái)?shù)は自然に除外されると言えます。通常、スミス數(shù)は、ユーザーの要件および問(wèn)題ステートメントの要件の一部に従って、數(shù)學(xué)で使用される數(shù)體系の非常に基本的なサブフィールドです。

無(wú)料ソフトウェア開(kāi)発コースを始めましょう

Web 開(kāi)発、プログラミング言語(yǔ)、ソフトウェア テスト、その他

スミス番號(hào)の背後にあるロジック

次に、スミス番號(hào)の背後にあるロジックを次のように見(jiàn)てみましょう。

スミス數(shù)のロジックは非常に簡(jiǎn)単です。次の數(shù)字を考えてみましょう。そうすれば、次のようなロジックを簡(jiǎn)単に理解できます。

例: 指定された番號(hào)がスミス番號(hào)であるかどうかを確認(rèn)する必要があるとします。

與えられた數(shù)字は: 95

まず、95 の素因數(shù)が 19 と 5 (5, 19) であることを調(diào)べる必要があります

次に、9 + 5 = 14 となる數(shù)字の合計(jì)を求めます

素因數(shù)の合計(jì)は 5 + 1 + 9 = 15

次に、両方の結(jié)果を比較します。ここで、14 は 15 に等しくありません。したがって、指定された數(shù)値は素?cái)?shù)ではありません。

次のような別の數(shù)を考えてみましょう。

與えられた番號(hào): 58

まず、58 = 2 と 29 の素因數(shù)を求めます

素因數(shù)の合計(jì)は = 2 + 2 +9 = 13

指定された數(shù)字の合計(jì)は = 5 + 8 = 13 です

次に両方の結(jié)果を比較します。ここでは両方の結(jié)果が同じであるか、等しいと言えます。したがって、與えられた番號(hào)はスミス番號(hào)であると言えます。

これはスミス數(shù)の背後にある非常に単純なロジックです。素因數(shù)和と桁和を比較するだけで済みます。両方の合計(jì)が等しい場(chǎng)合、指定された數(shù)値はスミス數(shù)値であり、それ以外の場(chǎng)合、その數(shù)値はスミス數(shù)値ではありません。

Java でスミス番號(hào)を確認(rèn)する方法?

次に、次のように Java で指定された數(shù)値が smith であるかどうかを確認(rèn)する方法を見(jiàn)てみましょう。

上記の點(diǎn)で、スミス數(shù)値のさまざまな例についてはすでに説明しました。次に、スミス番號(hào)を見(jiàn)つけるためのさまざまな手順を次のように見(jiàn)てみましょう。

1.まず、初期化するか、ユーザーから數(shù)値を読み取る必要があります。

2.その後、指定された數(shù)値の桁の合計(jì)を見(jiàn)つける必要があります。

3.次に、指定された數(shù)値の素因數(shù)を見(jiàn)つける必要があります。

4.次に、素因數(shù)の桁の合計(jì)を計(jì)算します。

5.次に、指定された數(shù)値の桁の合計(jì)と素因數(shù)の桁の合計(jì)を比較します。

a.両方の合計(jì)が等しい場(chǎng)合、指定された數(shù)値がスミス數(shù)値であると言えます。

b.それ以外の場(chǎng)合、合計(jì)が異なるため、指定された數(shù)値はスミス數(shù)値ではないと考えることができます。

したがって、上記の手順は Java でスミス數(shù)値プログラムを?qū)g裝するのに役立ちます。

次に、理解を深めるために、次のように Java のスミス數(shù)値のさまざまな例を見(jiàn)てみましょう。

例 #1

コード:

import java.util.*;
public class Smith_Num
{
static int F_Sum_P_Fact(int no)
{
int j=2, add=0;
while(no>1)
{
if(no%j==0)
{
add=add+F_S_Digit(j);
no=no/j;
}
else
{
do
{
j++;
}
while(!isPrime(j));
}
}
return add;
}
static int F_S_Digit(int no)
{
int sum=0;
while(no>0)
{
sum=sum+no%10;
no=no/10;
}
return sum;
}
static boolean isPrime(int j)
{
boolean b=true;
int d=2;
while(d<Math.sqrt(j))
{
if(j%d==0)
{
b=false;
}
d++;
}
return b;
}
public static void main(String args[])
{
Scanner s_c = new Scanner(System.in);
System.out.print("Enter a number: ");
int no=s_c.nextInt();
int x = F_S_Digit(no);
int y = F_Sum_P_Fact(no);
System.out.println("addition of digit = "+x);
System.out.println("addition of prime factors digits is = "+y);
if(x==y)
System.out.print("The user enterd number is smith number.");
else
System. out.print("The user entered number is not smith number.");
}
}

説明

上記のプログラムでは、スミス番號(hào)プログラムを Java で実裝しようとしています。ここでは、まず素因數(shù)の桁を合計(jì)する関數(shù)を作成しました。同様に、上記のプログラムで示したように、指定された數(shù)値の桁の合計(jì)を求める関數(shù)も作成しました。次に、ブール関數(shù)を使用して、與えられた數(shù)値が素?cái)?shù)かどうかをチェックする関數(shù)を作成しました。次に、メイン関數(shù)を作成します。メイン関數(shù)內(nèi)でユーザーから數(shù)値を受け取り、すでに作成したすべての関數(shù)を呼び出し、両方の合計(jì)を比較します。合計(jì)が等しい場(chǎng)合は、指定された數(shù)値をスミス番號(hào)として出力し、合計(jì)が等しくない場(chǎng)合は、指定された數(shù)値はスミス番號(hào)ではないと出力します。上記のプログラムの最終出力を、次のスクリーンショットを使用して説明します。

例 #2

次のような別の例を見(jiàn)てみましょう。

コード:

import java.util.*;
public class Smith_Num_2
{
static List<Integer> F_P_Fact(int no)
{
List<Integer> output = new ArrayList<>();
for (int j = 2; no % j == 0; no = no/j)
output.add(j);
for (int j = 3; j* j <= no; j=j+2)
{
while (no % j == 0)
{
output.add(j);
no = no/j;
}
}
if (no != 1)
output.add(no);
return output;
}
static int S_Digit(int no)
{
int s= 0;
while (no > 0)
{
s =s+(no % 10);
no = no/10;
}
return s;
}
public static void main(String args[])
{
for (int no = 1; no < 5000; no++)
{
List<Integer> Fact = F_P_Fact(no);
if (Fact.size() > 1)
{
int s = S_Digit(no);
for (int fa : Fact)
s =s-S_Digit(fa);
if (s == 0)
System.out.println(no);
}
}
}
}

説明

上記の例では、示されているように、最大?? 5000 までのすべてのスミス番號(hào)を見(jiàn)つけようとしています。上記のプログラムの最終出力を、次のスクリーンショットを使用して説明します。

Javaのスミス番號(hào)

結(jié)論

この記事から Java のスミス數(shù)を?qū)Wんでいただければ幸いです。上記の記事から、スミス數(shù)の基本的なロジックを?qū)Wび、スミス數(shù)のさまざまな例も確認(rèn)しました。この記事から、Java でスミス番號(hào)をいつどのように使用するかを?qū)Wびました。

以上がJavaのスミス番號(hào)の詳細(xì)內(nèi)容です。詳細(xì)については、PHP 中國(guó)語(yǔ) Web サイトの他の関連記事を參照してください。

このウェブサイトの聲明
この記事の內(nèi)容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰屬します。このサイトは、それに相當(dāng)する法的責(zé)任を負(fù)いません。盜作または侵害の疑いのあるコンテンツを見(jiàn)つけた場(chǎng)合は、admin@php.cn までご連絡(luò)ください。

ホットAIツール

Undress AI Tool

Undress AI Tool

脫衣畫(huà)像を無(wú)料で

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード寫(xiě)真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

寫(xiě)真から衣服を削除するオンライン AI ツール。

Clothoff.io

Clothoff.io

AI衣類(lèi)リムーバー

Video Face Swap

Video Face Swap

完全無(wú)料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡(jiǎn)単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無(wú)料のコードエディター

SublimeText3 中國(guó)語(yǔ)版

SublimeText3 中國(guó)語(yǔ)版

中國(guó)語(yǔ)版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強(qiáng)力な PHP 統(tǒng)合開(kāi)発環(huán)境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開(kāi)発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Java Classloadersの動(dòng)作方法 Java Classloadersの動(dòng)作方法 Jul 06, 2025 am 02:53 AM

Javaのクラスロードメカニズムはクラスローダーを介して実裝されており、そのコアワークフローは、読み込み、リンク、初期化の3つの段階に分けられます。ローディングフェーズ中、クラスローダーはクラスのバイトコードを動(dòng)的に読み取り、クラスオブジェクトを作成します。リンクには、クラスの正しさの確認(rèn)、靜的変數(shù)へのメモリの割り當(dāng)て、およびシンボル?yún)⒄栅谓馕訾蓼欷蓼埂3跗诨?、靜的コードブロックと靜的変數(shù)割り當(dāng)てを?qū)g行します。クラスの読み込みは、親クラスローダーに優(yōu)先順位を付けてクラスを見(jiàn)つけ、ブートストラップ、拡張機(jī)能、およびアプリケーションクラスローダーを順?lè)嗽嚖筏?、コアクラスライブラリが安全であり、重複した負(fù)荷を回避することを確認(rèn)します。開(kāi)発者は、urlclasslなどのクラスローダーをカスタマイズできます

現(xiàn)代のジャワの非同期プログラミング技術(shù) 現(xiàn)代のジャワの非同期プログラミング技術(shù) Jul 07, 2025 am 02:24 AM

Javaは、Java19での完了可能なストリーム(ProjectReactorなど)、仮想スレッドの使用など、非同期プログラミングをサポートしています。 1.CompletableFutureチェーンコールを通じてコードの読みやすさとメンテナンスを改善し、タスクオーケストレーションと例外処理をサポートします。 2。ProjectReactorは、バックプレッシャーメカニズムとリッチ演算子を備えた応答性プログラミングを?qū)g裝するためのモノとフラックスタイプを提供します。 3.仮想スレッドは、同時(shí)性コストを削減し、I/O集約型タスクに適しており、従來(lái)のプラットフォームスレッドよりも軽量で拡張が容易です。各方法には適用可能なシナリオがあり、適切なツールをお客様のニーズに応じて選択する必要があり、混合モデルはシンプルさを維持するために避ける必要があります

Java Nioとその利點(diǎn)を理解する Java Nioとその利點(diǎn)を理解する Jul 08, 2025 am 02:55 AM

Javanioは、Java 1.4によって導(dǎo)入された新しいIoapiです。 1)バッファとチャネルを?qū)澫螭趣筏皮い蓼埂?)バッファ、チャネル、セレクターのコアコンポーネント、3)ノンブロッキングモードをサポートし、4)従來(lái)のIOよりも効率的に並行接続を処理します。その利點(diǎn)は、次のことに反映されます。1)非ブロッキングIOはスレッドオーバーヘッドを減らし、2)データ送信効率を改善し、3)セレクターがマルチプレックスを?qū)g現(xiàn)し、4)メモリマッピングはファイルの読み取りと書(shū)き込みを速めます。注:1)バッファのフリップ/クリア操作は混亂しやすく、2)不完全なデータをブロックせずに手動(dòng)で処理する必要があります。3)セレクター登録は時(shí)間內(nèi)にキャンセルする必要があります。4)NIOはすべてのシナリオに適していません。

Javaで酵素を使用するためのベストプラクティス Javaで酵素を使用するためのベストプラクティス Jul 07, 2025 am 02:35 AM

Javaでは、列挙は固定定數(shù)セットを表すのに適しています。ベストプラクティスには以下が含まれます。1。列挙を使用して固定狀態(tài)またはオプションを表して、タイプの安全性と読みやすさを改善します。 2.フィールド、コンストラクター、ヘルパーメソッドなどの定義など、柔軟性を高めるために、酵素にプロパティとメソッドを追加します。 3. enummapとEnumsetを使用して、パフォーマンスとタイプの安全性を向上させ、配列に??基づいてより効率的であるためです。 4.動(dòng)的値、頻繁な変更、複雑なロジックシナリオなどの列挙の悪用を避けてください。これらは他の方法に置き換える必要があります。列挙の正しい使用は、コードの品質(zhì)を改善し、エラーを減らすことができますが、適用される境界に注意を払う必要があります。

匿名のインナークラスとは何ですか? 匿名のインナークラスとは何ですか? Jul 07, 2025 am 02:18 AM

匿名の內(nèi)部クラスは、Javaでサブクラスを作成したり、その場(chǎng)でインターフェイスを?qū)g裝するために使用され、GUIアプリケーションでのイベント処理など、特定の目的を達(dá)成するための方法をオーバーライドするためによく使用されます。その構(gòu)文フォームは、クラス本體を直接定義する新しいインターフェイスまたはクラスであり、アクセスされるローカル変數(shù)が最終的または同等の不変でなければならないことを要求します。それらは便利ですが、使いすぎてはいけません。特にロジックが複雑な場(chǎng)合は、Java8のLambda式に置き換えることができます。

Javaで例外を適切に処理する方法は? Javaで例外を適切に処理する方法は? Jul 06, 2025 am 02:43 AM

Javaの例外を処理するための鍵は、それらをキャッチし、それらを明確に処理し、問(wèn)題を隠さないことです。まず、必要に応じて特定の例外タイプをキャッチし、一般的なキャッチを避け、CheckEdexceptionsを優(yōu)先順位付けする必要があります。ランタイムの例外は事前に審査する必要があります。次に、ログフレームワークを使用して例外を記録し、タイプに基づいて再試行、ロールバック、またはスローする必要があります。第三に、最終的なブロックを使用してリソースをリリースする必要があり、リソース付きの試行をお?jiǎng)幛幛工氡匾ⅳ辘蓼?。?に、カスタムの例外を合理的に定義し、runtimeexceptionまたは例外を継承し、簡(jiǎn)単にデバッグするためのコンテキスト情報(bào)を伝達(dá)する必要があります。

JavaのSingletonデザインパターンとは何ですか? JavaのSingletonデザインパターンとは何ですか? Jul 09, 2025 am 01:32 AM

JavaのSingleton Design Patternは、クラスに1つのインスタンスしかないことを保証し、プライベートコンストラクターと靜的方法を介したグローバルアクセスポイントを提供することを保証します。これは、共有リソースへのアクセスを制御するのに適しています。実裝方法には以下が含まれます。1。レイジーロード、つまり、インスタンスは最初のリクエストが要求されたときにのみ作成されます。これは、リソースの消費(fèi)が高く、必ずしも必要ではない狀況に適しています。 2。スレッドセーフ処理。同期方法または再確認(rèn)ロックを介して、マルチスレッド環(huán)境で1つのインスタンスのみが作成され、パフォーマンスへの影響が低下するようにします。 3.クラスの読み込み中にインスタンスを直接初期化するHungry Loadingは、事前に初期化できる軽量オブジェクトまたはシナリオに適しています。 4.列挙の実裝は、Java列挙を使用してシリアル化、スレッドの安全性をサポートし、反射攻撃を防止することは、推奨される簡(jiǎn)潔で信頼できる方法です。特定のニーズに応じて、さまざまな実裝方法を選択できます

Java String vs StringBuilder vs StringBuffer Java String vs StringBuilder vs StringBuffer Jul 09, 2025 am 01:02 AM

文字列は不変、StringBuilderは可変で非スレッドセーフ、StringBufferはMutableとThread-Safeです。 1.文字列のコンテンツが作成されると、少量のスプライシングに適しています。 2。StringBuilderは、単一のスレッドの頻繁なスプライシングに適しており、パフォーマンスが高くなっています。 3。StringBufferは、マルチスレッドの共有シナリオに適していますが、パフォーマンスがわずかに低くなっています。 4.初期容量を合理的に設(shè)定し、ループで文字列スプライシングを使用することはパフォーマンスを向上させることができます。

See all articles