Выдать все простые числа в диапазоне от 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)
- Код завершается
ИИ поможет Вам:
- решить любую задачу по программированию
- объяснить код
- расставить комментарии в коде
- и т.д