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

Список, найти значение по формуле. Ошибка деления на нуль

12.06.2014, 12:57. Показов 624. Ответов 1
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте, прошу помощи в обнаружении ошибочки! Не могу найти деление на нуль! =( Постановка задания закомментирована в коде, представленном ниже:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
{Программа решает следующую задачу:
Дан список из n целых неотрицательных чисел a1,a2,...,a n.
Найти: (a1+a2)div a n  +  (a2+a3)div a n-1  + ... +  (a n-1+a n)div a1}
 
program Teach;
 
  type dmas = ^rmas;
       rmas = record
         n    :integer;
         next :dmas;
         prev :dmas;
       end;
 
  var p1,pt,p2, pfirst, plast :dmas;
      e: integer;
      k: char;
      f: boolean;
 
{Создание массива}
{====================}
      procedure crmas;
          var i:integer;
        begin
          writeln;
          e:=random(20);
 
          for i:=1 to e do
            begin
              new(p2);
              p2^.n:=random(100)+1;
              p2^.next:=p1^.next;
              p2^.prev:=p1^.next^.prev;
              p1^.next^.prev:=p2;
              p1^.next:=p2;
            end;
        end;
{====================}
{Вывод массива}
{====================}
      procedure printlprya;      //прямой
        begin
          writeln;
          p1:=pfirst^.next;
          while p1<>pfirst do
             begin
              write(p1^.n:4);
              p1:=p1^.next;
             end;
          writeln;
        end;
{====================}
      procedure printlobra;      //обратный
        begin
          writeln;
          p2:=p1^.prev;
          while p2<>p1 do
            begin
              write(p2^.n:4);
              p2:=p2^.prev;
            end;
          writeln;
        end;
{====================}
{Условная сумма}
{====================}
       function usum: integer;      //обратный
       var ts,s:integer;
        begin
          ts:=0;
          p1:=pfirst^.next;
          p2:=p1^.prev;
          while (p1<>pfirst) do
             begin
              s:=p1^.n;
              p1:=p1^.next;
              s:=s+p1^.n;
              p1:=p1^.next;
 
              ts:=ts+(s div p2^.n);
              p2:=p2^.prev;
             end;
          usum:=ts;
        end;
{====================}
 
 
begin
       randomize;
       f:=true;
       new(p1);
       p1^.next:=p1;
       p1^.prev:=p1;
       pfirst:=p1;
 
       crmas;
       printlprya;
 
       writeln('Условная сумма:',usum:6);
       readln;
end.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
12.06.2014, 12:57
Ответы с готовыми решениями:

Ошибка при делении нуль на нуль
Всем привет! Имеется функция которая вычисляет математическое уравнение введённое в поле Edit. Всё нормально работет. Если производится...

Проверка деления на нуль
Написал программу, но не до конца нужно сделать проверку деления на нуль #include &lt;QCoreApplication&gt; #include &lt;iostream&gt; ...

Проверка деления на нуль
Как проверить в этом коде условие?? Так чтоб было сообщения деления на нуль?? #include&lt;iostream&gt; #include&lt;stdio.h&gt;...

1
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33421 / 21527 / 8240
Регистрация: 22.10.2011
Сообщений: 36,935
Записей в блоге: 12
13.06.2014, 14:43
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
       function usum: integer;      //обратный
       var ts,s:integer;
        begin
          ts:=0;
          p1:=pfirst^.next;
          p2:=p1^.prev^.prev; // <--- Раз
          while (p1<>pfirst) do
             begin
              s:=p1^.n;
              p1:=p1^.next;
              s:=s+p1^.n;
              // p1:=p1^.next; // <--- Два
               
              ts:=ts+(s div p2^.n);
              p2:=p2^.prev;
             end;
          usum:=ts;
        end;
, ошибка исчезает...
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.06.2014, 14:43
Помогаю со студенческими работами здесь

Попытка деления на нуль
&quot;Попытка деления на нуль&quot;. И всё вроде бы ясно, вот только как сохранить формулу и при этом избежать ошибки?:scratch: for (int j = 0; j...

Вывод об ошибке деления на нуль
Как сделать так чтобы выводилось сообщение в правой области экрана при делении на нуль. uses FormsABC; function...

Бесконечность и попытка деления на нуль
Если оба числа целочисленные, то при делении на нуль выходит &quot;попытка деления на нуль&quot;. А если хотя бы один из членов - число с...

Обработать исключительную ситуацию деления на нуль
Помогите написать программу с обработкой исключительной ситуации деления на нуль, пожалуйста. Вот тут что то есть, или это не то? Я что то...

Найти произведение положительных чисел столбца, последний элемент которого нуль.Есть ошибка
Найти произведение положительных чисел столбца, последний элемент которого нуль.Есть ошибка... #include &lt;stdio.h&gt; #include...


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

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

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
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