在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方法使用正则表达式移除所有空白字符(包括换行符),然后检查字符串是否为回文。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。