目錄
史密斯數背後的邏輯
如何在Java中檢查史密斯數?
範例#2
結論
首頁 Java java教程 Java 中的史密斯數

Java 中的史密斯數

Aug 30, 2024 pm 04:28 PM
java

在 Java 中我們有不同類型的功能;史密斯號碼是提供給使用者的功能。基本上,史密斯數只不過是一個合數(在數係中以10為底),其所有數字之和等於其所有質因數(不包括1)所有數字之和,這就是所謂的史密斯數數字。史密斯數的另一個名稱是笑話數。根據定義,我們可以說,如果滿足條件,所有質數都被自然排除。通常,史密斯數是根據使用者要求及其問題陳述的一些要求在數學中使用的數字系統的一個非常基本的子欄位。

開始您的免費軟體開發課程

網頁開發、程式語言、軟體測試及其他

史密斯數背後的邏輯

現在讓我們來看看史密斯數背後的邏輯如下。

史密斯數的邏輯很簡單,我們考慮一下下面的數字,我們就很容易理解如下邏輯了。

範例:假設我們需要檢查給定的數字是否為史密斯號碼。

給定的數字是:95

首先,我們要找出 95 的質因數是 19 和 5 (5, 19)

現在求數字和 9 + 5 = 14

質因數總和為 5 + 1 + 9 = 15

現在比較兩個結果,看這裡 14 不等於 15。所以給定的數字不是素數。

讓我們考慮另一個數字,如下所示。

給出的數字:58

先找出 58 = 2 和 29 的質因數

質因數總和 = 2 + 2 +9 = 13

給定數字的總和 = 5 + 8 = 13

現在比較兩個結果,這裡兩個結果是相同的,或者我們可以說是相等的。所以我們可以說給定的數字是史密斯數。

這就是史密斯數背後非常簡單的邏輯,我們只需要比較素數階乘和與數字和即可。如果兩個總和相等,則給定的數字是史密斯數,否則該數字不是史密斯數。

如何在Java中檢查史密斯數?

現在讓我們看看如何在 java 中檢查給定的數字是否是 smith。

在上面這一點中,我們已經討論了史密斯數的不同範例。現在讓我們來看看尋找史密斯編號的不同步驟,如下所示。

1.首先我們需要初始化或讀取使用者的數字。

2.之後我們需要找出給定數字的數字總和。

3.接下來我們要找出給定數字的質數因子。

4.現在計算質因數的數字和。

5.現在比較給定數字的數字和與質因數的數字和。

a.如果兩個和相等,那麼我們可以說給定的數字是史密斯數。

b.否則,我們可以認為給定的數字不是史密斯數,因為總和不同。

所以上述步驟對於用Java實作史密斯數程式很有用。

範例

現在讓我們看看java中史密斯數的不同範例,以便更好地理解,如下。

範例#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.");
}
}

說明

在上面的程式中,我們嘗試用java實作史密斯數程式。在這裡,我們首先創建了質因數數字總和的函數;同樣,我們還創建了函數來查找給定數字的數字總和,如上面的程式所示。之後,我們創建了使用布林函數檢查給定數字是否為素數的函數。然後我們編寫主函數,在主函數中我們接受來自使用者的數字並呼叫我們已經創建的所有函數並比較兩個總和。如果總和相等,則列印給定的數字為史密斯數,如果總和不相等,則列印給定的數字不是史密斯數。我們使用下面的螢幕截圖來說明上述程式的最終輸出。

範例#2

讓我們來看另一個例子,如下。

代碼:

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 以內的所有 smith 編號,如圖所示。我們使用下面的螢幕截圖來說明上述程式的最終輸出。

Java 中的史密斯數

結論

我們希望您透過這篇文章學習 Java 中的史密斯數。從上面的文章中,我們了解了史密斯數的基本邏輯,也看到了史密斯數的不同例子。從這篇文章中,我們學習瞭如何以及何時在 java 中使用史密斯數。

以上是Java 中的史密斯數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Laravel 教程
1604
29
PHP教程
1510
276
如何在Java中實現簡單的TCP客戶端? 如何在Java中實現簡單的TCP客戶端? Aug 08, 2025 pm 03:56 PM

Importjava.ioandjava.net.SocketforI/Oandsocketcommunication.2.CreateaSocketobjecttoconnecttotheserverusinghostnameandport.3.UsePrintWritertosenddataviaoutputstreamandBufferedReadertoreadserverresponsesfrominputstream.4.Usetry-with-resourcestoautomati

用Docker將Java應用程序部署到Kubernetes 用Docker將Java應用程序部署到Kubernetes Aug 08, 2025 pm 02:45 PM

容器化Java應用:創建Dockerfile,使用基礎鏡像如eclipse-temurin:17-jre-alpine,複製JAR文件並定義啟動命令,通過dockerbuild構建鏡像並用dockerrun測試本地運行。 2.推送鏡像到容器註冊表:使用dockertag標記鏡像並推送到DockerHub等註冊表,需先登錄dockerlogin。 3.部署到Kubernetes:編寫deployment.yaml定義Deployment,設置副本數、容器鏡像和資源限制,編寫service.yaml創建

VS代碼快捷方式專注於Explorer面板 VS代碼快捷方式專注於Explorer面板 Aug 08, 2025 am 04:00 AM

VSCode中可通過快捷鍵快速切換面板與編輯區。要跳轉至左側資源管理器面板,使用Ctrl Shift E(Windows/Linux)或Cmd Shift E(Mac);返回編輯區可用Ctrl `或Esc或Ctrl 1~9。相比鼠標操作,鍵盤快捷鍵更高效且不打斷編碼節奏。其他技巧包括:Ctrl KCtrl E聚焦搜索框,F2重命名文件,Delete刪除文件,Enter打開文件,方向鍵展開/收起文件夾。

修復:Windows Update無法安裝 修復:Windows Update無法安裝 Aug 08, 2025 pm 04:16 PM

runthewindowsupdatetrubloubleshooterviaSettings>更新&安全> is esseShootsoAtomationfixCommonissues.2.ResetWindowSupDateComponentsByStoppingRealatedServices,RenamingTheSoftWaredWaredWaredSoftwaredSistribution andCatroot2Folders,intrestrestartingthertingthertingtherserviceSteStoceTocle

如何在Java中使用一個時循環 如何在Java中使用一個時循環 Aug 08, 2025 pm 04:04 PM

AwhileloopinJavarepeatedlyexecutescodeaslongastheconditionistrue;2.Initializeacontrolvariablebeforetheloop;3.Definetheloopconditionusingabooleanexpression;4.Updatethecontrolvariableinsidethelooptopreventinfinitelooping;5.Useexampleslikeprintingnumber

Java對象的序列化過程是什麼? Java對象的序列化過程是什麼? Aug 08, 2025 pm 04:03 PM

JavaserializationConvertSanObject'SstateIntoAbyTeSteAmForStorageorTransermission,andDeserializationReconstructstheObjectStheObjectFromThstream.1.toenableserialization,aclassMustimustimplementTheSerializableizableface.2.UseObjectObjectObjectObjectOutputputputputputtreamToserialializeanobectizeanobectementeabectenobexpent,savin

什麼是Java的哈希圖? 什麼是Java的哈希圖? Aug 11, 2025 pm 07:24 PM

ahashmapinjavaiSadattrastureturethatStoreskey-valuepairsforefficeFitedReval,插入和deletion.itusesthekey’shashcode()methodtodeTermInestorageLageLageAgeLageAgeAgeAgeAgeAneStorageAgeAndAllowSavereo(1)timecomplexityforget()

python numpy陣列示例 python numpy陣列示例 Aug 08, 2025 am 06:13 AM

NumPy數組的使用包括:1.創建數組(如從列表、全零、全一、範圍創建);2.形狀操作(reshape、轉置);3.向量化運算(加減乘除、廣播、數學函數);4.索引與切片(一維和二維操作);5.統計計算(最大值、最小值、均值、標準差、求和及軸向操作);這些操作高效且無需循環,適合大規模數值計算,最終掌握需多加練習。

See all articles