
En Unix, estoy intentando crear todas las combinaciones posibles de estas letras en 6 posiciones específicas de la siguiente manera:
- Posición 1 - A o B o C
- Posición 2 - A o C
- Posición 3 - sólo C
- Posición 4 - A o D
- Posición 5 - B o C
- Posición 6 - C o A
Así, por ejemplo, las combinaciones podrían ser AACABC, BACABC,...
¿Existe alguna manera rápida de que las herramientas UNIX puedan hacer esto?
Respuesta1
Los requisitos corresponden a la expansión de la riostra.
{A,B,C}{A,C}C{A,D}{B,C}{C,A}
Esto se expande a 48 cadenas (48 = 3*2*1*2*2*2):
$ printf '%s\n' {A,B,C}{A,C}C{A,D}{B,C}{C,A}
AACABC
AACABA
AACACC
AACACA
AACDBC
AACDBA
AACDCC
AACDCA
ACCABC
ACCABA
ACCACC
ACCACA
ACCDBC
ACCDBA
ACCDCC
ACCDCA
BACABC
BACABA
BACACC
BACACA
BACDBC
BACDBA
BACDCC
BACDCA
BCCABC
BCCABA
BCCACC
BCCACA
BCCDBC
BCCDBA
BCCDCC
BCCDCA
CACABC
CACABA
CACACC
CACACA
CACDBC
CACDBA
CACDCC
CACDCA
CCCABC
CCCABA
CCCACC
CCCACA
CCCDBC
CCCDBA
CCCDCC
CCCDCA
Respuesta2
Eso suena como un trabajo para for
bucles anidados:
#!/bin/bash
for p1 in A B C; do
for p2 in A C; do
for p3 in C; do
for p4 in A D; do
for p5 in B C; do
for p6 in C A; do
echo "$p1$p2$p3$p4$p5$p6"
done
done
done
done
done
done
Puede haber herramientas externas que hagan esto más elegante, pero esta forma es "100% bash" y, por lo tanto, bastante portátil.