在 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 if b="false;" d return public static void main args scanner s_c="new" system.out.print a number: int no="s_c.nextInt();" x="F_S_Digit(no);" y="F_Sum_P_Fact(no);" system.out.println of digit="+x); System.out.println(" addition prime factors digits is="+y); if(x==y) System.out.print(" the user enterd number smith number. else system. out.print entered not> <p><strong>說明</strong></p> <p>在上面的程式中,我們嘗試用java實作史密斯數程式。在這裡,我們首先創建了質因數數字總和的函數;同樣,我們還創建了函數來查找給定數字的數字總和,如上面的程式所示。之後,我們創建了使用布林函數檢查給定數字是否為素數的函數。然後我們編寫主函數,在主函數中我們接受來自使用者的數字並呼叫我們已經創建的所有函數並比較兩個總和。如果總和相等,則列印給定的數字為史密斯數,如果總和不相等,則列印給定的數字不是史密斯數。我們使用下面的螢幕截圖來說明上述程式的最終輸出。 </p> <h4 id="範例">範例#2</h4> <p>讓我們來看另一個例子,如下。 </p> <p><strong>代碼:</strong></p> <pre class="brush:php;toolbar:false">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 0) { s =s+(no % 10); no = no/10; } return s; } public static void main(String args[]) { for (int no = 1; no 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); } } } }</integer></integer>
說明
在上面的範例中,我們試著找出 5000 以內的所有 smith 編號,如圖所示。我們使用下面的螢幕截圖來說明上述程式的最終輸出。
結論
我們希望您透過這篇文章學習 Java 中的史密斯數。從上面的文章中,我們了解了史密斯數的基本邏輯,也看到了史密斯數的不同例子。從這篇文章中,我們學習瞭如何以及何時在 java 中使用史密斯數。
以上是Java 中的史密斯數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

Java是平台獨立的,因為其"一次編寫,到處運行"的設計理念,依賴於Java虛擬機(JVM)和字節碼。 1)Java代碼編譯成字節碼,由JVM解釋或即時編譯在本地運行。 2)需要注意庫依賴、性能差異和環境配置。 3)使用標準庫、跨平台測試和版本管理是確保平台獨立性的最佳實踐。

Java'splatFormIndenceIsnotsimple; itinvolvesComplexities.1)jvmcompatiblemustbebeeniblemustbeensuredacrossplatforms.2)Nativelibrariesandsystemcallsneedcarefulhandling.3)

Java'splatformindependencebenefitswebapplicationsbyallowingcodetorunonanysystemwithaJVM,simplifyingdeploymentandscaling.Itenables:1)easydeploymentacrossdifferentservers,2)seamlessscalingacrosscloudplatforms,and3)consistentdevelopmenttodeploymentproce

thejvmistheruntimeenvorment forexecutingjavabytecode,Cocucialforjava的“ WriteOnce,RunanyWhere”能力

JavaremainsatopchoicefordevelopersduetoitsplatFormentence,對象與方向設計,強度,自動化的MememoryManagement和ComprechensivestAndArdArdArdLibrary

Java'splatFormIndependecemeansDeveloperScanWriteCeandeCeandOnanyDeviceWithouTrecompOlding.thisAcachivedThroughThroughTheroughThejavavirtualmachine(JVM),WhaterslatesbyTecodeDecodeOdeIntComenthendions,允許univerniverSaliversalComplatibilityAcrossplatss.allospplats.s.howevss.howev

要設置JVM,需按以下步驟進行:1)下載並安裝JDK,2)設置環境變量,3)驗證安裝,4)設置IDE,5)測試運行程序。設置JVM不僅僅是讓其工作,還包括優化內存分配、垃圾收集、性能調優和錯誤處理,以確保最佳運行效果。

toensurejavaplatFormIntence,lofterTheSeSteps:1)compileAndRunyOpplicationOnmultPlatFormSusiseDifferenToSandjvmversions.2)upureizeci/cdppipipelinelikeinkinslikejenkinsorgithikejenkinsorgithikejenkinsorgithikejenkinsorgithike forautomatecross-plateftestesteftestesting.3)


熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

Safe Exam Browser
Safe Exam Browser是一個安全的瀏覽器環境,安全地進行線上考試。該軟體將任何電腦變成一個安全的工作站。它控制對任何實用工具的訪問,並防止學生使用未經授權的資源。

PhpStorm Mac 版本
最新(2018.2.1 )專業的PHP整合開發工具

SecLists
SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

禪工作室 13.0.1
強大的PHP整合開發環境

SublimeText3 英文版
推薦:為Win版本,支援程式碼提示!