分解質因數

来源:http://www.cnblogs.com/Jack1816274408/archive/2017/11/13/7825363.html
-Advertisement-
Play Games

題目內容: 每個非素數(合數)都可以寫成幾個素數(也可稱為質數)相乘的形式,這幾個素數就都叫做這個合數的質因數。比如,6可以被分解為2x3,而24可以被分解為2x2x2x3。 現在,你的程式要讀入一個[2,100000]範圍內的整數,然後輸出它的質因數分解式;當讀到的就是素數時,輸出它本身。 輸入格 ...


 

 

題目內容:

每個非素數(合數)都可以寫成幾個素數(也可稱為質數)相乘的形式,這幾個素數就都叫做這個合數的質因數。比如,6可以被分解為2x3,而24可以被分解為2x2x2x3。

現在,你的程式要讀入一個[2,100000]範圍內的整數,然後輸出它的質因數分解式;當讀到的就是素數時,輸出它本身。

 

輸入格式:

一個整數,範圍在[2,100000]內。

 

輸出格式:

形如:

n=axbxcxd

n=n

所有的符號之間都沒有空格,x是小寫字母x。

 

輸入樣例:

18

 

輸出樣例:

18=2x3x3

 

import java.util.Scanner;

public class Main {
public static void main(String[] args) {
Scanner sc = new Scanner(System.in);

int count = 0;// 計數器
int n = 0;// 輸入
int nBeifen;// 備份n
int prime = 2;// 素數,第一個素數是2

n = sc.nextInt();

if (prime(n)) {
System.out.printf("%d=%d\n", n, n);// n=n
} else {
System.out.printf("%d=", n);// n=axbxcxd

nBeifen = n;

while (nBeifen > 1) {
if (nBeifen % prime == 0) {
if (count > 0) {
System.out.printf("x");
}
nBeifen = nBeifen / prime;
System.out.printf("%d", prime);
count++;
} else {
prime++;
prime = nextPrime(prime);// 下一個素數
}
}

System.out.printf("\n");
}
}

public static boolean prime(int n) {// 判斷是否素數
boolean isPrime = true;// 預設是素數

if (n == 1 || (n % 2 == 0 && n != 2)) {// 判斷1或者除了2的偶數
isPrime = false;
} else if (n == 2) {// 判斷2
isPrime = true;
} else {// 判斷其他
for (int i = 3; i < Math.sqrt(n); i += 2) {
if (n % i == 0) {
isPrime = false;
break;
}
}
}

return isPrime;
}

public static int nextPrime(int n) {// 下一個素數
while (true) {
if (prime(n)) {
return n;
} else {
n++;
}
}
}
}


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 一、莊贏會員管理系統是個什麼樣的系統? 莊贏會員管理系統主是幫助莊家管理會員。 二、現在莊家運營的模式是什麼? 莊家運營網站的程式和資料庫都在上家的伺服器上,程式和資料庫都是由上家進行維護的,莊家只有一個管理後臺,說白了玩家的所有數據包括網站的所有數據都不在莊家自己手裡,莊家自然是不放心了。 三、目 ...
  • 最近的項目在做socket通信報文解析的時候,用到了結構體與位元組數組的轉換;由於客戶端採用C++開發,服務端採用C#開發,所以雙方必須保證各自定義結構體成員類型和長度一致才能保證報文解析的正確性,這一點非常重要。 首先是結構體定義,一些基本的數據類型,C#與C++都是可以匹配的: 一、首先是 [St ...
  • 1 package kk; public class circle { private double radius; // 構造方法,有參構造 public circle(double radius) { this.radius = radius; } //方法的重載,參數不同 ... ...
  • 這裡有dao、service和Servlet三個地方 通過配過文件xml生成對象,並註入對象類型的屬性,降低耦合 dao文件代碼: service文件代碼:(提供setter方法,xml文件可通過這種方法配置) xml文件代碼: Servlet類文件可以繞開dao的文件,直接使用service即可 ...
  • 有時候,打開別人的開發環境中導過來的項目的JSP文件,會出現“Failed to create the part's controls”的錯誤! 解決的方法有: 方法1:關閉myeclipse的jsp設計視圖,window -> perferences -> General -> editors - ...
  • ecs_account_log:賬戶變動日誌(註冊用戶充值、支付等記錄信息) ecs_ad:廣告表 ecs_admin_action:管理員許可權表(定義了128項功能操作) ecs_admin_log:管理員操作日誌表 ecs_admin_message:管理員留言表 ecs_admin_user: ...
  • 今天學習的內容我覺得還是很有意思的,當然我主要也是從這個網址學的:http://bbs.fishc.com/thread-46069-1-1.html,大家可以直接看這個網址進行學習,當然也可以看看我的總結,嘻嘻^-^ 這裡就不講解安裝的方法了吧,也比較簡單,大家可以看剛剛那個網址或者百度安裝。 1 ...
  • 配套視頻: static作用 static特點 static記憶體分析 一、引出static 在我們生活當中 , 有些事物不屬於某一個對象,而是屬於整個事物的類型 比如:全世界人口的總數 人的毀滅行為:毀滅的行為應該屬於人類, 不應該屬於某一個人 狀態和行為應該 有 對象 和 類 之分 有的狀態和行為 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...