Форум программистов, компьютерный форум, киберфорум
Pascal (Паскаль)
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/55: Рейтинг темы: голосов - 55, средняя оценка - 4.60
0 / 0 / 0
Регистрация: 10.11.2017
Сообщений: 42

Найти максимальное и минимальное число из максимум 30 без массивов

27.09.2018, 09:26. Показов 11855. Ответов 9
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Программе на вход подается максимум 30 чисел (признак конца последовательности 0). Вывести максимальное и минимальное числа последовательности.
Использовать можно только условный оператор и циклы.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
27.09.2018, 09:26
Ответы с готовыми решениями:

В последовательности случайных чисел найти минимальное и максимальное число в каждой последовательности(без массивов)
Очень нужна помощь! В последовательности случайных чисел найти минимальное и максимальное число в каждой последовательности(без...

Как определить какое число в последовательности встретится раньше?минимальное,или максимальное(без массивов)
namespace ConsoleApplication1 { class Program { static void Main(string args) { int n, x;...

Найти максимальное и минимальное значение двух массивов
Как мне найти максимальное и минимальное значение двух массивов,которые заполнены случайными числами? Могут быть и ситуации,когда эти...

9
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
27.09.2018, 09:53
Pascal
1
2
3
4
5
6
7
8
9
10
11
var min, max, n : Integer;
begin
  Read(n);
  if n = 0 then Halt;
  min := n; max := n;
  repeat
    Read(n);
    if n > max then max := n else if n < min then min := n;
  until n = 0;
  WriteLn(min, ' ', max);
end.
0
Супер-модератор
Эксперт Pascal/DelphiАвтор FAQ
 Аватар для volvo
33395 / 21505 / 8236
Регистрация: 22.10.2011
Сообщений: 36,902
Записей в блоге: 12
27.09.2018, 10:26
Это некорректное решение. Вводим <1, 2, 3, 4, 5, 6, 7, 0> и убеждаемся в этом. Минимум должен быть равен 1, а не 0. 0 - конец последовательности, он к самой последовательности на относится.
0
 Аватар для JuriiMW
5095 / 2661 / 2355
Регистрация: 10.12.2014
Сообщений: 10,060
27.09.2018, 11:10
volvo, сорри…
Нужно изменить:
Pascal
8
    if n <> 0 then if n > max then max := n else if n < min then min := n;
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
27.09.2018, 12:57
JuriiMW,
в подобных случаях предпочитаю видоизменить сам цикл:
Pascal
6
7
8
9
  repeat
    Read(n); if n=0 then Break;
    ...
  until False;
0
Модератор
10431 / 5719 / 3404
Регистрация: 17.08.2012
Сообщений: 17,394
28.09.2018, 01:43
Здесь лучше подойдёт цикл while.
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
var
  min, max, n: integer;
 
begin
  read(n);
  if n <> 0
    then begin
      min := n;
      max := n;
      while n <> 0 do
        begin
          if n > max
            then max := n
            else if n < min
              then min := n;
          read(n)
        end;
      write('min = ', min, ', max = ', max)
    end
    else write('Пустая последовательность')
end.
0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
28.09.2018, 10:17
Cyborg Drone,
позволю себе не согласиться -- ну сами посудите, сколько лишних приседаний пришлось сделать, чтобы он подошел...
Если формирующее условие цикла действие не удается вынести в условие while, приходится его дублировать в теле:
Pascal
1
2
3
4
5
  действие;
  while условие do begin
    ...
    действие;
  end;
вместо
Pascal
1
  while условие_и_действие do ...;
А раз уж пришлось проверку на завершение цикла вносить внутрь его тела, то уж пусть это будет явно -- вот бесконечный цикл, вот условие его завершения. Да, я знаю суть возражений про то, что Break усложняет верифицируемость алгоритма, но в данном случае пользы больше, чем вреда, имхо.
0
Модератор
10431 / 5719 / 3404
Регистрация: 17.08.2012
Сообщений: 17,394
03.10.2018, 21:50
bormant, да нисколько лишних приседаний. С "иными лишними приседаниями", но то же самое:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
var
  min, max, n: integer;
 
begin
  read(n);
  min := n;
  max := n;
  while n <> 0 do
    begin
      if n > max
        then max := n
        else if n < min
          then min := n;
      read(n)
    end;
  if (min <> 0) or (max  <> 0)
    then write('min = ', min, ', max = ', max)
    else write('Пустая последовательность')
end.
Разве в этой "более понятной" версии формирующее условие цикла действие не внесено в условие while? Вообще, while и repeat...break...until true алгоритмически эквивалентны. Я что-то не до конца понимаю? Вообще, ты для меня - пример для подражанья, как бы это не звучало. Ну и, сдаётся мне, надо бы уже давно дополнить алгоритмические языки циклом
Pascal
1
2
3
  while x correct
    {...}
  until y;


Добавлено через 35 минут

Не по теме:

Вообще, я мечтаю об языке, где возможны присваивания при выполнении условий, типа

Pascal
1
if a = b := c + d then
и ещё очень хочется пред- и пост- инкремента и декремента в паскале... В общем, мечтаю об ортогональности, а дури для создания своего паскаля не хватает... Ещё есть куча идей... Но маловато как-то времени и силёнок...

0
Модератор
Эксперт Pascal/DelphiЭксперт NIX
 Аватар для bormant
7816 / 4635 / 2837
Регистрация: 22.11.2013
Сообщений: 13,158
Записей в блоге: 1
04.10.2018, 12:27
Cyborg Drone,
первое возражение (#5) было про
Pascal
1
2
3
  repeat
    if n<>0 then ...;
  until n=0;
vs.
Pascal
1
2
3
4
  repeat
    if n=0 then Break;
    ...
  until False;
второе (#7) про частую ситуацию:
Pascal
1
2
3
4
5
  Read(n);
  while n<>0 do begin
    ...
    Read(n);
  end;
Вот только оно к именно этой теме из-за необходимости отдельно обработать первый элемент (получить начальные значения min и max) действительно не применимо, виноват-с...

Тем не менее, практического значения в этом -- ну ни на грош ;-)
Что пнем об сову, что совой об пень (на 2 начальных сравнения разница):
Pascal
1
2
3
4
5
6
7
8
9
10
11
  Read(n); mx:=n; mn:=n;
  while n<>0 do begin
    if mx<n then mx:=n else if mn<n then mn:=n;
    Read(n);
  end;
 
  Read(n); mx:=n; mn:=n;
  repeat
    Read(n); if n=0 then Break;
    if mx<n then mx:=n else if mn<n then mn:=n;
  until False;
Добавлено через 4 минуты

Не по теме:

А про операцию присваивания, пре- и пост- инкремент/декремент -- есть С, С++, D.
Правда ко всему этому в нагрузку предлагается еще много чего всякого разного ;-) такого, что частенько сам себе скажешь "ну и ладно, ну и обойдусь" ;-)



Добавлено через 18 минут

Не по теме:


Почти желаемое (жаль, только семантически, не по эффективности):

Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
function PreInc(var n: Longint): Longint;
begin
  PreInc:=n; Inc(n);
end;
 
function PostInc(var n: Longint): Longint;
begin
  Inc(n); PostInc:=n;
end;
 
function Let(var n: Longint; const v: Longint): Longint;
begin
  n:=v; Let:=v;
end;

0
Модератор
10431 / 5719 / 3404
Регистрация: 17.08.2012
Сообщений: 17,394
05.10.2018, 09:37
Чтобы сову не мучить, неплохо бы сначала (на этапе компиляции) каким-то боком сделать n "не числом", тогда и ввод n вне цикла не нужен, и вопрос о типе цикла снимается... Но - для целых чисел - это фантастика...

Согласен, эту простенькую задача - как ни крути, всё равно из неё костыль будет торчать.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.10.2018, 09:37
Помогаю со студенческими работами здесь

Найти максимальное и минимальное значение из трёх массивов
Всем доброй ночи. Подскажите, как можно найти максимальное и минимальное значение из нескольких массивов, в моём случае из трёх. ...

Найти минимальное положительное число и максимальное отрицательное число среди заданных
Дано N действительных случайных чисел в диапазоне от -100 до 100. Найти минимальное положительное число и максимальное отрицательное число.

Найти максимальное и минимальное число
Помогите пожалуйста! :) Среди четырех чисел найти максимальное и минимальное, используя функцию нахождения максимума и минимума из двух...

Найти максимальное и минимальное число в массиве
:wall:Помогите : Найти максимальное и минимальное число в масиве; при помощи Этого var max, min, i, n, k: longint; a: array of...

Найти максимальное и минимальное число в массиве
помогите решить задачу! одномерный массив с числами от -10 до +10. 15 случайных целых чисел. найти максимальное и минимальное число...


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

Или воспользуйтесь поиском по форуму:
10
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru