170 похожих чатов

Господа, ищу возрастающие последовательности в списке digits, где каждое следующие

число больше строго на 0.1 или на 1).
Как-то можно это в питоне упростить?

for i in range(0, len(digits) - 1):
k = 0

while Decimal(digits[i + k + 1]) == Decimal(digits[i + k]) + Decimal('0.1') or \
Decimal(digits[i + k + 1]) == int(Decimal(digits[i + k]) + 1):
k += 1
if k == len(digits) - i - 1: break

if k > 0:
print(digits[i:i+k+1])

11 ответов

16 просмотров

А можно пример что именно это делает

Andrei-Kopylov Автор вопроса
Tishka17
А можно пример что именно это делает

Ищет возрастающие последовательности.. Первая строка - это исходный список.. Первая последовательность - это вторая строка. Она обрывается, когда после 2.2 идет 1.. Продолжалась бы, если бы после 2.2 шло 2.3 или 3

а зачем, собсна, децимал? В digits лежат строки? (да и в конце вообще decimal -> int, что мешало сразу в int, учитывая то, что там лишь сложение делается перед приведением к инту)

Andrei-Kopylov Автор вопроса
megahomyak
а зачем, собсна, децимал? В digits лежат строки? (...

Да, в digits строки.. Ну да, во втором случае лишний десимал.. Ну это не суть.. Вопрос больше, можно ли как-то проще в питоне записать, что извлекаем подсписки, где следующий элемент больше предыдущего на 0.1 или 1?

k тут для чего?

Andrei-Kopylov Автор вопроса
megahomyak
k тут для чего?

Количество элементов в подсписке

Andrei Kopylov
Количество элементов в подсписке

то есть тебе надо найти длину первой попавшейся возрастающей последовательности?

Andrei-Kopylov Автор вопроса
megahomyak
то есть тебе надо найти длину первой попавшейся во...

Не первой, а всех Есть допустим список [1, 2, 3, 2, 5, 6, 7] Из него должно извлекаться, если по условию +1: [1, 2, 3] [5, 6, 7] Теперь усложним: Есть допустим список [1, 1.1, 1.2, 2, 4, 1, 4.1, 4.2] Из него должно извлекаться, если по условию +1 от int или +0.1: [1, 1.1, 1.2, 2] [4.1, 4.2]

Кстати, а вот тут почему просто не сравнить два числа? (Можно и без децималов тогда)

Andrei-Kopylov Автор вопроса
megahomyak
Кстати, а вот тут почему просто не сравнить два чи...

Нужно, чтобы не просто больше было, а ровно на 0.1 больше от предыдущего значения ИЛИ на 1 больше от int(предыдущего значения)

Похожие вопросы

Обсуждают сегодня

А чем вам питонисты не угодили?😂
.
79
Язык Си можно выучить за день? По книжке ANSI C на 230 страниц
Vincent Vegan
29
Всем привет, написал код ниже, но он выдает сегфолт, в чем причина? #include <stdio.h> #include <stdlib.h> #include <string.h> struct product { char *name; float price; };...
buzz базз
75
Dim Dim, [02.07.2024 11:07] DB 0x62 Dim Dim, [02.07.2024 11:07] DB 0x66 Dim Dim, [02.07.2024 11:07] кто пояснит что это?
Dim Dim
14
Ошибка: segmentation fault (core dumped) Код: pastebin.com/BEsNNSSV Сообщение от компилятора: отсутствует ОС: Arch Linux Ядро: x86_64 Linux 6.9.7-arch1-1 Процессор: Intel Cele...
sec
4
Ребят, а за скок можно впарить анон чат с апишкой и веб админкой ?
Eugene Неелов
15
Ещё такой вопрос. Мне необходимо хранить пароль пользователя локально. Для этого планирую использовать ini файл. Это для автозаполнения полей логин и пароль при авторизации. Е...
Евгений
19
Кстати, я тут еще с одной темой столкнулся, вот учу я C++, на таком то ресурсе, а остальные постоянно советуют практиковаться, что то писать, проекты, но как писать если вот т...
aaswq1
7
Добрый день, чат. Мне в очередь из других RabbitMQ по shovel валятся метрики в формате текста для Prometheus. Помогите пожалуйста подружить RabbitMQ и Prometheus, чтобы он (...
Aleksey
4
@ahndmn @ayaw0_0 здарова, на чем пишете?
Aiwan \ (•◡•) / _bot
7
Карта сайта