将一个字符串反转的方式

        首先要先介绍一下如何将两个字母,不借助额外的空间做到交换。

        如下所示,提供两种方式:

private static void swap1(char a,char b){
		 System.out.println("a is: "+a);
		 System.out.println("b is: "+b);

		 a=(char) (a+b);
		 b=(char) (a-b);
		 a=(char) (a-b);
		 
		 System.out.println("a is: "+a);
		 System.out.println("b is: "+b);
	 }
	 
	 private static void swap2(char a,char b){
		 System.out.println("a is: "+a);
		 System.out.println("b is: "+b);

		 a=(char) (a^b);
		 b=(char) (a^b);
		 a=(char) (a^b);
		 
		 System.out.println("a is: "+a);
		 System.out.println("b is: "+b);
	 }

 接下来看看其中反转字符串的方法:

//第一种巧妙地使用递归
private static String reverse1(String str){
		 int length=str.length();
		 if(length<=1)	return str;
		 String left=str.substring(0, length/2);
		 String right=str.substring(length/2,length);
		 
		 return reverse1(right)+reverse1(left);
	 }
	
// 第二种将字符向前插入
	 private static String reverse2(String str){
		 int length=str.length();
		 String reverse="";
		 for(int i=0;i<length;i++){
			 reverse=str.charAt(i)+reverse;
		 }
		 return reverse;
	 }
	 
	 private static String reverse22(String str){
		 int length=str.length();
		 StringBuilder reverse=new StringBuilder();
		 for(int i=0;i<length;i++){
			 //每次在0位置插入,StringBuilder中的元素会自动后移??
			 reverse.insert(0, str.charAt(i));
		 }
		 return reverse.toString();
	 }
	//第三种从后到前添加字符 
	 private static String reverse3(String str){
		 int length=str.length();
		 String reverse="";
		 for(int i=length-1;i>=0;i--){
			 reverse=reverse+str.charAt(i);
		 }
		 return reverse;
	 }
	 
	 private static String reverse33(String str){
		 int length=str.length();
		 StringBuilder reverse=new StringBuilder();
		 for(int i=length-1;i>=0;i--){
			 reverse.append( str.charAt(i));
		 }
		 return reverse.toString();
	 }
	 //毫无创意
	 private static String reverse4(String str){
		 StringBuilder stringBuilder=new StringBuilder(str);
		 return stringBuilder.reverse().toString();
	 }
	 //第五种:一分为二,左右互换
	 private static String reverse5(String str){
		 char temp;
		 int length=str.length();
		 char[] array=str.toCharArray();
		 for(int i=0;i<(length-1)/2;i++){
			 temp=array[i];
			 array[i]=array[length-1-i];
			 array[length-1-i]=temp;
		 }
		 return new String(array);
	 }
	 //第六种,使用util包中的Stack
	 private static String reverse6(String str){
		 char[] array=str.toCharArray();
		 Stack<Character> stack=new Stack<Character>();
		 for(int i=0;i<str.length();i++){
			 stack.push(array[i]);
		 }
		 String reverse="";
		 for(int i=0;i<str.length();i++){
			 reverse=reverse+stack.pop();
		 }
		 return reverse;
	 }
	 //第七种,从两头开始互换,向中间推进
	 public static String reverse7(String s) {
		 
		   char[] str = s.toCharArray();
		 
		   int begin = 0;
		 
		   int end = s.length() - 1;
		
		   

		   while (begin < end) {
		 
		    str[begin] = (char) (str[begin] ^ str[end]);
		 
		    str[end] = (char) (str[begin] ^ str[end]);
		 
		    str[begin] = (char) (str[end] ^ str[begin]);
		 
		    begin++;
		 
		    end--;
		 
		   }
		 
		   
		 
		   return new String(str);
		 
		  }

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值