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
    }
}
相关推荐
Mahir081 小时前
Spring 循环依赖深度解密:从问题本质到三级缓存源码级解析
java·后端·spring·缓存·面试·循环依赖·三级缓存
杜子不疼.1 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号31 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia2 小时前
Qt——编辑交互功能的实现
开发语言·qt
RyFit2 小时前
SpringAI 常见问题及解决方案大全
java·ai
石山代码2 小时前
C++ 内存分区 堆区
java·开发语言·c++
绝知此事2 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海3 小时前
C# 隐式转换深度解析
java·开发语言·c#
一只大袋鼠3 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git
LuminousCPP4 小时前
数据结构 - 线性表第四篇:C 语言通讯录优化升级全记录(踩坑 + 思考)
c语言·开发语言·数据结构·经验分享·笔记·学习