Maison  >  Article  >  développement back-end  >  Comment coupler efficacement des permutations à partir de listes de longueurs disparates ?

Comment coupler efficacement des permutations à partir de listes de longueurs disparates ?

Barbara Streisand
Barbara Streisandoriginal
2024-10-29 01:03:02520parcourir

How to Efficiently Pair Permutations from Lists of Disparate Lengths?

Associer efficacement des permutations à partir de listes disparates

Votre objectif est de générer des combinaisons uniques d'éléments de deux listes, avec le nombre d'appariements guidé par la longueur de la liste la plus courte. Illustrons ce concept :

Considérons deux listes :

names = ['a', 'b']
numbers = [1, 2]

Le résultat souhaité serait :

[('a', 1), ('b', 2)]
[('b', 1), ('a', 2)]

Pour y parvenir, vous pouvez exploiter la puissance de Python itertools.product. Voici comment cela fonctionne :

<code class="python">from itertools import product

a = ['foo', 'melon']
b = [True, False]
c = list(product(a, b))</code>

En utilisant le produit, vous obtenez toutes les combinaisons possibles par paires :

[('foo', True), ('foo', False), ('melon', True), ('melon', False)]

Dans les scénarios où une liste est plus longue que l'autre (par exemple, les noms ont trois éléments alors que les nombres n'en ont que deux), les permutations seront toujours calculées sur la base de la liste la plus courte :

names = ['a', 'b', 'c']
numbers = [1, 2]

Résultat attendu :

[('a', 1), ('b', 2)]
[('b', 1), ('a', 2)]
[('a', 1), ('c', 2)]
[('c', 1), ('a', 2)]
[('b', 1), ('c', 2)]
[('c', 1), ('b', 2)]

Cette approche garantit que vous obtenez toutes les combinaisons possibles nécessaires pour votre cas d'utilisation spécifique, quelles que soient les longueurs relatives des listes d'entrée.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn