кодесурса
«C

Упражнения C: генерация простых чисел мерсенна в диапазоне чисел

script1adsense2code
script1adsense3code

Числа C: Упражнение 33 с решением

Напишите программу на C для генерации простых чисел мерсенна в диапазоне чисел.

Тестовые данные
Введите верхний предел [диапазон от 1 до верхнего предела]: 1000

Пример решения :

Код C:

# include <stdio.h>
# include <stdlib.h>
# include <stdbool.h>
# include <math.h>
void GenAllPrim(int n1, bool prarr1[])
{
    for (int i=0; i<=n1; i++)
        prarr1[i] = true;
 
    for (int p=2; p*p<=n1; p++)
    {
        if (prarr1[p] == true)
        {
            for (int i=p*2; i<=n1; i += p)
                prarr1[i] = false;
        }
    }
}
void chkMerPrime(int nm)
{
    bool prarr1[nm+1];
    GenAllPrim(nm,prarr1);
    for (int j=2; ((1<<j)-1) <= nm; j++)
    {
        long long num = (1<<j) - 1;
        if (prarr1[num])
            printf(" %lli ",num);
    }
}
int main()
{
    int n ;
	printf("\n\n Generate Mersenne primes within a range of numbers:\n");
	printf("--------------------------------------------------------\n");
	printf(" Input a upper limit [range from 1 to upper limit]: ");
    scanf("%d",&n);	
    printf(" Mersenne prime numbers are: \n");
    chkMerPrime(n);
    printf("\n\n");
}

Пример вывода:

 Введите верхний предел [диапазон от 1 до верхнего предела]: 1000                                                      
 Простые числа Мерсенна:                                                                                  
 3 7 31 127 

Блок - схема:

«Блок-схема:

Редактор кода программирования C:

Внесите свой код и комментарии через Disqus.

Предыдущий: Напишите программу на C, чтобы проверить, является ли число числом Мерсенна или нет.
Далее: Напишите программу на C, чтобы найти нарциссические десятичные числа в определенном диапазоне.

Каков уровень сложности этого упражнения?

Новый контент: Composer: менеджер зависимостей для PHP , R программирования


script1adsense4code
script1adsense5code
disqus2code
script1adsense6code
script1adsense7code
script1adsense8code
buysellads2code