我正在尝试弄清楚如何使用每个 x 位置重新排列字符串,以便示例输入字符串“ABCDEFGHI”和 x 为 4 会产生 DHCIFEGBA。我是这样得到的:
第一个字母很简单:它是字符 4。[A, B, C, D]
第二个字母也很简单:它是字符 8。[E, F, G, H]
第 3 个字母很简单:它是字符 3。发生这种情况是因为我边数边绕了一圈,所以我使用了 I、A、B、C。
第 4 个字母是比较棘手的地方:它是字符 9。因为 D 和 H 已经消失,所以它们不会用于计数,导致 E、F、G、I。
字母 #5 遵循相同的模式,跳过 C 和 D:A、B、E、F
字母 #6 有跳过和换行:G、A、B、E。
字母 #7 再次换行:G、A、B、G。
字母 #8 也换行(技术上两次,因为之前“光标”在 G 后面:A、B、A、B
字母 #9 是我们的余数:A, A, A, A
显然需要循环直到输出字符串长度与输入字符串长度相匹配——中间的所有这些困惑(主要是跳过和循环)我一辈子都弄不明白。
感谢任何帮助或指导。
最佳答案
在独特的范围内完美工作,但在 ABCDEAFGHAI 之类的情况下会失败
$s = 'ABCDEFGHI';
$_len = strlen($s);
$out = '';
$c = 3;
echo '<pre>';
while ( $_len > 0 ) {
echo strlen($s) , ' :: '. $s . "\n";
$term = $s[$c-1];
list($a,$b) = explode($term, $s);
$s = $b.$a;
$x = strlen($s);
if($x <= $c) {
for($i=0; $i<($c-$x);$i++)
$s .= $s;
}
$out .= $term;
$_len--;
}
echo "\n\n\n" , $out;
输出:
9 :: ABCDEFGHI
8 :: EFGHIABC
7 :: IABCEFG
6 :: EFGIAB
5 :: ABEFG
4 :: GABE
6 :: GABGAB
4 :: ABAB
4 :: AAAA
DHCIFEGBA
一个有希望的更好的解决方案
function rearrangeString($string, $step = 4) {
$output = '';
$lenght = strlen($string);
if($step >= $lenght) {
return strrev($string);
} elseif($step < 1) {
return $string;
} else {
for($i=0; $i < $lenght; $i++) {
$_tempLen = strlen($string);
$output .= $string[$step-1];
list($a,$b) = explode($string[$step-1], $string);
$string = $b . $a;
$_tempLen = strlen($string);
if($step > $_tempLen) {
$string = str_repeat($string, $step-$_tempLen+1);
}
unset($_tempLen, $a, $b);
}
return $output;
}
}
$rearranged = rearrangeString('ABCDEFGHI');
var_dump($rearranged == 'DHCIFEGBA');
$rearranged = rearrangeString('ABCDEFGHI', 9);
var_dump($rearranged == 'IHGFEDCBA');
$rearranged = rearrangeString('ABCDEFGHI', 1);
var_dump($rearranged == 'ABCDEFGHI');
$rearranged = rearrangeString('ABCDEFGHI', 3);
var_dump($rearranged == 'CFIDHEBGA');
$rearranged = rearrangeString('ABCDEFGHI', 6);
var_dump($rearranged == 'FCAIBEHD');
$rearranged = rearrangeString('FARBE', 2);
var_dump($rearranged == 'ABFER');
关于php - 使用 PHP 使用每个 x 字母位置重新排列字符串,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3969601/