Есть ответ 👍

Задача найти, cколько элементов массива больше своих соседей.(python)
a = list(map(int, input().split()))
s=0
if len(a)<3:
print('0')
else:
for i in range(2,len(a)):
if a[i-2]>a[i-1] and a[i]>a[i-1]:
s+=1
print(s)
Вот мой код. Почему не проходит?

226
293
Посмотреть ответы 3

Ответы на вопрос:


1 a = [int(x) for x in input().split()]

2 b = []

3 i = 0

4 if len (a) == 1:

7 print(a)

6 else:

7 for c in a:

 8 b.append(int(a[i - 1]) + int(a[i + 1]))

  9i = i + 1

10print(b)


a = list(map(int, input().split()))

s=0

if len(a)<3:

   pass

else:

   for i in range(1,len(a)-1):

       if a[i] > a[i-1] and a[i]>a[i+1]:

           s+=1

print(s)

Ввод/вывод:

test 1

>>> 1 3 2 4 2

>>> 2

test 2

>>> 1 2

>>> 0

test 3  

>>> 1 5 2 6 3 8 4 9 2 10 1

>>> 5

Объяснение:

У вас была ошибка в проверке элементов, вы искали кол-во элементов, которые меньше обоих своих соседей, вместо тех, которые больше, как в задании. Так же, при длине последовательности меньше трёх программа выводила 0 два раза - в начале, где вы проверяли длину последовательности, и в конце переменную s, которая тоже в таком случае равна нулю.

Babay28
4,6(17 оценок)

На первом месте стоит одна из фишек а, б, в. на втором – одна из фишек б, в, г. на третьем месте – одна из фишек а, в, г, не стоящая в ряду на первом или втором месте => 4)ббг

Популярно: Информатика