Проверка на мультипростое число - C (СИ)
Формулировка задачи:
Доброго времени суток!
Попыталась найти что-то подобное на форуме - не нашла (очень сложно сформулировать поисковый запрос по проблеме).
Сама уже вторые сутки ломаю голову (понимаю, что не срок. Однако препод бьет копытом, брызжет слюной и ругается).
Также, я еще создала функцию, которая считает количество цифр в введенном числе.
Она используется в дальнейшем для разделения числа.
Если мы хотим отделить первое число, то
num1 = num\10^(n-1) - первая цифра ("7" в примере)
num2 = num%10^(n-1) - все остальное("523" в примере)
на входе функция is_multi_prime в первую очередь проверяет целое ли введенное число вообще (если нет, значит сразу же 0), потом разделяет его по первой цифре. Если первая цифра - прайм, то функция рекурсивно вызывается опять с параметром num2.
В принципе, у меня получилось добиться того, что 7523 - мультипрайм. И даже пара самых простых непраймов и не мультипраймов давали правильные значения.
Но как только числа стали четырехзначными, все посыпалось.
Более того, я ни малейшего понятия не имею, как запихнуть проверку следующего разделения, если первое не прошло (например, 2311 - простое число. два - не простое, но 23 и 11 - простые, 2 и 3, 1 и 1 - простые). Ну в смысле, я могу русским/английским языком описать алгоритм, но не могу его описать на Си.
Задача
Требуется написать программу, которое будет выводить, является ли введенное с клавиатуры число "мультипростым". Под "мультипростым" числом понимаетсяпростое
число, которое либо состоит из одной цифры (3, 5...), либо которое можно разбить на простые и/или мультипростые составляющие. Под разбивкой понимается отделение скольких бы то ни былолевых
цифр числа от остальных. Сложно объяснить, проще показать на примере: Число 7523. Само по себе число 7523 простое. Возможны три варианта разбивки: 7 523 75 23 752 3 7 - простое число. 523 - тоже просто и может быть разбито на 5 23 или 52 3. Пять - простое число. Двадцать три - тоже, причем, два и три - тоже простые. Т.е. возможен как минимум один вариант, что это число "мультипростое" => тру. Программа должнаобязательно
содержать две функции: нерекурсивнуюint is_prime(int num)
(которая возвращает 1, если число простое, и 0 - в обратном случае)и рекурсивную int is_multi_prime(int num)
(которая возвращает 1, если число "мультипростое", и 0 - в обратном случае). Если кому нужно, я могу выслать оригинал задания (на английском языке). Ко всему прочему, есть ограничения, установленные преподавателем: "вы должны использовать только то, что мы уже прошли на занятиях. и ни в коем случае то, что мы еще не прошли". Так что массивы, строки, классы - использовать нельзя. По сути, можно использовать только функции и рекурсию.Мои соображения по поводу решения.
(это можно не читать, если само задание понятно и решение его очевидно) я, честно говоря, уже запуталась в своих размышлениях. И получившийся говнокод кидать не буду (ибо стыдно). В любом случае, is_prime - это просто.{
int i;
for( i=2; i*i<=num; i++)
{
if (num%i ==0)
return 0;
}
return 1;
}З.ы,
Думаю, меня вполне устроит подробный алгоритм на русском/английском, но если будет разобранный код - будет лучше. Также, могу скинуть скетч блок-схемы, конкретно лекции/семинары по курсу и т.п. Спасибо!!Решение задачи: «Проверка на мультипростое число»
textual
Листинг программы
#include <stdio.h>
int is_prime(unsigned n) {
unsigned i;
if ( n < 2 )
return 0;
for ( i = 2; i * i <= n; ++i )
if ( ! ( n % i ) )
return 0;
return 1;
}
unsigned pow_10(unsigned pwr) {
return ( pwr ) ? 10 * pow_10(pwr - 1) : 1;
}
unsigned num_digits(unsigned n) {
return ( n > 9 ) ? 1 + num_digits(n / 10) : 1;
}
int is_multi_prime(unsigned n) {
unsigned div = pow_10(num_digits(n));
if ( n < 10 )
return is_prime(n);
while ( ( div /= 10 ) > 9 )
if ( ! is_prime(n / div) || ! is_prime(n % div) )
return 0;
return 1;
}
#define LIMIT 1000000
int main(void) {
unsigned n;
for ( n = 1; n < LIMIT; ++n )
if ( is_multi_prime(n) )
printf("%u\n", n);
return 0;
}
Объяснение кода листинга программы
- Включаем стандартную библиотеку ввода-вывода
- Определяем функцию is_prime, которая проверяет простое ли число (проверка на делимость без остатка)
- Определяем функцию pow_10, которая вычисляет число 10 в степени (с использованием рекурсии)
- Определяем функцию num_digits, которая вычисляет количество цифр числа (с использованием рекурсии)
- Определяем функцию is_multi_prime, которая проверяет число на мультипростоту (проверка на деление без остатка на все числа от 10 до 999)
- В функции main инициализируем переменную n со значением 1
- В цикле от 1 до LIMIT (предварительно определенного ограничения) вызываем функцию is_multi_prime и выводим результат (если число мультипростое)
- Завершаем программу с возвращаемым значением 0