Обнаружение последовательных целых чисел в списке [дубликат]

48
задан James 2 March 2010 в 09:10
поделиться

2 ответа

Из документации :

>>> from itertools import groupby
>>> from operator import itemgetter
>>> data = [ 1, 4,5,6, 10, 15,16,17,18, 22, 25,26,27,28]
>>> for k, g in groupby(enumerate(data), lambda (i, x): i-x):
...     print map(itemgetter(1), g)
...
[1]
[4, 5, 6]
[10]
[15, 16, 17, 18]
[22]
[25, 26, 27, 28]

Вы можете довольно легко адаптировать это, чтобы получить печатный набор диапазонов.

71
ответ дан 26 November 2019 в 18:49
поделиться

Встроенный: Нет, насколько мне известно.

Вы должны пройти через массив. Начните с помещения первого значения в переменную и распечатайте его, затем, пока вы продолжаете нажимать следующее число, ничего не делайте, кроме запоминания последнего числа в другой переменной. Если следующего числа нет в строке, сравните последнее запомненное число с первым числом. Если то же самое, ничего не делайте. Если он другой, выведите «-» и последнее число. Затем поместите текущее значение в первую переменную и начните заново. В конце массива вы выполняете ту же процедуру, как если бы вы набрали число вне строки.

Я, конечно, мог бы написать код, но я не хочу портить вам домашнее задание: -)

3
ответ дан 26 November 2019 в 18:49
поделиться
Другие вопросы по тегам:

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