汇编语言中有一种移位指令叫做循环左移(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);
如对本文有疑问, 点击进行留言回复!!
php 使用 yansongda/pay 进行微信,支付宝支付
Codeforces Round #658 (Div. 2) (C1、C2)
van-uploader + thinkphp6.0 图片上传
网友评论