翻转字符串

题目:

给定一个字符类型的数组chas和一个整数size,请把大小为size的左半区整体移动到右半区,右半区整体移到左边。

举例:

如果把chas看做字符串“ABCDE”,size=3,调整成“DEABC”。

思路:

首先判断该字符串左右移动的距离,取最小的哪一个。举例“1234567ABCD”。需要移动的size是7.即将1234567移动到ABCD的右边变为“ABCD1234567”。
显然右边的size记为right为4比左边的(left)7要小因此先将小的部分移动到左边变为“ABCD5671234”。这样左边的部分就处理完了。接下来需要处理的是“5671234”部分。此时的left就是原先长的部分变为了原先的left-right,此数据为3。右半部分依旧为原先的长度(4)。
在对left(3)和right(4)进行一次比较,这次是左边比较小,因此将左边的3个字符和右边的3个字符进行交换得到“2341567”。由于之前比较的是right部分比较大,因此right向前移动3个字符,下一次需要比较的字符串为“2341”。此时更新后的left和right分别为3和1.
再一次比较right部分比较小,更新字符串变为“1342”。更新后的left和right分别为2和1,下一次需要比较的字符为“342”。
更新新的字符我们得到“243”。因此下一步我分需要比较的字符是“43”,left和right分别变为了1和1.
在进行最后一次字符转换“43”变为了“34”。
由于left-right为0,我们跳出循环整个程序的执行过程结束!

代码:

       /**
	 * 移动字符串操作
	 */
	public char [] moveChar(String str,int size){
		if(str == null || str.length() == 0 || size == 0)
			return null;
		
		char [] chas = str.toCharArray();
		int length = str.length();
		int start = 0;
		int end = chas.length - 1;
		int left = size;
		int right = length - size;
		int gap = Math.min(left, right);
		int d = left - right;
		while(true){
			changeCharacter(chas, start, end, gap);
			
			if(d == 0){
				break;
			}else if(d > 0){
			    start += gap;
			    left = d;
			}else{
				end -= gap;
				right = -d;
			}
			gap = Math.min(left, right);
			d = left - right;
		}
		return chas;
	}
	
	/**
	 * 翻转字符操作
	 */
	public void changeCharacter(char [] chas,int left,int right,int size){
		int index = right - size + 1;
		int i = 0;
		while(i++ < size){
			char temp = chas[left];
			chas[left] = chas[index];
			chas[index] = temp;
			left++;
			index++;
		}
	}





评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值