JAVA工具类匹配重复或者连续的字符和符号

java 复制代码
import java.util.ArrayList;
import java.util.List;

public class StringChecker {
    static String SYMBOLS = "~!@#$%^&*()_+{}|<>?,./";
    static List<String> symbolSubstrings = splitStringIntoSubstrings(SYMBOLS, 3);

    /**
     * 检查字符串是否包含重复或递增的字符
     *
     * @param str 要检查的字符串
     * @return 如果字符串包含重复或递增的字符,则返回true;否则返回false
     */
    public static boolean containsRepeatingOrIncrementalChars(String str) {
        int length = str.length();
        if (length < 3) {
            return false;
        }
        int[] asciiArray = convertToAsciiArray(str);

        for (int i = 0; i < asciiArray.length; i++) {
            if (i >= asciiArray.length - 2) {
                break;
            }
            int current = asciiArray[i];
            int next = asciiArray[i + 1];
            int afterNext = asciiArray[i + 2];
            // 校验重复或递增的数字或字母
            if ((next == current + 1 && afterNext == next + 1) || (current == next && next == afterNext)) {
                return true;
            }
        }

        for (String symbol : symbolSubstrings) {
            if (str.contains(symbol)) {
                return true;
            }
        }
        return false;
    }

    /**
     * 将字符串按指定长度拆分成子串
     *
     * @param str             要拆分的字符串
     * @param substringLength 子串的长度
     * @return 拆分后的子串列表
     */
    public static List<String> splitStringIntoSubstrings(String str, int substringLength) {
        List<String> substrings = new ArrayList<>();

        for (int i = 0; i < str.length(); i++) {
            if (i + substringLength > str.length()) {
                break;
            }
            int endIndex = Math.min(i + substringLength, str.length());
            String substring = str.substring(i, endIndex);
            substrings.add(substring);
        }

        return substrings;
    }

    /**
     * 将字符串转换为ASCII码数组
     *
     * @param str 要转换的字符串
     * @return ASCII码数组
     */
    public static int[] convertToAsciiArray(String str) {
        int[] asciiArray = new int[str.length()];

        for (int i = 0; i < str.length(); i++) {
            asciiArray[i] = (int) str.charAt(i);
        }

        return asciiArray;
    }

    public static void main(String[] args) {
        System.out.println(containsRepeatingOrIncrementalChars("abc3132132"));    // true
        System.out.println(containsRepeatingOrIncrementalChars("123fasfadfas")); // true
        System.out.println(containsRepeatingOrIncrementalChars("!@#dfafa"));      // true
        System.out.println(containsRepeatingOrIncrementalChars("aabc"));          // true
        System.out.println(containsRepeatingOrIncrementalChars("fas12@##"));      // false
    }
}
相关推荐
资生算法程序员_畅想家_剑魔9 分钟前
Java常见技术分享-12-多线程安全-锁机制
java·开发语言
一叶飘零_sweeeet17 分钟前
吃透 Spring 体系结构
java·spring
胡楚昊25 分钟前
NSSCTF动调题包通关
开发语言·javascript·算法
2401_8370885032 分钟前
简要总结 HashSet 和 HashMap(Java)
java·开发语言
毕设源码-钟学长1 小时前
【开题答辩全过程】以 基于Java的家政服务管理系统的设计与实现为例,包含答辩的问题和答案
java·开发语言
小白学大数据1 小时前
Java 爬虫对百科词条分类信息的抓取与处理
java·开发语言·爬虫
zmzb01031 小时前
C++课后习题训练记录Day56
开发语言·c++
编程小Y1 小时前
C++ Insights
开发语言·c++
小c君tt2 小时前
QT中想在QTextEdit控件中使用Qslog日志输出出现问题原因及解决方法
开发语言·qt
Coder_Boy_2 小时前
Spring 核心思想与企业级最佳特性(实践级)事务相关
java·数据库·spring