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
    }
}
相关推荐
皮皮林5519 小时前
Java性能调优黑科技!1行代码实现毫秒级耗时追踪,效率飙升300%!
java
冰_河9 小时前
QPS从300到3100:我靠一行代码让接口性能暴涨10倍,系统性能原地起飞!!
java·后端·性能优化
桦说编程12 小时前
从 ForkJoinPool 的 Compensate 看并发框架的线程补偿思想
java·后端·源码阅读
躺平大鹅13 小时前
Java面向对象入门(类与对象,新手秒懂)
java
初次攀爬者14 小时前
RocketMQ在Spring Boot上的基础使用
java·spring boot·rocketmq
花花无缺14 小时前
搞懂@Autowired 与@Resuorce
java·spring boot·后端
Derek_Smart16 小时前
从一次 OOM 事故说起:打造生产级的 JVM 健康检查组件
java·jvm·spring boot
NE_STOP17 小时前
MyBatis-mybatis入门与增删改查
java
孟陬20 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端