免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1873 | 回复: 5
打印 上一主题 下一主题

求一个算法 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2012-08-16 15:29 |只看该作者 |倒序浏览
求一个算法 把"ab23de" 变成 "ED32BA",即反转并转为大写,考虑性能
java实现

论坛徽章:
0
2 [报告]
发表于 2012-08-16 15:57 |只看该作者
这样可以么:
public static void reverse(){
   String str = "ab23de";
   char[] arry = str.toCharArray();
   int length = arry.length;
   for(int i=0; i<length/2; i++){
   char tmp = arry[i];
   arry[i] = arry[length-1-i];
  arry[length-i-1] = tmp;
  }
  String result = new String(arry).toUpperCase();
  System.out.println(result);
}

论坛徽章:
0
3 [报告]
发表于 2012-08-16 16:14 |只看该作者
那还还不如 先把String转为StringBuilder,再用StringBuilder中的reverse() 最后再toUpperCase方法回复 2# _emma


   

论坛徽章:
0
4 [报告]
发表于 2012-08-16 18:12 |只看该作者
char rev[] = new char[str.length];
for(int i = 0; i < str.length; ++i) {
    rev[i] = toUpper(str[str.length - i - 1]);
}
String ret = new String(rev);

论坛徽章:
0
5 [报告]
发表于 2012-08-24 16:45 |只看该作者
StringBuilder str = new StringBuilder("ab23de";
str = str.reverse();
System.out.println(str.toString().toUpperCase());

鉴定完毕

论坛徽章:
4
金牛座
日期:2013-10-11 16:12:50卯兔
日期:2014-07-31 09:17:19辰龙
日期:2014-08-08 09:28:02狮子座
日期:2014-09-14 20:32:05
6 [报告]
发表于 2012-08-29 14:15 |只看该作者
>>> 'ab23de'[-1::-1].upper()
'ED32BA'
>>>

不过咱不会java,这个是python的答案。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP