I am trying to get all possible upper and lower case combinations from a given string, without affecting numbers in said string. I currently found this piece of code that works until you put a number into the sequence:
<?php
if (isset($_GET['word'])) {
$word = $_GET["word"];
function permute($input){
$n = strlen($input);
$max = 1 << $n;
$input = strtolower($input);
for($i = 0; $i < $max; $i++)
{
$combination = $input;
for($j = 0; $j < $n; $j++)
{
if((($i >> $j) & 1) == 1)
$combination[$j] = chr(ord($combination[$j]) - 32);
}
echo $combination . " ";
}
}
permute($word);
}
?>
Output of abc1
:
Expected output:
abc1 Abc1 aBc1 ABc1 abC1 AbC1 aBC1 ABC1
Here's one option using a recursive function, combining permutations for the first character with all possible permutations for the rest of the string:
Usage:
Demo