0 / 0 / 0
Регистрация: 22.06.2020
Сообщений: 8

Задача на вывод простых множителей из определенного натурального числа

22.06.2020, 22:29. Показов 2359. Ответов 8
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
сама задача

Составить программу, которая запрашивает натуральное число n и выводит
все его простые множители (т.е. произведение выведенных простых чисел должно
равняться n). Предлагается реализовать следующий алгоритм:
1. Положить текущее значение делителя d равным 2;
2. Если n = 1, перейти к 5;
3. Если n делится на d без остатка, за новое значение n принять частное от
деления n на d и вывести значение d (d – делитель n). Перейти к 2;
4. Если d2 превышает n, принять значение n в качестве d, в противном случае
увеличить значение d на единицу. Перейти к 3;
5. Завершить работу алгоритма.

дан и алгоритм решения. есть вариант решения, но он не работает - выводит бесконечное число 0.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  read(n);
  repeat 
  begin
  if n div d=0 then 
  begin
  n2:=n div d; 
  write(n2);
  end;
  if n2>n then begin
  d:=n2;
  end 
  else  d:=d+1;
  end
  until n=1;
  
write();
end.
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
22.06.2020, 22:29
Ответы с готовыми решениями:

Создать функцию,формирующую массив простых множителей заданного натурального числа
Создать функцию,формирующую массив простых множителей заданного натурального числа

Вывод на экран простых делителей натурального числа
Здравствуйте, помогите пожалуйста с задачей Составьте программу вывода на экран дисплея простых делителей натурального числа N

Сформировать массив простых множителей заданного числа
Доброго времени суток. Помогите решить 2 задачки: 1)Сформировать массив простых множителей заданного числа 2)Коэффициенты многочлена...

8
 Аватар для JuriiMW
5096 / 2662 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
23.06.2020, 04:51
Дословно по алгоитму:
Pascal
1
2
3
4
5
6
7
8
9
label l2,l3,l5;
begin
  var n:=ReadLnInteger;
  var d:=2;
  l2:if n=1 then goto l5;
  l3:if n mod d=0 then begin n:=n div d;d.Print;goto l2;end;
  if d > n then n:=d else d += 1; goto l3;
  l5:Println;
end.
1
0 / 0 / 0
Регистрация: 22.06.2020
Сообщений: 8
23.06.2020, 19:39  [ТС]
спасибо, что показал, как это должно работать. но мне кажется, что в условии какая-то ошибка - нужно же выводить n- числа, которые мы хотим получить, а не постоянную d

а если так?
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
begin
var n:=ReadlnInteger;
var d:=2;
var s:boolean:=true;
while s=true do begin
if n=1 then 
begin break; end
else if n mod d=0 then begin
n:= n div d;  
n.Print; continue; end
else if d>n then
begin  n:=d; end
 else d+=1;
end;
end.
0
 Аватар для JuriiMW
5096 / 2662 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
24.06.2020, 04:14
Цитата Сообщение от cinnallow Посмотреть сообщение
выводит
все его простые множители
Даём вашей программе 360
Получаем результат: 180 90 45 15 5 1
Гм! Э-э-э… А где здесь простые числа? Только одно.
0
0 / 0 / 0
Регистрация: 22.06.2020
Сообщений: 8
24.06.2020, 10:00  [ТС]
хм.
поняла, упустила каким образом меняется d. (третий блок условий)
Pascal
1
else d+=1;
и поэтому посчитала, что числа, выводимые d.print будут одинаковыми и бесполезными для решения.
нужно было сначала проверить

еще раз спасибо за помощь
0
 Аватар для JuriiMW
5096 / 2662 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
24.06.2020, 10:12
Лучший ответ Сообщение было отмечено cinnallow как решение

Решение

Вообще, без goto, брейков и континьюмов правильней будет так:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
begin
  var n:=ReadLnInteger;
  while n.IsEven do
    begin
      2.Print;
      n := n div 2;
    end;
  var d := 3;
  while n >= d do begin
    if n mod d = 0 then
      begin
        d.Print;
        n := n div d;
      end
    else
      d += 2;
  end;
end.
1
0 / 0 / 0
Регистрация: 22.06.2020
Сообщений: 8
24.06.2020, 18:28  [ТС]
Pascal
1
n.IsEven
типа функции odd()?
0
 Аватар для JuriiMW
5096 / 2662 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
24.06.2020, 18:29
Неа!
Это типа метода.
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
24.06.2020, 20:13
Pascal
1
2
3
4
uses School;
begin
  Factorize(ReadInteger).Print
end.
вся программа
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
24.06.2020, 20:13
Помогаю со студенческими работами здесь

Выбирать числа, которые являются произведением простых множителей
Рассматриваются числа вида N2 - 1, где N - натуральное число. Из них выбираются те числа, которые являются произведением К различных...

Разложение числа на заданное количество взаимно простых множителей
разложить заданное число(k) на заданное кол-во взаимно простых множителей(n) (delphi,pascal)! пожайлуста очень надо , у меня ничего не...

Выбираются те числа,которые являются произведением k различных простых множителей , k<7
n-натуральное число, выбираются те числа,которые являются произведением k различных простых множителей,k&lt;7.Найти первых таких,s&lt;15/ ...

Найти количество различных простых множителей в разложении числа на простые множители.
1. Составить программу, которая находит количество различных простых множителей в разложении числа на простые множители.

Нужно найти числа которые являются произведением K различных простых множителей , k<7
Помогите пожалуйста решить задачу:Нужно найти числа которые являются произведением K различных простых множителей , k&lt;7 .Или хотя бы...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru