通过更改大小写来置换字符串(不影响数字)

Posted

技术标签:

【中文标题】通过更改大小写来置换字符串(不影响数字)【英文标题】:Permute a string by changing case (without affecting numbers) 【发布时间】:2020-11-16 04:08:34 【问题描述】:

我试图从给定的字符串中获取可能的大小写组合,而不影响字符串中的数字。我目前发现这段代码一直有效,直到您将数字放入序列中。这是我现在正在使用的代码:

<?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); 

?>

“abc1”的示例输出

我怎样才能得到输出:

abc1 Abc1 aBc1 ABc1 abC1 AbC1 aBC1 ABC1

【问题讨论】:

【参考方案1】:

这是一个使用递归函数的选项,将第一个字符的排列与字符串其余部分的所有可能排列组合起来:

/**
 * @param string $str
 * @return string[]
 */
function findAllPermutations(string $str): array

  if ($str === '') 
    return [];
  
  if (strlen($str) === 1) 
    return ctype_digit($str) ? [$str] : [strtolower($str), strtoupper($str)];
  

  $permutations = [];
  foreach (findAllPermutations($str[0]) as $firstCharPermutation) 
    foreach (findAllPermutations(substr($str, 1)) as $restPermutation) 
      $permutations[] = $firstCharPermutation . $restPermutation;
    
  

  return $permutations;

用法:

$permutations = findAllPermutations('abc1');
print_r($permutations);
// or, if you want them separated with a space:
echo implode(' ', $permutations);

Demo

【讨论】:

以上是关于通过更改大小写来置换字符串(不影响数字)的主要内容,如果未能解决你的问题,请参考以下文章

R:删除子字符串并通过添加数字来更改剩余的字符串

211 字符串置换

字符串置换 python3

JSK424:置换的玩笑(搜索)

lintcode入门篇七

Laravel migrate - 列类型字符串不更新大小