J'ai un problème:Trouver le 2x2 la plus optimale des correspondances entre les collections hétérogènes
J'ai une classe A et classe B, dont les objets par exemple peuvent être inspectés programatically être semblables ou différents les uns des autres dans différentes les montants. Par exemple, ils peuvent correspondre parfaitement, ou être très différents (même si les classes sont différentes, elles peuvent toujours représenter la même information et être notées identiques.)
Maintenant, étant donné deux collections, une de A et une de B , quelle serait la meilleure façon de jumeler les As et les Bs de manière à ce qu'ils soient mieux adaptés, en laissant certains orphelins si la collection est plus grande que l'autre ou si certains As ou Bs sont simplement trop différents pour être appariés ? Ma première tentative a été de créer un tableau à deux dimensions, où chaque cellule était le «score» du match (0 = parfait, avec des nombres plus élevés étant pire) et récursif à travers chaque chemin à la recherche du score accumulé le plus bas. Cela fonctionne et les résultats sont parfaits, mais il est horriblement lent.
Des idées sur des algorithmes plus efficaces?
Dans le cas où vous vous poseriez la question, ma classe A représente un canal d'entrée de mixage audio, et mon B représente l'état persistant de la même chose (appelé une scène). Le problème que j'essaie de résoudre est de savoir comment importer une scène dans une table de mixage existante, où la scène (B) pourrait être légèrement, voire très différente de l'une des voies existantes (A). Je ne veux pas juste ajouter des canaux (A) si je peux légèrement modifier pour correspondre. Par exemple, je pourrais pourrais ajouter un insert d'effet au A afin de correspondre parfaitement avec le B et éviter d'avoir à ajouter une autre A.
Mike