Выдать все простые числа в диапазоне от 2 до N, заполнив массив числами от 2 до N - PascalABC.NET
Формулировка задачи:
Вводится число N(N<=100). Выдать все простые числа в диапазоне от 2 до N, заполнив массив числами от 2 до N, а затем обнулить все кратные 2, затем все кратные 3 и т.д. Необнулённые и будут простыми числами.
Решение задачи: «Выдать все простые числа в диапазоне от 2 до N, заполнив массив числами от 2 до N»
textual
Листинг программы
var a:array [2..100] of integer; n, i, f: integer; begin repeat write('Введите натуральное число от 2 до 100 n='); readln(n); until n in [2..100]; for i := 2 to n do a[i] := i; for f := 2 to trunc(sqrt(n)) do//все возможные делители for i := f+1 to n do//проверяем то что впереди(эти числа типа 2,3 не трогаем) if (a[i] mod f = 0) then a[i] := 0; for i := 2 to n do if a[i] <> 0 then write(a[i]:4); end.
Объяснение кода листинга программы
- Объявляется массив a размером от 2 до 100 для хранения чисел
- Вводятся три переменные n, i, f типа integer
- В цикле repeat, который повторяется до тех пор, пока пользователь не введет число в диапазоне от 2 до 100, происходит следующее: a) Запрашивается у пользователя ввод числа n b) Число n сохраняется в переменную n
- В цикле for, который начинается с i=2 и идет до n, каждое число от 2 до n присваивается соответствующему индексу массива a
- В цикле for, который начинается с f=2 и идет до корня из n (trunc(sqrt(n))), проверяются все возможные делители числа n a) Цикл for начинается с i=f+1 и идет до n, чтобы не трогать числа типа 2,3 b) Если остаток от деления a[i] на f равен 0, то a[i] присваивается 0, т.е. это число является составным
- В цикле for, который начинается с i=2 и идет до n, проверяется каждое число в массиве a a) Если a[i] не равно 0, то это число является простым, и его значение выводится на экран с шагом 4 (например, 4, 8, 12, 16)
- Код завершается
ИИ поможет Вам:
- решить любую задачу по программированию
- объяснить код
- расставить комментарии в коде
- и т.д