
No Unix, estou tentando criar todas as combinações possíveis dessas letras em 6 posições específicas, como segue:
- Posição 1 - A ou B ou C
- Posição 2 - A ou C
- Posição 3 - apenas C
- Posição 4 - A ou D
- Posição 5 - B ou C
- Posição 6 - C ou A
Assim, por exemplo, as combinações poderiam ser AACABC, BACABC,...
Existe uma maneira rápida de como as ferramentas UNIX podem fazer isso?
Responder1
Os requisitos correspondem à expansão da cinta
{A,B,C}{A,C}C{A,D}{B,C}{C,A}
Isso se expande para 48 strings (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
Responder2
Isso parece um trabalho para for
loops aninhados:
#!/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
Pode haver ferramentas externas que tornam isso mais elegante, mas desta forma é "100% bash" e, portanto, bastante portátil.