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

目錄
史密斯數(shù)背后的邏輯
如何在Java中檢查史密斯數(shù)?
示例#2
結(jié)論
首頁(yè) Java java教程 Java 中的史密斯數(shù)

Java 中的史密斯數(shù)

Aug 30, 2024 pm 04:28 PM
java

在 Java 中我們有不同類(lèi)型的功能;史密斯號(hào)碼是提供給用戶(hù)的一種功能?;旧?,史密斯數(shù)只不過(guò)是一個(gè)合數(shù)(在數(shù)系中以10為底),其所有數(shù)字之和等于其所有質(zhì)因數(shù)(不包括1)所有數(shù)字之和,這就是所謂的史密斯數(shù)數(shù)字。史密斯數(shù)的另一個(gè)名稱(chēng)是笑話(huà)數(shù)。根據(jù)定義,我們可以說(shuō),如果滿(mǎn)足條件,所有素?cái)?shù)都被自然排除。通常,史密斯數(shù)是根據(jù)用戶(hù)要求及其問(wèn)題陳述的一些要求在數(shù)學(xué)中使用的數(shù)字系統(tǒng)的一個(gè)非?;镜淖幼侄巍?/p>

開(kāi)始您的免費(fèi)軟件開(kāi)發(fā)課程

網(wǎng)絡(luò)開(kāi)發(fā)、編程語(yǔ)言、軟件測(cè)試及其他

史密斯數(shù)背后的邏輯

現(xiàn)在讓我們看看史密斯數(shù)背后的邏輯如下。

史密斯數(shù)的邏輯很簡(jiǎn)單,我們考慮一下下面的數(shù)字,我們就很容易理解如下邏輯了。

示例:假設(shè)我們需要檢查給定的數(shù)字是否是史密斯號(hào)碼。

給定的數(shù)字是:95

首先,我們需要找出 95 的質(zhì)因數(shù)是 19 和 5 (5, 19)

現(xiàn)在求數(shù)字之和 9 + 5 = 14

質(zhì)因數(shù)之和為 5 + 1 + 9 = 15

現(xiàn)在比較兩個(gè)結(jié)果,看這里 14 不等于 15。所以給定的數(shù)字不是素?cái)?shù)。

讓我們考慮另一個(gè)數(shù)字,如下所示。

給出的數(shù)字:58

首先找到 58 = 2 和 29 的質(zhì)因數(shù)

質(zhì)因數(shù)之和 = 2 + 2 +9 = 13

給定數(shù)字的總和 = 5 + 8 = 13

現(xiàn)在比較兩個(gè)結(jié)果,這里兩個(gè)結(jié)果是相同的,或者我們可以說(shuō)是相等的。所以我們可以說(shuō)給定的數(shù)字是史密斯數(shù)。

這就是史密斯數(shù)背后非常簡(jiǎn)單的邏輯,我們只需要比較素?cái)?shù)階乘和與數(shù)字和即可。如果兩個(gè)總和相等,則給定的數(shù)字是史密斯數(shù),否則該數(shù)字不是史密斯數(shù)。

如何在Java中檢查史密斯數(shù)?

現(xiàn)在讓我們看看如何在 java 中檢查給定的數(shù)字是否是 smith。

在上面這一點(diǎn)中,我們已經(jīng)討論了史密斯數(shù)的不同示例?,F(xiàn)在讓我們看看查找史密斯編號(hào)的不同步驟,如下所示。

1.首先我們需要初始化或讀取用戶(hù)的數(shù)字。

2.之后我們需要找到給定數(shù)字的數(shù)字之和。

3.接下來(lái)我們需要找到給定數(shù)字的素?cái)?shù)因子。

4.現(xiàn)在計(jì)算質(zhì)因數(shù)的數(shù)字和。

5.現(xiàn)在比較給定數(shù)字的數(shù)字之和與質(zhì)因數(shù)的數(shù)字之和。

a.如果兩個(gè)和相等,那么我們可以說(shuō)給定的數(shù)字是史密斯數(shù)。

b.否則,我們可以認(rèn)為給定的數(shù)字不是史密斯數(shù),因?yàn)榭偤筒煌?/p>

所以上述步驟對(duì)于用Java實(shí)現(xiàn)史密斯數(shù)程序很有用。

示例

現(xiàn)在讓我們看看java中史密斯數(shù)的不同示例,以便更好地理解,如下。

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

說(shuō)明

在上面的程序中,我們嘗試用java實(shí)現(xiàn)史密斯數(shù)程序。在這里,我們首先創(chuàng)建了質(zhì)因數(shù)數(shù)字之和的函數(shù);同樣,我們還創(chuàng)建了函數(shù)來(lái)查找給定數(shù)字的數(shù)字總和,如上面的程序所示。之后,我們創(chuàng)建了使用布爾函數(shù)檢查給定數(shù)字是否為素?cái)?shù)的函數(shù)。然后我們編寫(xiě)主函數(shù),在主函數(shù)中我們接受來(lái)自用戶(hù)的數(shù)字并調(diào)用我們已經(jīng)創(chuàng)建的所有函數(shù)并比較兩個(gè)總和。如果總和相等,則打印給定的數(shù)字為史密斯數(shù),如果總和不相等,則打印給定的數(shù)字不是史密斯數(shù)。我們使用下面的屏幕截圖來(lái)說(shuō)明上述程序的最終輸出。

示例#2

讓我們看另一個(gè)例子,如下。

代碼:

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);
}
}
}
}

說(shuō)明

在上面的示例中,我們嘗試找出 5000 以?xún)?nèi)的所有 smith 編號(hào),如圖所示。我們使用下面的屏幕截圖來(lái)說(shuō)明上述程序的最終輸出。

Java 中的史密斯數(shù)

結(jié)論

我們希望您通過(guò)這篇文章學(xué)習(xí) Java 中的史密斯數(shù)。從上面的文章中,我們了解了史密斯數(shù)的基本邏輯,也看到了史密斯數(shù)的不同例子。從這篇文章中,我們學(xué)習(xí)了如何以及何時(shí)在 java 中使用史密斯數(shù)。

以上是Java 中的史密斯數(shù)的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線(xiàn)人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話(huà)題

將語(yǔ)義結(jié)構(gòu)應(yīng)用于html的文章,部分和旁邊 將語(yǔ)義結(jié)構(gòu)應(yīng)用于html的文章,部分和旁邊 Jul 05, 2025 am 02:03 AM

在HTML中合理使用語(yǔ)義化標(biāo)簽?zāi)芴嵘?yè)面結(jié)構(gòu)清晰度、可訪問(wèn)性和SEO效果。1.用于獨(dú)立內(nèi)容區(qū)塊,如博客文章或評(píng)論,需保持自包含性;2.用于歸類(lèi)相關(guān)內(nèi)容,通常包含標(biāo)題,適用于頁(yè)面不同模塊;3.用于與主內(nèi)容相關(guān)但非核心的輔助信息,如側(cè)邊欄推薦或作者簡(jiǎn)介。實(shí)際開(kāi)發(fā)中應(yīng)結(jié)合、等標(biāo)簽,避免過(guò)度嵌套,保持結(jié)構(gòu)簡(jiǎn)潔,并通過(guò)開(kāi)發(fā)者工具驗(yàn)證結(jié)構(gòu)合理性。

請(qǐng)求的操作需要高程窗戶(hù) 請(qǐng)求的操作需要高程窗戶(hù) Jul 04, 2025 am 02:58 AM

遇到“此操作需要提升權(quán)限”提示時(shí),說(shuō)明你需要管理員權(quán)限才能繼續(xù)。解決方法包括:1.右鍵選擇“以管理員身份運(yùn)行”程序或設(shè)置快捷方式始終以管理員身份運(yùn)行;2.檢查當(dāng)前賬戶(hù)是否為管理員賬戶(hù),若不是則切換或請(qǐng)求管理員協(xié)助;3.用管理員權(quán)限打開(kāi)命令提示符或PowerShell執(zhí)行相關(guān)命令;4.在必要時(shí)通過(guò)獲取文件所有權(quán)或修改注冊(cè)表等手段繞過(guò)限制,但此類(lèi)操作需謹(jǐn)慎并充分了解風(fēng)險(xiǎn)。確認(rèn)權(quán)限身份并嘗試上述方法通常可解決問(wèn)題。

Java中可呼叫和可運(yùn)行的差異 Java中可呼叫和可運(yùn)行的差異 Jul 04, 2025 am 02:50 AM

Callable和Runnable在Java中主要有三點(diǎn)區(qū)別。第一,Callable的call()方法可以返回結(jié)果,適合需要返回值的任務(wù),如Callable;而Runnable的run()方法無(wú)返回值,適用于無(wú)需返回的任務(wù),如日志記錄。第二,Callable允許拋出checked異常,便于錯(cuò)誤傳遞;而Runnable必須在內(nèi)部處理異常。第三,Runnable可直接傳給Thread或ExecutorService,而Callable只能提交給ExecutorService,并返回Future對(duì)象以

探索Java中不同的同步機(jī)制 探索Java中不同的同步機(jī)制 Jul 04, 2025 am 02:53 AM

Javaprovidesmultiplesynchronizationtoolsforthreadsafety.1.synchronizedblocksensuremutualexclusionbylockingmethodsorspecificcodesections.2.ReentrantLockoffersadvancedcontrol,includingtryLockandfairnesspolicies.3.Conditionvariablesallowthreadstowaitfor

Java Classloader在內(nèi)部如何工作 Java Classloader在內(nèi)部如何工作 Jul 06, 2025 am 02:53 AM

Java的類(lèi)加載機(jī)制通過(guò)ClassLoader實(shí)現(xiàn),其核心工作流程分為加載、鏈接和初始化三個(gè)階段。加載階段由ClassLoader動(dòng)態(tài)讀取類(lèi)的字節(jié)碼并創(chuàng)建Class對(duì)象;鏈接包括驗(yàn)證類(lèi)的正確性、為靜態(tài)變量分配內(nèi)存及解析符號(hào)引用;初始化則執(zhí)行靜態(tài)代碼塊和靜態(tài)變量賦值。類(lèi)加載采用雙親委派模型,優(yōu)先委托父類(lèi)加載器查找類(lèi),依次嘗試Bootstrap、Extension和ApplicationClassLoader,確保核心類(lèi)庫(kù)安全且避免重復(fù)加載。開(kāi)發(fā)者可自定義ClassLoader,如URLClassL

有效處理常見(jiàn)的Java例外 有效處理常見(jiàn)的Java例外 Jul 05, 2025 am 02:35 AM

Java異常處理的關(guān)鍵在于區(qū)分checked和unchecked異常并合理使用try-catch、finally及日志記錄。1.checked異常如IOException需強(qiáng)制處理,適用于可預(yù)期的外部問(wèn)題;2.unchecked異常如NullPointerException通常由程序邏輯錯(cuò)誤引起,屬于運(yùn)行時(shí)錯(cuò)誤;3.捕獲異常時(shí)應(yīng)具體明確,避免籠統(tǒng)捕獲Exception;4.推薦使用try-with-resources自動(dòng)關(guān)閉資源,減少手動(dòng)清理代碼;5.異常處理中應(yīng)結(jié)合日志框架記錄詳細(xì)信息,便于后

現(xiàn)代爪哇的異步編程技術(shù) 現(xiàn)代爪哇的異步編程技術(shù) Jul 07, 2025 am 02:24 AM

Java支持異步編程的方式包括使用CompletableFuture、響應(yīng)式流(如ProjectReactor)以及Java19 中的虛擬線(xiàn)程。1.CompletableFuture通過(guò)鏈?zhǔn)秸{(diào)用提升代碼可讀性和維護(hù)性,支持任務(wù)編排和異常處理;2.ProjectReactor提供Mono和Flux類(lèi)型實(shí)現(xiàn)響應(yīng)式編程,具備背壓機(jī)制和豐富的操作符;3.虛擬線(xiàn)程減少并發(fā)成本,適用于I/O密集型任務(wù),與傳統(tǒng)平臺(tái)線(xiàn)程相比更輕量且易于擴(kuò)展。每種方式均有適用場(chǎng)景,應(yīng)根據(jù)需求選擇合適工具并避免混合模型以保持簡(jiǎn)潔性

Java中'靜態(tài)”關(guān)鍵字的目的是什么? Java中'靜態(tài)”關(guān)鍵字的目的是什么? Jul 05, 2025 am 02:36 AM

靜態(tài)關(guān)鍵字在Java中用于創(chuàng)建屬于類(lèi)本身的變量和方法,而非類(lèi)的實(shí)例。1.靜態(tài)變量被所有類(lèi)的實(shí)例共享,適用于存儲(chǔ)所有對(duì)象共有的數(shù)據(jù),如Student類(lèi)中的schoolName。2.靜態(tài)方法屬于類(lèi),不依賴(lài)對(duì)象,常用于工具函數(shù),如Math.sqrt(),且只能訪問(wèn)其他靜態(tài)成員。3.靜態(tài)代碼塊用于在類(lèi)加載時(shí)執(zhí)行初始化操作,如加載庫(kù)或設(shè)置日志。4.靜態(tài)內(nèi)部類(lèi)可以獨(dú)立于外部類(lèi)實(shí)例化,但無(wú)法訪問(wèn)外部類(lèi)的非靜態(tài)成員。合理使用static能有效管理類(lèi)級(jí)別的資源和行為。

See all articles