Python | Ocurrencia máxima consecutiva en la lista

A veces, mientras trabajamos con listas de Python o en una configuración de programación competitiva, podemos encontrarnos con un subproblema en el que necesitamos obtener un elemento que tenga la máxima ocurrencia consecutiva. El conocimiento de su solución puede ser de gran ayuda y puede emplearse cuando se requiera. Analicemos ciertas formas en que se puede realizar esta tarea.

Método #1: Usar groupby() + max()+ lambda
Esta tarea se puede resolver usando una combinación de las funciones anteriores. En esto, agrupamos cada ocurrencia de números usando groupby()y obtenemos el máximo usando max(). La función lambda proporciona lógica de utilidad para realizar esta tarea.

# Python3 code to demonstrate working of
# Consecutive Maximum Occurrence in list
# using groupby() + max() + lambda
from itertools import groupby
  
# initializing list
test_list = [1, 1, 1, 2, 2, 4, 2, 2, 5, 5, 5, 5]
  
# printing original list
print("The original list is : " + str(test_list))
  
# Consecutive Maximum Occurrence in list
# using groupby() + max() + lambda
temp = groupby(test_list)
res = max(temp, key = lambda sub: len(list(sub[1])))
  
# printing result 
print("Maximum Consecutive Occurring number is : " + str(res[0]))
Producción :

The original list is : [1, 1, 1, 2, 2, 4, 2, 2, 5, 5, 5, 5]
Maximum Consecutive Occurring number is : 5

Publicación traducida automáticamente

Artículo escrito por manjeet_04 y traducido por Barcelona Geeks. The original can be accessed here. Licence: CCBY-SA

Deja una respuesta

Tu dirección de correo electrónico no será publicada. Los campos obligatorios están marcados con *