ต่อไปนี้เป็นโค้ด Java เพื่อค้นหาตัวประกอบเฉพาะที่ใหญ่ที่สุดของตัวเลข -
ตัวอย่าง
import java.io.*;
import java.util.*;
public class Demo{
static long maxPrimeFactors( long val){
long max_prime = -1;
while (val % 2 == 0) {
max_prime = 2;
val >>= 1;
}
for (int i = 3; i <= Math.sqrt(val); i += 2){
while (val % i == 0){
max_prime = i;
val = val / i;
}
}
if (val > 2)
max_prime = val;
return max_prime;
}
public static void main(String[] args){
int val = 148592;
System.out.println("The largest prime factor of 148592 is ");
System.out.println(maxPrimeFactors(val));
val = 890654;
System.out.println("The largest prime factor of 890654 is ");
System.out.println(maxPrimeFactors(val));
}
} ผลลัพธ์
The largest prime factor of 148592 is 251 The largest prime factor of 890654 is 4591
คลาสชื่อ Demo มีฟังก์ชันสแตติกที่แสดงค่า และกำหนดเงื่อนไข 'while' ซึ่งจะตรวจสอบว่าโมดูลัสค่า 2 เป็น 0 หรือไม่ หากเป็น 0 ตัวแปร (max_prime) จะได้รับการกำหนดค่าเป็น 2 มิฉะนั้น บิตที่ถูกต้องจะเปลี่ยน 1 อีกครั้ง วนซ้ำ 'for' ซ้ำเหนือองค์ประกอบจาก 3 เป็นรากที่สองของค่า และเพิ่มขึ้น 2 หลังจากการวนซ้ำทุกครั้ง
ตอนนี้ วนรอบ 'while' จะตรวจสอบว่าตัววนโมดูลัสของค่าเป็น 0 หรือไม่ ถ้าใช่ ตัวแปร (max_prime) จะได้รับการกำหนดค่าที่กำลังมีการวนซ้ำ ค่าจะถูกหารด้วยค่าที่วนซ้ำ หากค่านี้มากกว่า 2 ค่านี้ (max_prime) จะถูกกำหนดให้กับตัวแปรชื่อ max_prime นี้จะถูกส่งกลับ ในฟังก์ชันหลัก ค่าจำนวนเต็มถูกกำหนดและหาตัวประกอบเฉพาะที่ใหญ่ที่สุดโดยการเรียกใช้ฟังก์ชันด้วยอาร์กิวเมนต์เฉพาะ