Advertisement
believe_me

Untitled

Oct 27th, 2021
244
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
Java 3.34 KB | None | 0 0
  1. import java.util.Scanner;
  2.  
  3. public class lab22 {
  4.  
  5.     public static int inputNumber() {
  6.         Scanner scanner = new Scanner(System.in);
  7.         final int MAX_NUMBER = 100000000;
  8.         boolean isIncorrect;
  9.         int number;
  10.         number = 0;
  11.         System.out.printf("Введите натуральное число не большее, чем %,d \n", MAX_NUMBER);
  12.         do {
  13.             isIncorrect = false;
  14.             try {
  15.                 number = Integer.parseInt(scanner.nextLine());
  16.             } catch (Exception ex) {
  17.                 System.out.printf("Нужно ввести натуральное число, не большее, чем %,d \n", MAX_NUMBER);
  18.                 isIncorrect = true;
  19.             }
  20.             if (!isIncorrect && (number < 1 || number > MAX_NUMBER)) {
  21.                 System.out.printf("Число должно быть больше 0 и не больше чем %,d \n", MAX_NUMBER);
  22.                 isIncorrect = true;
  23.             }
  24.         } while (isIncorrect);
  25.         scanner.close();
  26.         return number;
  27.     }
  28.  
  29.  
  30.     public static int searchMaxCountOfRepeats(int number) {
  31.         int maxCountOfRepeats, counter, previous, singleNumber, newNumber;
  32.         maxCountOfRepeats = 0;
  33.         while (number > 0) {
  34.             counter = 1;
  35.             singleNumber = number % 10;
  36.             previous = singleNumber;
  37.             number = number / 10;
  38.             newNumber = number;
  39.             while (newNumber > 0) {
  40.                 singleNumber = newNumber % 10;
  41.                 newNumber = newNumber / 10;
  42.                 if (previous == singleNumber)
  43.                     counter++;
  44.                 if (counter > maxCountOfRepeats)
  45.                     maxCountOfRepeats = counter;
  46.             }
  47.         }
  48.         return maxCountOfRepeats;
  49.     }
  50.  
  51.     public static void allSolutions(int number, int maxCountOfRepeats) {
  52.         int counter, previous, singleNumber, newNumber;
  53.         while (number > 0) {
  54.             counter = 1;
  55.             singleNumber = number % 10;
  56.             previous = singleNumber;
  57.             number = number / 10;
  58.             newNumber = number;
  59.             while (newNumber > 0) {
  60.                 singleNumber = newNumber % 10;
  61.                 newNumber = newNumber / 10;
  62.                 if (previous == singleNumber) {
  63.                     counter++;
  64.                     if (counter == maxCountOfRepeats)
  65.                         System.out.print(previous + " ");
  66.                 }
  67.             }
  68.         }
  69.     }
  70.  
  71.     public static void printResult(int number, int maxCountOfRepeats) {
  72.         System.out.println("Самая часто встречающаяся цифра/цифры: ");
  73.         if (maxCountOfRepeats == 1)
  74.             System.out.println("Такой цифры нет.");
  75.         if (maxCountOfRepeats == 0)
  76.             System.out.println(number);
  77.         else
  78.             allSolutions(number, maxCountOfRepeats);
  79.     }
  80.  
  81.  
  82.     public static void main(String[] args) {
  83.         int maxCountOfRepeats, number;
  84.         System.out.println("Программа позволяет узнать, какая цифра в данном числе встречается чаще всего.");
  85.         number = inputNumber();
  86.         maxCountOfRepeats = searchMaxCountOfRepeats(number);
  87.         printResult(number, maxCountOfRepeats);
  88.     }
  89. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement