• 技术文章 >后端开发 >PHP问题

    php判断字符串是否重复

    尚2019-10-29 16:39:57原创2615

    php入门到就业线上直播课:进入学习

    PHP判断字符串是否有重复字符:

    方法一、

    1、将字符串转成字符数组

    2、使用Arrays.sort(char[])对字符数组进行排序,然后,逐个遍历整个排序后的数组,如果不是最后一个字符,并且如果当前字符和其后面的字符相同,那么就直接返回false,否则继续遍历,如果所有的元素和其后面都不相同或者已经遍历到最后一个字符了,就认为是没有重复字符,即返回true

    3、另外,对于null或者长度是0的字符串,没有重复字符,返回true

    方法二、

    创建哈希表,遍历字符串,如果哈希表中不包含该字符,就添加进去,如果包含,就返回false,如果没有重复的字符,那么最后返回true。

    方法三、

    上述两种方法均需要额外开辟空间,如果想不开辟空间,那么可以借助String.indexOf(char ch, int fromIndex),遍历字符串中的字符,遍历到倒数第二个字符即可。对每个字符,判断其后是否有重复的字符即可,如果有就返回false,如果没有重复的字符,那么返回true。

    实现代码:

    public class Solution {
        /*
         * @param str: A string
         * @return: a boolean
         */
        public boolean isUnique(String str) {
            // write your code here
            /*
            //思路一
            //如果str是null,那么抛出异常
            if(str == null){
                throw new IllegalArgumentException("invalid parameters");
            }
            
            //如果str的长度是0或者1,那么没有重复字符,返回true
            if(str.length() == 0 || str.length() == 1){
                return true;
            }
            
            //将字符串转成字符数组
            char[] ch = str.toCharArray();
            
            //对数组进行排序
            Arrays.sort(ch);
            
            //遍历数组,看当前字符是否和后面字符相同,相同就返回false,否则返回true
            for(int i = 0; i < ch.length-1; i++){
                if(ch[i] == ch[i+1]){
                    return false;
                }
            }
            
            return true;
            */
            
            /*
            //思路二
            //如果str是null,那么抛出异常
            if(str == null){
                throw new IllegalArgumentException("invalid parameters");
            }
            //如果str的长度是0或者1,那么没有重复字符,返回true
            if(str.length() == 0 || str.length() == 1){
                return true;
            }
            
            //创建hash表,将字符串字符存到hash表中
            HashSet<Character> hs = new HashSet<Character>();
            
            for(int i = 0; i < str.length(); i++){
                if(hs.contains(str.charAt(i))){
                    return false;//hash表中有相同的字符,那么说明有重复的字符
                }
                
                hs.add(str.charAt(i));
            }
            
            return true;
            */
            
            //思路三
            //如果str是null,那么抛出异常
            if(str == null){
                throw new IllegalArgumentException("invalid parameters");
            }
            //如果str的长度是0或者1,那么没有重复字符,返回true
            if(str.length() == 0 || str.length() == 1){
                return true;
            }
            
            //从前向后遍历字符串,对每个字符,调用String.indexOf()看其后面是否有相同的字符,如果有返回false,否则最后返回true
            for(int i = 0; i < str.length()-1; i++){
                if(str.indexOf(str.charAt(i), i+1) != -1){
                    return false;
                }
            }
            
            return true;
     
        }
    }

    推荐:php服务器

    以上就是php判断字符串是否重复的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。

    前端(VUE)零基础到就业课程:点击学习

    清晰的学习路线+老师随时辅导答疑

    自己动手写 PHP MVC 框架:点击学习

    快速了解MVC架构、了解框架底层运行原理

    专题推荐:php 字符串
    上一篇:php不等待结果直接返回 下一篇:自己动手写 PHP MVC 框架(40节精讲/巨细/新人进阶必看)

    相关文章推荐

    • ❤️‍🔥共22门课程,总价3725元,会员免费学• ❤️‍🔥接口自动化测试不想写代码?• php检测账号密码是否匹配• php网页标题在哪里修改• php调用不同目录的类• php常用函数有必要背吗• html如何调用php文件
    1/1

    PHP中文网