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 ответов

26 просмотров

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

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(предыдущего значения)

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта