java – 使用lambda表达式反转字符串中的单词
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了java – 使用lambda表达式反转字符串中的单词,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1373字,纯文字阅读大概需要2分钟。
内容图文
所以我正在做一些标准的编程面试问题,并遇到了这个问题:
Reverse words in a string (words are separated by one or more spaces)
我认为使用lambda表达式来做它会很有趣,但我发现很难做到正确而且我的解决方案感觉有点笨拙和hacky.所以现在我的问题是:是否有比我更惯用的解决方案?
public static String reverseWordsInString(String str)
{
StringBuilder sb = new StringBuilder();
Stream.of(str.split(" ")).forEach(
word -> sb.append(reverseWord(word, !str.endsWith(word)))
);
return sb.toString();
}
public static String reverseWord(String str, boolean trailingSpace)
{
StringBuilder sb = new StringBuilder();
for(int i = str.length() - 1; i >= 0; i--)
{
sb.append(str.charAt(i));
}
sb.append(trailingSpace ? " " : "");
return sb.toString();
}
解决方法:
你的任务描述有点含糊不清.我无法识别你是否必须扭转单词或反转单词的字符.但这里有两种解决方案:
public static String reverseWordsInString(String str) {
return String.join(" ", Pattern.compile(" +").splitAsStream(str)
.collect(LinkedList::new, LinkedList::addFirst, (a,b)->a.addAll(0, b)));
}
public static String reverseWordCharacters(String str) {
return Pattern.compile(" +").splitAsStream(str)
.map(word->new StringBuilder(word).reverse())
.collect(Collectors.joining(" "));
}
第一个将反转一个字符串的单词,因此reverseWordsInString(“这是一个例子”)将返回示例一个是这个,第二个将反转每个单词的字符,所以reverseWordCharacters(“这是一个例子”)产生siht si na elpmaxe.
内容总结
以上是互联网集市为您收集整理的java – 使用lambda表达式反转字符串中的单词全部内容,希望文章能够帮你解决java – 使用lambda表达式反转字符串中的单词所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。