加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

练习三:字符串倒置

发布时间:2020-12-13 20:15:32 所属栏目:百科 来源:网络整理
导读:字符串比如“ad2 lsdkf,lksdjf. sdkfj”倒序排列"sdkfj lksdjf. lsdkf,ad2" 每个单词是空格分开,标点符号当作字母,不能用String的自带的一些方法,比如indexof,trim,split等方法。 public static void myConvert(String source) {char[] tmpArray = source.

字符串比如“ad2 lsdkf,lksdjf. sdkfj”倒序排列"sdkfj lksdjf. lsdkf,ad2" 每个单词是空格分开,标点符号当作字母,不能用String的自带的一些方法,比如indexof,trim,split等方法。

public static void myConvert(String source) {

		char[] tmpArray = source.toCharArray();

		StringBuffer out = new StringBuffer();
		StringBuffer tmp = new StringBuffer();
		for (int index = tmpArray.length - 1; index >= 0; index--) {
			if (tmpArray[index] == ' ') {
				out.append(" ");
				tmp.append(out);
				out.delete(0,out.length());
			} else {
				out.insert(0,tmpArray[index]);
			}
		}
		tmp.append(out);
		System.out.println(tmp.toString());

	}

使用了2个StringBuffer,有些笨重。下面的比较轻巧。


	public static void reverseString(String source) {
		
		char[] cTemp = source.toCharArray();
		String newString = "";
		String sTemp = "";
		for (int i = cTemp.length - 1; i >= 0; i--) {
			if (cTemp[i] == ' ') {
				newString += sTemp + cTemp[i];
				sTemp = "";
			} else {
				sTemp = cTemp[i] + sTemp;
			}
		}
		newString += sTemp;
		System.out.println(newString);
	}

这个程序是找别人的,很是轻巧学习。


此题源地址:http://www.iteye.com/topic/786985

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读