Pregunta

Estoy trabajando en un proyecto en el que necesito recorrer letras como esta: a, A, b, B ... z, Z, aa, Aa, aA, AA, bb ... zz, ZZ... en PHP.

¿Es posible hacer esto de forma escalable?

¿Fue útil?

Solución

¿No estás seguro de que sea esto lo que estás buscando?

$low = $low2 = range('a', 'z');
$upp = $upp2 = range('A', 'Z');

$arr = array();
foreach ($low as $val)
{
  $arr[] = $val;
  foreach ($low2 as $lval)
  {
    $arr[] = $val.$lval;
  }
}

foreach ($upp as $val)
{
  $arr[] = $val;
  foreach ($upp2 as $uval)
  {
    $arr[] = $val.$uval;
  }
}

foreach ($low as $val)
{
  foreach ($upp as $uval)
  {
    $arr[] = $val.$uval;
  }
}

foreach ($upp as $val)
{
  foreach ($low as $lval)
  {
    $arr[] = $val.$lval;
  }
}

Otros consejos

Calcular permutaciones es una tarea bastante pesada.Esto lo hará específicamente para su caso de calcular dos permutaciones de caracteres del conjunto que contiene todas las letras mayúsculas y minúsculas (no he probado la función, pero debería poder averiguar qué está haciendo y corregir cualquier error,empezar al menos).

function permutations($items)
{
  empty($items)?return array():$perms = array();
  for ($i = count($items)-1; $i > 0; --$i)
  {
    $perms[] = $items[0].$items[$i];
  }
  return array_merge($perms, permutations(array_slice($items,1)));
}

$lowercase y $uppercase son matrices que contienen los valores ASCII para a-z y A-Z, respectivamente.

Modifique según sea necesario.

<?php

    $lowercase = array(97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113, 114, 115, 116, 117, 118, 119, 120, 121, 122);

    $uppercase = array(65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90);

    $i = 0;
    for($i; $i < 26; $i++) {
        echo chr($lowercase[$i]) . ", ";
        echo chr($uppercase[$i]) . ", ";
    }

    $i = 0;
    for($i; $i < 26; $i++) {
        echo chr($lowercase[$i]);
        echo chr($lowercase[$i]);
        echo ", ";
        echo chr($uppercase[$i]);
        echo chr($lowercase[$i]);
        echo ", ";
        echo chr($lowercase[$i]);
        echo chr($uppercase[$i]);
        echo ", ";
        echo chr($uppercase[$i]);
        echo chr($uppercase[$i]);
        echo ", ";
    }

?>

Así es como se ve el resultado:

a, A, b, B, c, C, d, D, e, E, f, F, g, G, h, H, i, I, j, J, k, K, l, L, m, M, n, N, o, O, p, P, q, Q, r, R, s, S, t, T, u, U, v, V, w, W, x, X, y, Y, z, Z, aa, Aa, aA, AA, bb, Bb, bB, BB, cc, Cc, cC, CC, dd, Dd, dD, DD, ee, Ee, eE, EE, ff, Ff, fF, FF, gg, Gg, gG, GG, hh, Hh, hH, HH, ii, Ii, iI, II, jj, Jj, jJ, JJ, kk, Kk, kK, KK, ll, Ll, lL, LL, mm, Mm, mM, MM, nn, Nn, nN, NN, oo, Oo, oO, OO, pp, Pp, pP, PP, qq, Qq, qQ, QQ, rr, Rr, rR, RR, ss, Ss, sS, SS, tt, Tt, tT, TT, uu, Uu, uU, UU, vv, Vv, vV, VV, ww, Ww, wW, WW, xx, Xx, xX, XX, yy, Yy, yY, YY, zz, Zz, zZ, ZZ,

Este código escribe una línea con elementos de 1 carácter de ancho, luego otra con 2 caracteres de ancho, etc.

Para cada ancho, imprime todas las permutaciones iterando las letras y contando de 0 a 2 ^ de ancho y capitalizando en función de bits binarios.

e.g.
  00 = aa
  01 = aA
  10 = Aa
  11 = AA

(actually I have iterated bits from lowest to highest rank to get the order to match your example)

El código:

$maxwidth = 3;
for ( $width = 1; $width <= $maxwidth; $width++ ) {
    for ( $letter = ord('a'); $letter <= ord('z'); $letter++ ) {
        for ( $num = 0; $num < pow(2,$width); $num++ ) {
            for ( $bit = 0; $bit < $width; $bit++ ) {
                print ($num & pow(2, $bit)) ? strtoupper(chr($letter)) : chr($letter);  
            }
            print ','; 
        }
    }
    print "\n";
}

salida:

a, A, b, B, c, C, d, D, e, E, f, F, g, G, h, H, i, I, j, J, k, K, l, L , m, M, n, N, o, O, p, P, q, Q, r, R, s, S, t, T, u, U, v, V, w, W, x, X, y , Y, z, Z, aa, Aa, aA, AA, bb, Bb, bB, BB, cc, Cc, cC, CC, dd, Dd, dD, DD, ee, Ee, eE, EE, ff, Ff, fF, FF, gg, Gg, gG, GG, hh, Hh, hH, HH, ii, Ii, iI, II, jj, Jj, jJ, JJ, kk, Kk, kK, KK, ll, Ll, lL, LL, mm, Mm, mM, MM, nn, Nn, nN, NN, oo, Oo, oO, OO, pp, Pp, pP, PP, qq, Qq, qQ, QQ, rr, Rr, rR, RR, ss, Ss, sS, SS, tt, Tt, tT, TT, uu, Uu, uU, UU, vv, Vv, vV, VV, ww, Ww, wW, WW, xx, Xx, xX, XX, yy, Yy, yY, YY, zz, Zz, zZ, ZZ, aaa, Aaa, aAa, AAa, aaA, AaA, aAA, AAA, bbb, Bbb, bBb, BBb, bbB, BbB, bBB, BBB, ccc, Ccc, cCc, CCc, ccC, CcC, cCC, CCC, ddd, Ddd, dDd, DDd, ddD, DdD, dDD, DDD, eee, Eee, eEe, EEe, eeE, EeE, eEE, EEE, fff, Fff, fFf, FFf, ffF, FfF, fFF, FFF, ggg, Ggg, gGg, GGg, ggG, GgG, gGG, GGG, hhh, Hhh, hHh, HHh, hhH, HhH, hHH, HHH, iii, Iii, iIi, IIi, iiI, IiI, iII, III, jjj, Jjj, jJj, JJj, jjJ, JjJ, jJJ, JJJ, kkk, Kkk, kKk, KKk, kkK, KkK, kKK, KKK, lll, Lll, lLl, LLl, llL, LlL, lLL, LLL, mmm, Mmm, mMm, MMm, mmM, MmM, mMM, MMM, nnn, Nnn, nNn, NNn, nnN, NnN, nNN, NNN, ooo, Ooo, oOo, OOo, ooO, OoO, oOO, OOO, ppp, Ppp, pPp, PPp, ppP, PpP, pPP, PPP, qqq, Qqq, qQq, QQq, qqQ, QqQ, qQQ, QQQ, rrr, Rrr, rRr, RRr, rrR, RrR, rRR, RRR, sss, Sss, sSs, SSs, ssS, SsS, sSS, SSS, ttt, Ttt, tTt, TTt, ttT, TtT, tTT, TTT, uuu, Uuu, uUu, UUu, uuU, UuU, uUU, UUU, vvv, Vvv, vVv, VVv, vvV, VvV, vVV, VVV, www, Www, wWw, WWw, wwW, WwW, wWW, WWW, xxx, Xxx, xXx, XXx, xxX, XxX, xXX, XXX, yyy, Yyy, yYy, YYy, yyY, YyY, yYY, YYY, zzz, Zzz, zZz, ZZz, zzZ, ZzZ, zZZ, ZZZ,

Seguro.Los caracteres alfabéticos se pueden incrementar con solo $a++.En aras de la simplicidad, si solo se necesita un conjunto de longitud simple o doble, puede hacerlo ...

$single_set = array(); // array holding single-character sequence
$double_set = array(); // array holding double-character sequence

for ($v1 = 'a', $v2 = 'A'; $v1 !== 'aa'; $v1++, $v2++) {
    $single_set[] = $v1;
    $single_set[] = $v2;
    $double_set[] = $v1 . $v1;
    $double_set[] = $v1 . $v2;
    $double_set[] = $v2 . $v1;
    $double_set[] = $v2 . $v2;
    }

$set = $single_set + $double_set; // combined array sequence
Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top