随笔 - 361,  文章 - 0,  评论 - 62,  阅读 - 160万

题目描述:对字符串中的所有单词进行倒排。

说明:

1、每个单词是以26个大写或小写英文字母构成,可以用一个“-”中连接线连接单词两部分表示一个单词,但是仅限一个“-”,出现两个“--”则为非构成单词的字符;

2、非构成单词的字符均视为单词间隔符;

3、要求倒排后的单词间隔符以一个空格表示;如果原字符串中相邻单词间有多个间隔符时,倒排转换后也只允许出现一个空格间隔符;

4、每个单词最长20个字母;

5、输出字符串,否则输出-1。

样例输入:

i*&* am--a good-student

样例输出:

good-student a am i

代码示例:

复制代码
public class WordReverseOrder {

    public static void main(String[] args) {
        String string = "i*&*am--a good-student";

        String express = "(?!(?<=[a-zA-Z]+)-(?=[a-zA-Z]+))[^a-zA-Z]+";
        String[] strings = string.split(express);

        if (strings.length == 0) {
            System.out.println("-1");
        }else{
            boolean overLength = false;
            StringBuffer stringBuffer = new StringBuffer();
            for (int i = strings.length - 1; i >= 0; i--) {
                if (strings[i].length() > 20) {
                    overLength = true;
                    break;
                }
                if (!"".equals(strings[i].trim())) {
                    stringBuffer.append(strings[i] + " ");
                }
            }
            if (overLength || stringBuffer == null) {
                System.out.println("-1");
            } else {
                System.out.println(stringBuffer.toString().trim());
            }
        }
    }
}
复制代码

 

posted on   kosamino  阅读(502)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示