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

Вывести одно число наибольшую сумму двух результатов измерений, выполненных с интервалом

03.01.2015, 10:39. Показов 17966. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
На вход программы подаются результаты измерений, выполняемых прибором с интервалом 1 минуту. Все данные – целые числа (возможно, отрицательные). Требуется найти наибольшую сумму двух результатов измерений, выполненных с интервалом не менее, чем в 7 минут.
Описание входных данных
В первой строке вводится одно целое положительное число – количество измерений N, которое может быть очень велико. Гарантируется, что N > 7. Каждая из следующих N строк содержит по одному целому числу – результат очередного измерения.
Описание выходных данных
Программа должна вывести одно число наибольшую сумму двух результатов измерений, выполненных с интервалом не менее, чем в 7 минут.
Пример входных данных:
10
1
2
3
4
5
6
7
8
9
10
Пример выходных данных для приведённого выше примера входных данных:
13
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
03.01.2015, 10:39
Ответы с готовыми решениями:

Найти наименьшую сумму квадратов двух результатов измерений с интервалом в 5 элементов
На вход программы подаются результаты измерений, выполняемых прибором с интервалом 1 минуту. Все данные – натуральные числа, не...

Найти наименьшую сумму квадратов двух результатов измерений с интервалом в 5 элементов
На вход программы подаются результаты измерений, выполняемых прибором с интервалом 1 минуту. Все данные – натуральные числа, не...

Найти наименьшую сумму квадратов двух результатов измерений с интервалом в 5 элементов
На вход программы подаются результаты измерений, выполняемых прибором с интервалом 1 минуту. Все данные – натуральные числа, не...

3
205 / 142 / 57
Регистрация: 25.12.2014
Сообщений: 447
03.01.2015, 12:07
Пусть мы знаем нужное значение (обозначим его Smax ) для прочитанной части последовательности. Поступило новое число Х. Как оно может изменить Smax?
Будем хранить 6 последних чисел последовательности (6 чисел до Х) и М - максимальное из более ранних чисел (чисел, которые идут до этих шести). Тогда нужно сравнить Smax и X+М:которое их них больше, то и станет новым Smax.
В любом случае нужно откорректировать хранилище 6 чисел - самое старое выбросить, а Х к ним добавить.
А если отбрасываемое число больше М, то оно станет новым М, иначе М не изменится.
Таким образом продолжаем до конца последовательности.

А в начале программы нужно провести инициализацию структур данных.
После чтения N мы должны считать следующие 2 числа (максимальное из них примем за М). Потом прочитать еще 6 чисел для заполнения хранилища, одновременно определяя среди них максимальное. За Smax примем сумму этого максимального и М.
Теперь всё готово для цикла
"пока не конец файла ( прочитать Х, откорректировать Smax,M и хранилище из 6 чисел)"
Осталось после цикла вывести Smax на экран.
1
0 / 0 / 0
Регистрация: 03.01.2015
Сообщений: 2
03.01.2015, 13:07  [ТС]
Спасибо, получилось как-то так:
Pascal
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Var
  N, i, j, max, Smax, K: Integer;
  a: array[1..7] of Integer;
Begin
Readln(N);
max:=0;
Smax:=0;
For i:=1 to N Do
  Begin
  Readln(K);
  If i <= 7 Then a[i]:=K
            Else
              Begin
              If a[1] > max Then max:=a[1];
              For j:=1 to 5 Do a[j]:=a[j+1];
              a[6]:=K;
              If K + max > Smax Then Smax:=K+max;
              End;
  End;
Writeln(Smax);
End.
0
205 / 142 / 57
Регистрация: 25.12.2014
Сообщений: 447
03.01.2015, 21:46
Все данные – целые числа (возможно, отрицательные!)
А если отрицательные, то нельзя max:=0; Smax:=0;
И, вообще, я бы лучше первые 7 (даже 8) в общий цикл не вставлял. Сделал бы отдельно инициализацию, где заполнил бы массив, определил max, Smax и т.д. как я выше написал.
А потом бы и остальные обрабатывал уже единообразно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
03.01.2015, 21:46
Помогаю со студенческими работами здесь

Вывести одно число: сумму чисел, кратных 2 и оканчивающихся на 4
Написать программу, которая в последовательности натуральных чисел определяет сумму чисел, кратных 2 и оканчивающихся на 4. Программа...

Найти наибольшую по величине сумму двух соседних элементов массива
Помогите с программой! Const N=10 ввод массивов с клавиатуры. Определить наибольшую по величине сумму двух соседних элементов массива.

Определить, какой из двух произвольных массивов имеет наибольшую сумму элементов
Создать модуль обработки двухмерного массива(матрицы) размером м*н, который содержит: А) описание массива Б) процедуры: ...

Найти и вывести наибольшую разность двух чисел, содержащихся в массиве
Привет, форумчане. Прошу помощи. Уезжаю. Не будет ПК и интернета. Помогите. Если не будет сложно, то посмотрите и другие мои темы. Дан...

Найти наибольшую сумму чисел ряда, не превышающую заданное число k.
Помогите написать программу в С++. Найти найбольшую сумму чисел ряда 1,1/2,1/3...1/n не превышающую заданное число k.


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru