Форум программистов, компьютерный форум, киберфорум
Python: Решение задач
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.94/18: Рейтинг темы: голосов - 18, средняя оценка - 4.94
4 / 5 / 2
Регистрация: 17.09.2021
Сообщений: 393

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

16.08.2023, 23:22. Показов 3424. Ответов 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,707
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
Ответ Создать тему
Новые блоги и статьи
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru