关于n个元素的向量x向左移动位得问题(原问题来自于编程珠玑)

来源:互联网 发布:apache php版本 编辑:程序博客网 时间:2024/05/16 09:52

例如:abcdefgh 向左移三位 变成  defghabc


此问题我们在空间复杂度为1得情况下,可以使用下面得解决方法。

把这个问题看成是数组ab转换成数组ba


ab---(转置a)-》a^b---(转置b)-》a^b^---(整体转置)-》ba


如下过程

1 reverse(0,i-1)          /*cbadefgh*/

2 reverse(i,n-1)             /*cbahgfed*/

3 reverse(0,n-1)           /*defghabc*/


原创粉丝点击