Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/55: Рейтинг темы: голосов - 55, средняя оценка - 4.73
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98

Найти индекс элемента списка сумма которого и k следующих элементов равна заданной

16.03.2016, 20:23. Показов 11448. Ответов 18
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Дан массив целых чисел a[1], a[2], ..., a[n] и натуральные числа k и m. Укажите минимальное значение i, для которого a[i] + a[i+1] + ... + a[i + k] = m (то есть сумма k + 1 подряд идущих элементов массива равна m). Если такого значения нет, то выведите 0. Вложенные циклы не использовать.

Входные данные
На вход программе сначала подаются значения n, k и m (m <= 10000, 0 < k < n <= 30000; n - количество элементов в массиве). В следующей строке входных данных расположены сами элементы массива - целые числа, по модулю не превосходящие 100.

Выходные данные
Выведите ответ на задачу.

Примеры
входные данные
4 1 22
9 13 10 -11
выходные данные
1

Помогите пожалуйста решить
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
16.03.2016, 20:23
Ответы с готовыми решениями:

Найти строки матрицы, где есть эл-т для которого сумма предшествующих равна сумме следующих за ним элементов
Доброго времени суток всем. Прошу помочь с этими заданиям, написать код в c++ 2. Вывести строки матрицы, в которых есть такой...

Найти индекс элемента, для которого сумма элементов, стоящих до него, наименее отличается от суммы элементов
Помогите написать код на Си!!!:-[ Для этой программы функции ввода и вывода массивов описывать отдельно, не объединяя с обработкой...

Найти в массиве индекс элемента для которого сумма элементов, которые стоят до него
Задан массив, который состоит из n элементов. Найти в нём индекс элемента для которого сумма элементов, которые стоят до него, меньше всего...

18
Эксперт по компьютерным сетям
 Аватар для Jabbson
5907 / 3359 / 1036
Регистрация: 03.11.2009
Сообщений: 10,008
16.03.2016, 20:33
а что у Вас именно не получается?
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
17.03.2016, 15:47  [ТС]
Вообще ничего, даже не знаю с чего начать
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
17.03.2016, 17:33
Начинают со считывания данных, потом перебор массива с вычислением суммы и сравнением с заданным значением.
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
18.03.2016, 22:40  [ТС]
Мой вариант:
Python
1
2
3
n, k, m=(int(x) for x in input().split())
a=[int(x) for x in input().split()]
print(min(i for i in range(0,m-k-1) if sum(a[i:i+k+1])==int(m)))
Но он не рабочий :c
0
 Аватар для Zuzik
298 / 256 / 57
Регистрация: 11.06.2012
Сообщений: 1,557
19.03.2016, 01:30
Цитата Сообщение от OnikS228 Посмотреть сообщение
print(min(i for i in range(0,m-k-1) if sum(a[i:i+k+1])==int(m)))
Python
1
print(min(i for i in range(0,n-k-1) if sum(a[i:i+k+1])==m))
буквочку походу перепутали, вместо m n должно быть поидее говоря.
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
19.03.2016, 11:29
OnikS228, в первой строке можно не использовать генератор, т.к. split уже возвращает список
min будет перебирать до конца списка и в общем случае это не здорово — нужно ведь только одно 1-е значение.Если k достаточно большое то имеет смысл рассчитать сумму элементов сразу от 1-го, а потом при каждой итеррации изменять уже полученную сумму (отнимать a[i-1] и добавлять a[i+k])
Python
3
4
5
6
7
8
9
10
s = sum(a[:i+k+1])
for i in range(n - k - 1):
    if s == m:
        print(i + 1)
        break
    s += (a[i+k+1] - a[i])
else:
    print(0)
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
19.03.2016, 14:27  [ТС]
Python
1
2
3
4
5
6
7
8
9
10
n, k, m = (int(x) for x in input().split())
a = [int(x) for x in input().split()]
s = sum(a[:i+k+1])
for i in range(n - k - 1):
    if s == m:
        print(i + 1)
        break
    s += (a[i+k+1] - a[i])
else:
    print(0)
При таком варианте в 3 строке ошибка, что i не найдена
Python
1
2
3
4
5
6
7
8
9
10
n, k, m = (int(x) for x in input().split())
a = [int(x) for x in input().split()]
for i in range(n - k - 1):
    s = sum(a[:i+k+1])
    if s == m:
        print(i + 1)
        break
    s += (a[i+k+1] - a[i])
else:
    print(0)
При таком коде ответ при данных вводных данных получается верный, но тестирующая система при проверке получает неправильные ответы
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
20.03.2016, 16:12  [ТС]
АКТУАЛЬНО
0
 Аватар для vdm_mar
39 / 39 / 25
Регистрация: 25.10.2015
Сообщений: 102
20.03.2016, 17:20
Вы в первом своем варианте зря затащили i в строку 3. Первая сумма: s = sum(a[:k+1]). А во втором варианте, сумма постоянно будет увеличиваться за счет прибавления нового члена.

Python
1
2
3
4
5
6
7
8
9
10
n, k, m = (int(x) for x in input().split())
a = [int(x) for x in input().split()]
s = sum(a[:k+1])
for i in range(n - k - 1):
    if s == m:
        print(i + 1)
        break
    s += (a[i+k+1] - a[i])
else:
    print(0)
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
20.03.2016, 17:28  [ТС]
теперь стали все правильными, кроме одного(
0
 Аватар для vdm_mar
39 / 39 / 25
Регистрация: 25.10.2015
Сообщений: 102
20.03.2016, 18:02
в строке 4 не до конца проходит цикл, там должно быть range(n - k)

Python
1
2
3
4
5
6
7
8
9
10
n, k, m = (int(x) for x in input().split())
a = [int(x) for x in input().split()]
s = sum(a[:k+1])
for i in range(n - k):
    if s == m:
        print(i + 1)
        break
    s += (a[i+k+1] - a[i])
else:
    print(0)
0
3 / 2 / 0
Регистрация: 23.01.2016
Сообщений: 98
20.03.2016, 18:18  [ТС]
Хах, теперь ещё меньше правильных

Добавлено через 7 минут
Но теперь не "неправильный ответ", а "ошибка во время исполнения программы"
0
 Аватар для vdm_mar
39 / 39 / 25
Регистрация: 25.10.2015
Сообщений: 102
20.03.2016, 18:24
ну ищите "мелочи" в оформлении, идея Marinero стопудово классная
попробуйте сместить print(0) в for

Python
1
2
3
4
5
6
7
8
9
10
11
n, k, m = (int(x) for x in input().split())
a = [int(x) for x in input().split()]
s = sum(a[:k+1])
for i in range(n - k):
    if s == m:
        print(i + 1)
        break
    elif i == n - k - 1:
        print(0)
    else:
        s += (a[i+k+1] - a[i])
0
 Аватар для Semen-Semenich
5228 / 3474 / 1174
Регистрация: 21.03.2016
Сообщений: 8,301
21.03.2016, 17:33
OnikS228, в первой строке можно не использовать генератор, т.к. split уже возвращает список.
так то оно так но список то строк тип str возвращает а нам в решении числа нужны тип int и потом их преобразовывать в int лишние движения.так что генератор оправдан сразу получаем числа

Добавлено через 3 часа 1 минуту
этот код вообще ни о чем. что вы пытаетесь найти?
Python
1
2
3
4
5
s = sum(a[:k+1])
for i in range(n - k):
    if s == m:
        print(i + 1)
        break
задали значение s вне цикла и теперь пытаетесь в цикле его сравнить с m? так всегда будет falhe если случайно по совпадению сумма первых к элементов будет равна м так тогда и весь цикл
Python
1
2
for i in range(n - k):
    if s == m
будет истина и вы получите первую i+1
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
22.03.2016, 12:23
Цитата Сообщение от Marinero Посмотреть сообщение
s = sum(a[:i+k+1])
Конечно же
Python
3
s = sum(a[:k+1])
Цитата Сообщение от Semen-Semenich Посмотреть сообщение
задали значение s вне цикла и теперь пытаетесь в цикле его сравнить с m?
С какой радости Вы выбросили строку из кода и делаете выводы?
Python
8
s += (a[i+k+1] - a[i])
0
 Аватар для Semen-Semenich
5228 / 3474 / 1174
Регистрация: 21.03.2016
Сообщений: 8,301
22.03.2016, 14:50
пардон. не досмотрел.хотя при данных 4 2 22 9 13 10 -11 а так же 4 3 22 9 13 10 -11 результат 0 хотя 13+10+(-11) и есть 22 тут уж и два подряд идущих и три проверял.может что то недопонимаю в условии???
0
Эксперт NIX
 Аватар для Marinero
2796 / 2039 / 682
Регистрация: 02.03.2015
Сообщений: 6,509
22.03.2016, 17:01
Semen-Semenich, когда это 13 + 10 = 23 - 11 = 12 стало равно 22?
0
 Аватар для Semen-Semenich
5228 / 3474 / 1174
Регистрация: 21.03.2016
Сообщений: 8,301
22.03.2016, 17:20
прошу простить и понять сонный еще был((
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
22.03.2016, 17:20
Помогаю со студенческими работами здесь

Задан массив. Найти в нем индекс элемента, для которого сумма элементов, стоящих до него, наименее отличается от суммы
Здравствуйте, помогите пожалуйста довести код до ума. Условие такое: Задан массив, состоящий из 50 неотрицательных элементов. Найти в нем...

Найти индекс элемента для которого сумма элементов, стоящих перед ним, наименее отличается от суммы элементов, стоящих п
Заданный массив, состоящий из n неотрицательных элементов. Найти в нем индекс элемента для которого сумма элементов, стоящих к нему,...

Массив: Найти индекс элемента, для которого сумма элементов, стоящих до него наименее отличается от суммы элементов, стоящих после.
Задан массив неотрицательных чисел. Найти в нём индекс элемента для которого сумма элементов, стоящих до него наименее отличается от суммы...

Найти в массиве индекс элемента, для которого сумма элементов, стоящих до него, наименее отличается от суммы элементов, стоящих после него
Всем доброго времени суток) Помогите плиз с задачкой, что-то ничего не выходит, задание такое: Задан массив, состоящий из n...

Найти индекс элементов, сумма которых равна заданному числу
привет всем!!! есть одномерный массив типа integer. найти и вывести индексы двух элементов, сумма которых равна заданному числу...


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

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
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