java字符串反转

    今天去一个万人大企业面试java被问到了字符串的反转,由于时间原因,当时没有及时的想出来,回家后,想到了至少有两种实现方式。

    故封装成了两个通用接口,留给自己和他人使用和参考。经过多次测试没有问题,如果是短字符串反转完全可以复制粘贴拿去用。

使用两个数组加循环的解决方案(复制粘贴可直接使用):

	public static String reverseString(String string) {
		char[] oldChars = string.toCharArray();
		char[] newChars = new char[oldChars.length];

		for (int i = oldChars.length - 1; i >= 0; i--) {
			newChars[i] = oldChars[oldChars.length-1-i];
		}
		
		return new String(newChars);
	}

    这种实现方式是效率比较快的,它不需要一个中间变量,用来在项目中做短字符串的反转完全没有问题。

    机智的我马上联想到了堆栈数据结构,因为堆栈是LIFO的容器,这种特性不是正好可以做字符串反转吗!

使用堆栈加循环的解决方案(复制粘贴可直接使用):

public static String reverseString(String string) {
		char[] oldChars = string.toCharArray();
		char[] newChars = new char[oldChars.length];
		Stack<Character> stack = new Stack<>();
		
		for (int i = 0; i < oldChars.length; i++) {
			stack.push(oldChars[i]);
		}
		
		for (int i = 0; i < oldChars.length; i++) {
			newChars[i] = stack.pop();
		}
		
		return new String(newChars);
	}

通过长度为500的字符串循环1000次的方法调用,结果显示第一种方法要比第二种方法快约五倍

第一种:执行时间10毫秒左右
第二种:执行时间50毫秒左右

所以大家知道该怎么做了吧!😃

码字不易,点赞,评论,转发吧!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值