汇编语言中有一种移位指令叫做循环左移(ROL),现在有个简单的任务,就是用字符串模拟这个指令的运算结果。对于一个给定的字符序列S,请你把其循环左移K位后的序列输出。例如,字符序列S=”abcXYZdef”,要求输出循环左移3位后的结果,即“XYZdefabc”。是不是很简单?OK,搞定它! 1.字符串翻转,前n位取模长度,abc翻转成cba 后面的翻转成fedXYX ,然后再统一翻转 XYZdefabc 2.第二种思路,字符串复制一份拼接在一起,截取从n开始到len长度的子字符串,n也是要取模
<?php function LeftRotateString($str,$n){ $len=strlen($str); $n=$n%$len; swap($str,0,$n-1); swap($str,$n,$len-1); swap($str,0,$len-1); return $str; } function swap(&$str,$start,$end){ while($start<$end){ $temp=$str{$start}; $str{$start++}=$str{$end}; $str{$end--}=$temp; } } $a="abcAbce"; $s=LeftRotateString($a,13); var_dump($s);