4 / 5 / 2
Регистрация: 17.09.2021
Сообщений: 397

Статистика сбоев

16.08.2023, 23:22. Показов 3430. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
В мобильное приложение, которое разрабатывает Николай, встроен автоматический детектор сбоев. Когда в приложении возникает ошибка, детектор автоматически отправляет сообщение об этом на сервер.
Впервые за долгое время Коля решил проверить статистику работы своего приложение. Статистика представляет из себя последовательность чисел a₁, a₂, ..., aₙ, каждое из которых равно количеству сообщений об ошибках в соответствующий момент работы приложения. Николай называет сбоем период работы приложения, когда количество ошибок сначала не убывало, а потом не возрастало. Например, период работы приложения с количеством ошибок [1,2,4,3,3] является сбоем, а 
[3,1,2] нет. Коля выбрал 
m периодов работы приложения и узнал, являются ли эти периоды сбоями в приложении. А сможете ли узнать это вы? Формат входных данных
В первой строке ввода дано целое число 
n — количество моментов работы приложения, для которых записана статистика, (1≤n≤10⁵).
Во второй строке дано n целых чисел a₁, a₂, ..., aₙ — количество ошибок в соответствующий момент работы приложения 
(1≤aᵢ≤10⁹).
В третьей строке дано целое число m — количество периодов, интересующих Колю 
(1≤m≤10⁵).
В следующих m строках дано описание периодов, интересующих Колю. Описание каждого периода состоит из двух целых чисел 
xᵢ и yᵢ — номера первого и последнего моментов, входящих в период 
(1≤xᵢ≤yᵢ≤n). Формат выходных данных

Выведите m строк, каждая из которых соответствует периоду, интересующему Николая. В строке с номером i выведите «Yes» (без кавычек), если указанный период является сбоем, или «No» (без кавычек) иначе. Пример данных
Примеры
Ввод
8
2 4 1 1 3 6 5 1
7
1 3
2 3
2 4
2 5
8 8
1 5
5 8.
Вывод
Yes
Yes
Yes
No
Yes
No
Yes.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
16.08.2023, 23:22
Ответы с готовыми решениями:

Статистика
Добрый день, помогите решить задачу с сайта асмп. Вот задача: Вася не любит английский язык, но каждый раз старается получить хотя бы...

Статистика по клиентам
банка «Сохранбанк» есть короткий номер 800 на который клиенты отправляют смс сообщения для совершения транзакций. Каждая транзакция имеет...

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

3
3750 / 1944 / 612
Регистрация: 21.11.2021
Сообщений: 3,706
17.08.2023, 08:40
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
n = int(input('n = '))
arr = [int(x) for x in input('->').split()]
m = int(input('m = '))
beg_end_arr = []
for _ in range(m):
    beg_end_arr.append([int(x) for x in input('beg, end->').split()])
for i in range(m):
    cur_arr = arr[beg_end_arr[i][0]-1:beg_end_arr[i][1]]
    second = False
    for i in range(len(cur_arr)-1):
        if not second and cur_arr[i] > cur_arr[i+1]:
            second = True
            continue
        if second and cur_arr[i] < cur_arr[i+1]:
            print('NO')
            break
    else:
        print('YES')
1
0 / 0 / 0
Регистрация: 07.09.2023
Сообщений: 1
07.09.2023, 19:17
Решение, предложенное выше не совсем верно - его сложность O(n^2), можно сделать за O(n), используя массив префиксных значений
Python
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
n = int(input())
arr = list(map(int, input().split()))
m = int(input())
 
flag = False
 
ans = [-1 for _ in range(n)]
 
ans[0] = 0
 
for i in range(1, n):
    if flag == False and arr[i] < arr[i-1]:
        flag = True
        ans[i] = ans[i-1]
    elif flag and arr[i] > arr[i-1]:
        flag = False
        ans[i] = i - 1
    else:
        ans[i] = ans[i-1]
 
for i in range(m):
    st, en = map(int, input().split())
    if ans[en-1] <= st-1:
        print("YES")
    else:
        print("NO")
0
Эксперт Python
 Аватар для Red white socks
4523 / 1899 / 336
Регистрация: 18.01.2021
Сообщений: 3,489
07.09.2023, 20:20
Harment, идея красивая, но нужно допилить.
На тестовом массиве введите
Python
1
st, en = 3, 5
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.09.2023, 20:20
Помогаю со студенческими работами здесь

Статистика
Реализовать классы MinStat, MaxStat, AverageStat, которые будут находить минимум, максимум и среднее арифметическое последовательности...

Статистика и графы
Только начинаю изучать Python и графы, пытаюсь найти оптимальное решение такой задачи: Нужно найти и хранить статистику по часто...

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

Статистика по числу
Статистика по числу Герасим любит собирать занимательную статистику по произвольным числам и попросил Вас разработать функцию...

Статистика по числам
У Алевтины возникла новая идея для занимательной статистики. Поэтому она просит Вас написать функцию fun_ints_stat(n_first, n_last, *args),...


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

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

Новые блоги и статьи
SDL3 для Web (WebAssembly): Основы отладки веб-приложений на SDL3 по USB и Wi-Fi, запущенных в браузере мобильных устройств
8Observer8 07.02.2026
Содержание блога Браузер Chrome имеет средства для отладки мобильных веб-приложений по USB. В этой пошаговой инструкции ограничимся работой с консолью. Вывод в консоль - это часть процесса. . .
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru