Java中如何检测跨越多行的回文文本

发布时间:2024-11-11 17:29:47 作者:小樊
来源:亿速云 阅读:79

在Java中,要检测跨越多行的回文文本,可以使用正则表达式和Pattern和Matcher类

import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class MultilinePalindrome {
    public static void main(String[] args) {
        String input = "这是一个\n跨\n行\n的\n回文\n文本";
        System.out.println("输入文本: " + input);
        System.out.println("检测到的回文: " + isMultilinePalindrome(input));
    }

    public static boolean isMultilinePalindrome(String input) {
        // 正则表达式匹配任意空白字符(包括换行符)
        String regex = "\\s*";

        // 将输入文本按行分割
        String[] lines = input.split("(?m)");

        // 遍历每一行,检查是否为回文
        for (String line : lines) {
            String trimmedLine = line.trim();
            if (!trimmedLine.isEmpty() && !isPalindrome(trimmedLine)) {
                return false;
            }
        }

        return true;
    }

    public static boolean isPalindrome(String input) {
        Pattern pattern = Pattern.compile(regex);
        Matcher matcher = pattern.matcher(input);

        // 移除所有空白字符(包括换行符)
        input = matcher.replaceAll("");

        int left = 0;
        int right = input.length() - 1;

        while (left < right) {
            if (input.charAt(left) != input.charAt(right)) {
                return false;
            }
            left++;
            right--;
        }

        return true;
    }
}

这个程序首先将输入文本按行分割,然后检查每一行是否为回文。isPalindrome方法使用正则表达式移除所有空白字符(包括换行符),然后检查字符串是否为回文。

推荐阅读:
  1. 谷歌:Oracle Java 胜诉将杀死软件开发,要求美最高法院必须作出裁决!
  2. 如何以Java的视角来进行SQL注入

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

java

上一篇:Java回文串检测与字符串去重的结合

下一篇:Java回文串检测在代码审查中的应用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》