Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/11: Рейтинг темы: голосов - 11, средняя оценка - 5.00
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66

Наименьшая разность

18.10.2017, 16:34. Показов 2214. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть программа для определения наибольшей разности между двумя соседними числами:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
var n, n1, n2, d, dm, i: integer;
begin
  repeat
    write('n > 1; n = ');
    readln(n)
  until n > 1;
  writeln('Enter ', n, ' numbers:');
  dm := 0;
  for i := 1 to n do
    begin
      write(i, '? ');
      readln(n2);
      if i = 1 then n1 := n2;
      d := abs(n1 - n2);
      if d > dm then dm := d;
      n1 := n2
    end;
  write('Max difference: ', dm);
  readln
end.
А как сделать так, чтобы она выводила ещё и наименьшую разность?
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
18.10.2017, 16:34
Ответы с готовыми решениями:

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

Наименьшая стоимость карточки.
Язык Free Pascal GNU C GNU C++ Delphi Java Python 3.1 Min время, сек 0.002 0.008 0.002 0.003 0.139 0.08 Среднее время,...

Наименьшая система счисления
Помогите с задачей Известно, что основанием позиционной системы счисления называют количество различных символов, используемых для...

14
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 16:39
Добавлено через 2 минуты
Pascal
1
2
3
4
begin
  var A := ReadArrInteger(ReadlnInteger('N:')).Pairwise().Select(x -> x[0] - x[1]);
  WritelnFormat('Наименьшая разность равна {0}, в то время как наибольшая {1}.', A.Min(), A.Max());
end.
0
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 16:42  [ТС]
Volobuev Ilya, а проще можно как то? Желательно, чтобы это было связано с кодом выше
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 16:43
1. Разбиваю на пары последовательность. Например из 1, 2, 3 получаю [1, 2], [2, 3].
2. Преобразую в разности. Из [1, 2], [2, 3] получаю -1, -1.
3. Выбираю минимум и максимум разностей.
0
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 16:45  [ТС]
Volobuev Ilya, а если нужно взять значение по модулю?
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 16:46
Лучший ответ Сообщение было отмечено Сергей2000 как решение

Решение

- За разбитие на пары отвечает метод Pairwise().
- За нахождение разностей - Select(x -> x[0] - x[1]).
- За поиск минимума/максимума - Min() и Max() соответственно.

Добавлено через 38 секунд
Если нужен модуль:
Pascal
1
2
3
4
begin
  var A := ReadArrInteger(ReadlnInteger('N:')).Pairwise().Select(x -> Abs(x[0] - x[1]));
  WritelnFormat('Наименьшая разность по модулю равна {0}, в то время как наибольшая по модулю {1}.', A.Min(), A.Max());
end.
1
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 16:52  [ТС]
Volobuev Ilya, Undefined name reference 'Pairwise'
Что это и как можно исправить?
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 17:02
У вас какая версия PABC.Net?

Добавлено через 23 секунды
У меня 3.3. На 3.0 также работает все хорошо.

Добавлено через 18 секунд
Если версия 2.2, могут быть проблемы.

Добавлено через 39 секунд
Цитата Сообщение от Сергей2000 Посмотреть сообщение
Undefined name reference 'Pairwise'
Это значит, что он не знает что такое Pairwise().
0
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 17:04  [ТС]
Volobuev Ilya, 3.1
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 17:07
У меня не было никогда 3.1, ничего относительно нее сказать не могу, но:
Pascal
1
2
3
4
begin
  var A := ReadArrInteger(ReadlnInteger('N:')).Pairwise().Select(x -> Abs(x[0] - x[1]));
  WritelnFormat('Наименьшая разность равна {0}, в то время как наибольшая {1}.', A.Min(), A.Max());
end.
у меня компилируется и работает без ошибок.

Добавлено через 1 минуту
Попробуйте на 3.3.
0
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 17:11  [ТС]
Volobuev Ilya, да мне нужно именно на 3.1
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 17:24
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
begin
  var A := ReadArrInteger(ReadlnInteger('N:'));
  var Min := integer.MaxValue;
  var Max := 0;
  
  for var i := 0 to A.Length - 2 do
  begin
    var d := Abs(A[i] - A[i + 1]);
    if d < Min then Min := d;
    if d > Max then Max := d;
  end;
  
  WritelnFormat('Наименьшая разность равна {0}, в то время как наибольшая {1}.', Min, Max);
end.
Добавлено через 41 секунду
Так работает на 3.1?

Добавлено через 2 минуты
P. S. MaxInt эквивалентно integer.MaxValue.
0
0 / 0 / 0
Регистрация: 16.10.2013
Сообщений: 66
18.10.2017, 17:29  [ТС]
Volobuev Ilya, всё замечательно, но есть такой баг: если число в первойй строке 1, а во второй ноль, то выдаётся 2147483647, 0. Это можно исправить?
0
Alvin Seville
 Аватар для Соколиный глаз
343 / 273 / 134
Регистрация: 25.07.2014
Сообщений: 4,537
Записей в блоге: 22
18.10.2017, 17:34
Pascal
1
2
3
4
  if A.Length > 1 then
    WritelnFormat('Наименьшая разность равна {0}, в то время как наибольшая {1}.', Min, Max)
  else
    Writeln('Невозможно найти разности: в массиве присутствует лишь один элемент.');
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33399 / 21509 / 8236
Регистрация: 22.10.2011
Сообщений: 36,907
Записей в блоге: 12
18.10.2017, 17:50
Цитата Сообщение от Volobuev Ilya Посмотреть сообщение
- За разбитие на пары отвечает метод Pairwise().
- За нахождение разностей - Select(x -> x[0] - x[1]).
Вместо связки Pairwise + Select можно использовать либо вторую перегрузку Pairwise, которая позволяет сразу заменить пару (произвести с ней любое действие), либо Incremental, который прямо вот для этого и предназначен. Итого:
Pascal
1
2
3
4
5
 var v := A.Incremental((a, b) -> Abs(a - b)).ToArray.Println;
  if A.Length > 1 then
    WritelnFormat('Наименьшая разность равна {0}, в то время как наибольшая {1}.', v.Min, v.Max)
  else 
    Writeln('Массив из одного элемента');
(это опять же для версии 3.3)
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
18.10.2017, 17:50
Помогаю со студенческими работами здесь

Наименьшая продолжительность фильма
Здряв народ может кто подскажет хоть в каком направлении двигаться есть код он работает за исключением одной маленькой поправочки ...

Наибольшая и наименьшая сумма элементов
Сгенерировать две матрицы и поменять местами строки с наибольшей и наименьшей суммой элементов

Наименьшая сумма строки в матрице А
Для получения результата составить функцию, исходными данными которой являются два массива x1,x2,...,xn u y1,y2.(один из них) или матрица А...

Напечатать ту из матриц, норма которой наименьшая
:help:вот такая вот задачка...поможете?

Выведите на печать ту из матриц, норма которой наименьшая
Даны три квадратных матрицы А,В,С n-го порядка. Выведите на печать ту из них, сумма которой наименьшая.(Норма-максимум из абсолютных...


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

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
Программный отбор значений справочника
Maks 21.03.2026
Установка программного отбора значений справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит предопределенное значение перечислений. Процедура. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru