Listado de combinaciones (Microsoft Excel)
Ron sabe que puede usar la función COMBINAR para determinar el número de combinaciones que se pueden hacer a partir de varios dígitos. Sin embargo, se pregunta si hay una manera de enumerar todas las combinaciones.
No hay una forma incorporada de enumerar combinaciones en Excel. Sin embargo, puede crear una macro para hacer la lista por usted. Si desea encontrar las combinaciones únicas en un conjunto de números secuenciales que comienzan en 1, entonces el siguiente conjunto de macros funcionará. Todo lo que necesita hacer es ejecutar la función TestCNR y terminará con una «matriz» de celdas que representan el número de combinaciones de 4 dígitos en el conjunto secuencial de valores que van del 1 al 10.
Sub TestCNR() Cnr 10, 4 End Sub
Sub Cnr(n, r) i = 1 For j = 1 To r Cells(i, j).Value = j Next Do Until Finished(n, r, i) j = FindFirstSmall(n, r, i) For k = 1 To j — 1 Cells(i + 1, k).Value = Cells(i, k).Value Next Cells(i + 1, j).Value = Cells(i, j).Value + 1 For k = j + 1 To r Cells(i + 1, k).Value = Cells(i + 1, k - 1).Value + 1 Next i = i + 1 Loop End Sub
Function Finished(n, r, i) Temp = True For j = r To 1 Step -1 If Cells(i, j).Value <> j + (n - r) Then Temp = False End If Next Finished = Temp End Function Function FindFirstSmall(n, r, i) j = r Do Until Cells(i, j).Value <> j + (n - r) j = j - 1 Loop FindFirstSmall = j End Function
La macro sobrescribe lo que esté en su hoja de trabajo, así que asegúrese de ejecutar la prueba mostrando una hoja de trabajo en blanco. Si desea cambiar el tamaño del conjunto o el número de elementos en el subconjunto, simplemente cambie los valores pasados en la rutina TestCNR.
Si desea extraer combinaciones únicas de una cadena de caracteres (por ejemplo, las letras del alfabeto), debe utilizar un conjunto diferente de macros. Lo siguiente funcionará bien; asume que los caracteres que desea usar como su «universo» están en la celda A1 y el número que desea en cada combinación única está en la celda A2.
Sub FindSets() Dim iA() As Integer Dim sUniv As String Dim iWanted As Integer Dim j As Integer Dim k As Integer sUniv = Cells(1, 1).Value iWanted = Cells(2, 1).Value ReDim iA(iWanted) For j = 1 To iWanted iA(j) = j Next j iRow = PutRow(iA, sUniv, 1) Do Until DoneYet(iA, Len(sUniv)) j = WorkHere(iA, Len(sUniv)) iA(j) = iA(j) + 1 For k = j + 1 To iWanted iA(k) = iA(k - 1) + 1 Next k iRow = PutRow(iA, sUniv, iRow) Loop End Sub
Function DoneYet(iB, n) As Boolean iMax = UBound(iB) Temp = True For j = iMax To 1 Step -1 If iB(j) <> j + (n - iMax) Then Temp = False End If Next DoneYet = Temp End Function
Function WorkHere(iB, n) As Integer iMax = UBound(iB) j = iMax Do Until iB(j) <> j + (n - iMax) j = j - 1 Loop WorkHere = j End Function
Function PutRow(iB, sUniv, i) iMax = UBound(iB) sTemp = "" For j = 1 To iMax sTemp = sTemp & Mid(sUniv, iB(j), 1) Next j Cells(i, 2).Value = sTemp PutRow = i + 1 End Function
Ejecute la macro FindSets y las diferentes combinaciones deseadas terminan en la columna 2. Sin embargo, tenga cuidado al ejecutar la macro. El número de combinaciones puede aumentar muy rápidamente. Por ejemplo, si coloca 26 letras (de la A a la Z) en la celda A1 y el valor 5 en la celda A2, la macro se bloqueará. ¿Por qué? Porque hay 65.780 combinaciones posibles de cinco caracteres y solo 65.536 filas en las que colocarlas.
_Nota: _
Si desea saber cómo usar las macros descritas en esta página (o en cualquier otra página de los sitios ExcelTips), he preparado una página especial que incluye información útil.
link: / excelribbon-ExcelTipsMacros [Haga clic aquí para abrir esa página especial en una nueva pestaña del navegador]
.
ExcelTips es su fuente de formación rentable en Microsoft Excel.
Este consejo (6766) se aplica a Microsoft Excel 97, 2000, 2002 y 2003. Puede encontrar una versión de este consejo para la interfaz de cinta de Excel (Excel 2007 y posterior) aquí:
link: / excelribbon-Listing_Combinations [Combinaciones de listados]
.