lintcode8 - rotate string - easy

Given a string and an offset, rotate string by offset. (rotate from left to right)
Example
Given “abcdefg”.
offset=0 => “abcdefg”
offset=1 => “gabcdef”
offset=2 => “fgabcde”
offset=3 => “efgabcd”
Challenge
Rotate in-place with O(1) extra memory.

三步反转法。
如果点a是length -1 - offset那个index,反转[0, a],反转[a+1, end],反转[0,end]

细节:
一开始对offset做一个offset = offset % length的处理,可以避免算index越界。 %是求余运算

```java
public class Solution{
	public char[] rotateString(char[],int offset){
		if(A==null||A.length==0){
			return A;
		}
		offset=offset%A.length;
		
		reverse(A,0,A.length-offset-1);
		reverse(A,A.length-offset,A.length-1);
		reverse(A,0,A.length-1);
	}	
	private void reverse(char[],int start,int end){
		for(int i=start,j=end;i<j;i++;j--){
			char tmp=A[i];
			A[i]=A[j];
			A[j]=tmp;
		}
	}
	
}
		
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值