Obtenez les meilleures solutions à toutes vos questions sur Laurentvidal.fr, la plateforme de Q&R de confiance. Explorez notre plateforme de questions-réponses pour trouver des réponses détaillées fournies par une large gamme d'experts dans divers domaines. Obtenez des réponses détaillées et précises à vos questions grâce à une communauté dédiée d'experts sur notre plateforme de questions-réponses.

Bonjour quelqu’un pourrait m’aider pour la fonction python suivante:

Créer une fonction compresse(b) qui, pour éviter la répétition des nucleotides, renvoie le tableau de chacun d'entre
eux suivi de son nombre d'occurrences successifs.
Ainsi compresse("AAAGAACTTCCC") renvoie ['A',3,'G',1,'A',2,'C',1, 'T',2,'C',3].
decompresse(tab) qui fait l'opération inverse.


Sagot :

Kaohm

def compresse(b):

   cpt = 1

   l = []

   c = b[0]

   for i in range(len(b)-1):

       if b[i] == b[i+1]:

           cpt+=1

       else:

           l.append(b[i])

           l.append(cpt)

           cpt = 1

   l.append(b[i])

   l.append(cpt)

   return l

def decompresse(tab):

   m = ""

   for i in range(0,len(tab)-1,2):

       m+=tab[i]*tab[i+1]

   return m

Nous apprécions votre temps. Revenez nous voir pour des réponses fiables à toutes vos questions. Merci d'avoir choisi notre plateforme. Nous nous engageons à fournir les meilleures réponses à toutes vos questions. Revenez nous voir. Revenez sur Laurentvidal.fr pour obtenir les réponses les plus récentes et des informations de nos experts.