Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.68/103: Рейтинг темы: голосов - 103, средняя оценка - 4.68
23 / 21 / 3
Регистрация: 27.10.2017
Сообщений: 192

Выход за границу массива

09.04.2019, 21:47. Показов 19282. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Допустим имеем
Python
1
 list1 = [1, 2, 3, 4, 5]
сравниваю условия в цикле
Python
1
2
3
4
for num in list1:
   if list1[k] == list1[k+1]
        pass
   k+=1
Как можно предотвратить выход за границу массива через
Python
1
try except
или каким-нибудь другим способом?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
09.04.2019, 21:47
Ответы с готовыми решениями:

Выход за границу массива
Объясните пожалуйста где я вышел за границу массива #include<iostream> #include <clocale> using namespace std; int main() { ...

Выход за границу массива
Не могу понять почему выходит за границы индекса массива. using System; namespace ConsoleApplication4 { class Program ...

Выход за границу массива
не работает если ввести более 10 символов. подскажите где ошибка? do while неправильно организовал? #include <stdio.h> int...

12
 Аватар для Semen-Semenich
5227 / 3473 / 1174
Регистрация: 21.03.2016
Сообщений: 8,301
09.04.2019, 21:51
Python
1
2
for idex_ in range(len(list1)-1):
    if list1[idex_] == list1[idex_+1]
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
09.04.2019, 23:41
nikita55050505, Если Вы хотите, что бы Вам помогли, напишите условие задания и дайте весь код, а не его куски.
0
23 / 21 / 3
Регистрация: 27.10.2017
Сообщений: 192
10.04.2019, 00:00  [ТС]
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
27
28
29
30
31
32
"""def all_the_same(*elements):
    return all(x == y for x, y in zip(elements, elements[1:]))
 
 
if all_the_same(1, 1, 1, 1) == True:
    print('ok')"""
 
 
 
list1 = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2]
 
 
l = len(list1)
i=0
c=0
flag = True
while l!=0:
    if l == 0:
        continue
    for index in list1:
        if index == list1[c]:
            flag = True
        else:
            flag = False
            break
    c+=1
    l-=1
print(c)
if flag == True:
    print('ok')
else:
    print('neok')
Вот здесь где index == list1[c+1]
я хотел так написать и если бы программа пыталась взять c+1 но дальше ничего нет, т.е. нет столько элементов в массиве то обрабатывалась бы ошибка и пропускалась данная итерация
0
1732 / 970 / 199
Регистрация: 22.02.2018
Сообщений: 2,693
Записей в блоге: 6
10.04.2019, 00:36
nikita55050505, Код работает без ошибки. Но не понятно, что он должен делать. Условие задания Вы так и не написали. А не зная, что должен делать код трудно что либо посоветовать.
0
23 / 21 / 3
Регистрация: 27.10.2017
Сообщений: 192
10.04.2019, 01:15  [ТС]
Проверить что все символы в массиве одинаковы

Добавлено через 33 секунды
но суть не в этом, я хочу чтобы обрабатывалась ошибка за выход границы массива, возможно это?
0
60 / 86 / 16
Регистрация: 25.03.2019
Сообщений: 235
10.04.2019, 01:29
Цитата Сообщение от nikita55050505 Посмотреть сообщение
но суть не в этом, я хочу чтобы обрабатывалась ошибка за выход границы массива, возможно это?
Здесь сложного ничего нет. Перед тем, как получить значение list1[n + 1], проверяйте, не выходит ли n + 1 за длину списка. Как то так:
Python
1
2
3
4
5
6
7
8
9
10
11
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
 
 
if __name__ == "__main__":
    list1 = [1, 2, 3, 4, 5]
    n = 0
    while n < len(list1):
        if n + 1 < len(list1):
            print(list1[n + 1])
        n += 1
А try тут вообще не надо.
0
26 / 21 / 6
Регистрация: 23.08.2018
Сообщений: 68
10.04.2019, 03:47
Цитата Сообщение от nikita55050505 Посмотреть сообщение
но суть не в этом, я хочу чтобы обрабатывалась ошибка за выход границы массива, возможно это?
возможно
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
27
lst = [1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2]
 
# ловим границу
for i in range(len(lst)):
    try:
        print('сравниваем {} и {} => {}'.format(lst[i], lst[i+1], lst[i] == lst[i+1]))
    except IndexError:
        print(i+1, 'это заграница ;)')
print('последний легальный индекс', i)
 
# без try
# simple
print('простая проверка:', 'все одинаковые' if len(set(lst)) == 1 else 'разные')
 
# not simple
def show(i, j, msg):
    print('элементы списка с индексами {} и {} {}'.format(i, j, msg))
 
for i in range(1, len(lst)):
    if lst[i-1] == lst[i]:
        show(i-1, i, 'одинаковые')
    else:
        show(i-1, i, 'разные')
        print('detected different elements in list')
        break
else:
    print('list is ok')
0
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
10.04.2019, 10:02
nikita55050505,
1. Самый простой способ предотвратить вылет - от Semen Semenich.
2. Про "описать всю задачу" - верное замечание.

3. Проверить повторы? Окей, но ваш код проверяет только соседние элементы, а повторы по всему массиву проверяются по другому.
4. Чтобы проверить именно соседние элементы, я бы взял функцию pairwise со страницы python itertools recipes (google it).
0
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
10.04.2019, 13:29
Python
1
2
lst = [1,1,1,1,1,1,1]
print(len(set(lst)) == 1)
0
23 / 21 / 3
Регистрация: 27.10.2017
Сообщений: 192
10.04.2019, 19:10  [ТС]
Цитата Сообщение от dondublon Посмотреть сообщение
повторы по всему массиву проверяются по другому.
Как можно сравнить отдельно каждый элемент со всем массивом?

Добавлено через 35 секунд
Знаю что можно через два цикла, но может есть какой-то упрощенный способ через for
0
Эксперт Python
 Аватар для dondublon
4652 / 2072 / 366
Регистрация: 17.03.2012
Сообщений: 10,182
Записей в блоге: 6
10.04.2019, 19:19
nikita55050505, как сравнить - это уже другой вопрос. Вам надо сначала понять, что вы делаете.
Впрочем, ответ уже дал ioprst.
0
1303 / 843 / 409
Регистрация: 12.03.2018
Сообщений: 2,305
11.04.2019, 08:04
Если обязательно использовать for, можно сделать так:
Python
1
2
3
4
5
6
7
8
9
10
def foo(lst):
    for i in range(len(lst)):
        for j in range(len(lst)):
            if j != i:
                if lst[i] != lst[j]:
                    return False
    return True
 
lst = [1,1,1,1,1,1,1,1]
print(foo(lst))
Но использовать set намного проще. Не усложняйте себе жизнь

Вот еще решение в одну строчку:
Python
1
2
3
4
5
def foo(lst):
    return lst.count(lst[0]) == len(lst)
 
lst = [1,1,1,1,1,1,1,1]
print(foo(lst))
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
11.04.2019, 08:04
Помогаю со студенческими работами здесь

Выход за границу массива
на строке if (A == num) выдает ошибку и пишет выход за границу массива. В чем ошибка? Console::WriteLine(); ...

Выход индекса за границу массива
При запуске получаю сообщение о том, что индекс выходит за границу массива в строке. Прошу указать на ошибку. string data =...

Почему выход за границу массива?
Господа подскажите пожлст, почему в этом коде происходит выход за границу массива. ВСЕМ СПАСИБО. using System; class a { static...

Произведение матриц, выход за границу массива
#include &lt;iostream&gt; #include &lt;stdlib.h&gt; #include &lt;time.h&gt; #include &lt;cmath&gt; #include &lt;math.h&gt; using namespace std; void...

Исключительная ситуация - выход за границу массива
Ребят,помогите пожалуйста,мне нужно сделать ,если z&gt;q(z-знаменатель,q-исходное данное,которые мы задаем),то мы создаем ситуацию выхода за...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Конвертировать закладки 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. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru