Ebben a részben megtanuljuk mi az a kémszám és alkotni is Java programok ellenőrizni, hogy a megadott szám az Kém vagy nem. A kémszám program gyakran megkérdezik Jáva kódolási teszt.
Kémszám
A pozitív egész számot kémszámnak nevezzük, ha a összeg és termék számjegyei egyenlők. Más szavakkal, azt a számot, amelynek minden számjegyének összege és szorzata egyenlő, a-nak nevezzük kémszám .
Példa a kémszámra
Vegyük az 1124-es számot, és nézzük meg, hogy a szám kém-e vagy sem. Először is felosztjuk számjegyekre (1, 1, 2, 4). Ezután keresse meg az összes számjegy összegét és szorzatát.
Összeg =1+1+2+4= 8
összefűző karakterláncok
Termék =1*1*2*4= 8
Megfigyeljük, hogy a számjegyek összege és szorzata egyenlő. Ennélfogva, 1124 egy kémszám.
java tömb
Hasonlóképpen ellenőrizhetünk más számokat is. Néhány más kémszám a 22, 123, 132 stb.
Lépések a kémszám megtalálásához
- Olvasson vagy inicializáljon egy számot ( n ), amelyet ellenőrizni szeretne.
- Két változó deklarálása összeg és termék számjegyek összegének és szorzatának tárolásához. Az összeget ezzel inicializálja 0 és termékkel 1 .
- Találd meg utolsó az adott szám számjegye (n%10) a modulo operátor segítségével.
- Ismételje meg a lépéseket 3-tól 6-ig amíg a megadott szám (n) 0 nem lesz.
- Ha az összeg és a szorzat változó értéke azonos, akkor a megadott szám (n) a kém szám , különben nem kémszám.
Valósítsuk meg a fenti lépéseket egy Java programban.
Kémszám Java program
SpyNumberExample1.java
css listák
import java.util.Scanner; public class SpyNumberExample1 { public static void main(String args[]) { int num, product=1, sum=0, lastdigit; // create object of scanner Scanner sc = new Scanner(System.in); System.out.print('Enter the number to check: ' ); //reads an integer from the user and stores it in the variable num num=sc.nextInt(); //executes untill the condition becomes false while(num>0) { //finds the last digit of the number lastdigit=num%10; //adds last digit to the variable sum sum=sum+lastdigit; //calculates the product product=product*lastdigit; //removes the last digit from the given number num=num/10; } //compares the sum and product if(sum==product) //prints if the above condition returns true System.out.println('The given number is a spy number.'); else //prints if the above condition returns false System.out.println('The given number is not a spy number.'); } }
1. kimenet:
Enter the number to check: 123 The given number is a spy number.
2. kimenet:
Enter the number to check: 456 The given number is a not spy number.
SpyNumberExample2.java
import java.util.Scanner; public class SpyNumberExample2 { //method to check the Spy number private static boolean isSpyNumber(int number) { int lastDigit = 0; int sum = 0; int product = 1; //executes until the condition returns true while(number != 0) { //determines the last digit of the given number lastDigit = number % 10; //adds the last digit to the variable sum sum = sum + lastDigit; //multiply last digit with product product = product * lastDigit; //removes the last digit of the given number number = number / 10; } //compares the variable sum with product and returns the result accordingly if(sum == product) return true; return false; } //driver code public static void main(String args[]) { int lowerRange = 0, upperRange = 0; Scanner sc = new Scanner(System.in); System.out.print('Enter the lower range: '); //reads lower range lowerRange = sc.nextInt(); System.out.print('Enter upper range: '); //reads the upper range upperRange = sc.nextInt(); System.out.println('The Spy numbers between '+ lowerRange + ' to '+ upperRange+' are: '); for(int i=lowerRange; i<=upperrange; i++) { calling user-defined function that checks if the given number is spy or not if(isspynumber(i)) prints all numbers system.out.print(i +' '); } < pre> <p> <strong>Output:</strong> </p> <pre> Enter the lower range: 1 Enter upper range: 10000 The Spy numbers between 1 to 10000 are: 1 2 3 4 5 6 7 8 9 22 123 132 213 231 312 321 1124 1142 1214 1241 1412 1421 2114 2141 2411 4112 4121 4211 </pre> <hr></=upperrange;>
=upperrange;>