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

Вычислить сумму элементов массива

30.10.2020, 01:30. Показов 19043. Ответов 8

Студворк — интернет-сервис помощи студентам
Дорогие форумчане. Наткнулся на задачку.
Напишите программу, которая вычисляет сумму элементов массива.
Входные данные. В первой строке задается целое число N (1≤N≤30000) – количество элементов в массиве. Во второй строке записано N чисел, определяющих элементы массива. Все числа целые и по модулю не превосходят 100000.
Выходные данные. Необходимо вывести сумму всех элементов массива.
По сути ничего сложного. Написал код. НО!!! Происходит непонятное мне зацикливание. Если число больше 100000 в список начинает записываться все подряд.
Помогите пожалуйста исправить.


Python
1
2
3
4
5
6
7
8
9
10
n = int(input("Enter the number"))
while n<1 or n>30000:
    n = int(input("Enter the number"))
array  = []
for i in range(n):
    array.append(int(input()))
    while abs(array[i]) > 100000:
        array.append(int(input()))
 
print(sum(array))
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
30.10.2020, 01:30
Ответы с готовыми решениями:

В одномерном массиве, состоящем из n вещественных элементов, вычислить сумму элементов массива, расположенных после мини
В одномерном массиве, состоящем из n вещественных элементов, вычислить сумму элементов массива, расположенных после минимального элемента.

Вычислить сумму элементов массива
Дано натуральное число N и последовательность a1, a2, …, aN целых чисел, заданных случайным образом из диапазона от 15 до 85 включительно и...

Вычислить сумму элементов массива
Всем привет! Подскажите, как посчитать сумму в массиве таким образом: arr = вышло так, где каждый элемент это 1, 1+2, 1+2+3,...

8
312 / 192 / 98
Регистрация: 01.05.2014
Сообщений: 522
30.10.2020, 02:34
Что оно делает? Без него работает.
Цитата Сообщение от PIP_Install Посмотреть сообщение
Python
1
2
while abs(array[i]) > 100000:
        array.append(int(input()))
И ещё
Цитата Сообщение от PIP_Install Посмотреть сообщение
Python
1
while n<1 or n>30000:
можно сократить до:
Python
1
while 1 < n > 30000:
0
0 / 0 / 0
Регистрация: 28.05.2020
Сообщений: 13
30.10.2020, 16:10  [ТС]
Python
1
2
3
4
for i in range(n):
    array.append(int(input()))
    while abs(array[i]) > 100000:
        array.append(int(input()))
Должно ограничивать размер числа до 100000. Сначала при помощи for мы проходим по списку, потом при помощи первого append делаем вхождение в while, а while использует с for-ом одинаковое значение i. И по идее while должен требовать пользователя ввести число меньше 100000
0
2 / 1 / 1
Регистрация: 30.10.2020
Сообщений: 9
30.10.2020, 16:18
Лучший ответ Сообщение было отмечено PIP_Install как решение

Решение

используй не append на проверке, а взятие по индексу i, который и идет на проверку.
получается что ты бесконечно добавляешь функцией append, а тот самый i'тый элемент массива не изменяется, а проверяешь ты ведь его
1
 Аватар для Вадим Тукаев
310 / 291 / 116
Регистрация: 23.01.2018
Сообщений: 933
31.10.2020, 10:15
Python
1
print(sum(int(input()) for _ in range(int(input()))))
2
0 / 0 / 0
Регистрация: 28.05.2020
Сообщений: 13
31.10.2020, 14:08  [ТС]
Спасибо, попробую.
0
0 / 0 / 0
Регистрация: 28.05.2020
Сообщений: 13
02.11.2020, 17:51  [ТС]
Цитата Сообщение от Вадим Тукаев Посмотреть сообщение
print(sum(int(input()) for _ in range(int(input()))))
Это коротко, да, но таким образом не будут действовать проверки. По идее. И прийдется че-то переписывать, мудрить более стремные проверки.
По идее.

Добавлено через 3 минуты
Цитата Сообщение от Amurkin Посмотреть сообщение
используй не append на проверке, а взятие по индексу i, который и идет на проверку.
получается что ты бесконечно добавляешь функцией append, а тот самый i'тый элемент массива не изменяется, а проверяешь ты ведь его
проблема в том, что тогда путон выдает всем известную list assignment index out of range, я изначально так и записывал. Но по причине этой ошибки я и переписал на append. А значит или пытаться исправить эту проблему. Или переписывать программу под вот эту строку:
Цитата Сообщение от Вадим Тукаев Посмотреть сообщение
print(sum(int(input()) for _ in range(int(input()))))
Крч буду думать.
0
 Аватар для Semen-Semenich
5222 / 3469 / 1173
Регистрация: 21.03.2016
Сообщений: 8,295
02.11.2020, 17:57
PIP_Install, какую проверку? о чем думать? вам конкретно даны данные и решение Вадим Тукаев, полностью решает поставленную задачу
1
0 / 0 / 0
Регистрация: 28.05.2020
Сообщений: 13
02.11.2020, 18:33  [ТС]
Я допетрил. Вот код.
Python
1
2
3
4
5
6
7
8
9
10
11
12
while True:
    n = int(input("Enter the number"))
    while n<1 or n>30000:
        n = int(input("Enter the number"))
    array  = []
    i=0
    while i<=n-1:
        array.append(int(input()))        
        while abs(array[i]) > 100000:
            array[i] = int(input())            
        i+=1
    print(sum(array))
Добавлено через 10 минут
Просто забейте, про проверки написано в условии. А так. Пофиг уже.

Добавлено через 10 минут
Сделал более адекватную версию программы.

Python
1
2
3
4
5
6
7
8
9
10
while True:
    n = int(input("Enter the number "))
    while n<1 or n>30000:
        n = int(input("Enter valid number, 30000 > valid number >0"))
    array  = []
    for i in range(n):
        array.append(int(input()))        
        while abs(array[i]) > 100000:
            array[i] = int(input("Enter valid number valid number >100000"))            
    print(sum(array))
Добавлено через 46 секунд
Цитата Сообщение от Amurkin Посмотреть сообщение
используй не append на проверке, а взятие по индексу i, который и идет на проверку.
получается что ты бесконечно добавляешь функцией append, а тот самый i'тый элемент массива не изменяется, а проверяешь ты ведь его
и правда. проблема оказалась в этой ерунде. спасибо
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
02.11.2020, 18:33
Помогаю со студенческими работами здесь

Вычислить сумму элементов одномерного массива
Задание: Задан двумерный массив А из 6-и строк и 3-х столбцов. Составить программу, которая организует одномерный массив, каждый элемент...

Вычислить сумму положительных четных элементов массива
- Вычислить сумму положительных четных элементов массива.

Вычислить сумму и количество положительных элементов массива
Вычислить сумму и количество положительных элементов массива X(n), где 1&lt;=n&lt;=100 Буду очень признателен

Дан массив. Вычислить сумму элементов массива
Дан массивX(N). Вычислить сумму элементов массива с k1-го по k2-й (значения k1 и k2 вводятсяс клавиатуры; k2 &gt; k1, k1, k2 &lt;N). ...

Вычислить сумму четных элементов двухмерного массива
Дан двухмерный массив, состоящий из N, M целочисленных элементов. 1)Вычислить сумму четных элементов двухмерного массива. 2)Для...


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

Или воспользуйтесь поиском по форуму:
9
Ответ Создать тему
Новые блоги и статьи
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Первый деплой
lagorue 16.01.2026
Не спеша развернул своё 1ое приложение в kubernetes. А дальше мне интересно создать 1фронтэнд приложения и 2 бэкэнд приложения развернуть 2 деплоя в кубере получится 2 сервиса и что-бы они. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь постоянного тока с R, L, C, k(ключ), U, E, J. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа, решает её и находит: токи, напряжения и их 1 и 2 производные при t = 0;. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Изучаю kubernetes
lagorue 13.01.2026
А пригодятся-ли мне знания kubernetes в России?
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
WordPad для Windows 11
Jel 10.01.2026
WordPad для Windows 11 — это приложение, которое восстанавливает классический текстовый редактор WordPad в операционной системе Windows 11. После того как Microsoft исключила WordPad из. . .
Classic Notepad for Windows 11
Jel 10.01.2026
Old Classic Notepad for Windows 11 Приложение для Windows 11, позволяющее пользователям вернуть классическую версию текстового редактора «Блокнот» из Windows 10. Программа предоставляет более. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru