判断字符串是否包含重复字符

方法1: 遍历字符串中的所有字符,将当前字符和它后面的所有字符逐一比较是否相同,如果相同则说明重复,停止遍历。如果直到遍历结束还未发现重复字符,则说明该字符串中没有重复字符

方法2: 遍历字符串中的所有字符,比较字符的当前位置和最后一次出现的位置,如果两者不同,则说明存在重复字符。

 

public class Test3 {
    public static void main(String[] args) {
        String str = "abcdea";
        boolean duplicate = hasDuplicateChar1(str);
        System.out.println(duplicate);
    }

    public static boolean hasDuplicateChar1(String str) {
        /* 将每一个字符和它后面的所有字符比较,判断是否相同 */
        int len = str.length();
        for (int i = 0; i < len - 1; ++i) {
            for (int j = i + 1; j < len; ++j) {
                if (str.charAt(j) == str.charAt(i)) {
                    return true;
                }
            }
        }
        return false;
    }

    /* 判断字符串是否包含重复字符 */
    public static boolean hasDuplicateChar2(String str) {
        /* 判断一个字符最后一次出现的位置和当前位置是否相同,如果字母重复 则不相同,反之相同 */
        for (int i = 0; i < str.length(); ++i) {
            char ch = str.charAt(i);
            if (str.lastIndexOf(ch) != i) {
                return true;
            }
        }
        return false;
    }

}

 

转载于:https://www.cnblogs.com/hupeng1234/p/6825563.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C语言判断字符串是否存在重复字符的函数,可以通过使用数组和循环来实现。下面给出一个示例的函数实现: ```c #include <stdio.h> #include <stdbool.h> bool hasDuplicateCharacters(const char* str) { // 用一个数组来统计字符出现的次数,ASCII字符共有256个 int freq[256] = { 0 }; // 遍历字符串中的每个字符 for (int i = 0; str[i] != '\0'; i++) { // 如果该字符出现过,则返回true if (freq[(int)str[i]] > 0) { return true; } // 更新字符的出现次数 freq[(int)str[i]]++; } // 如果所有字符都未重复出现,则返回false return false; } int main() { const char* str1 = "abcde"; const char* str2 = "hello"; if (hasDuplicateCharacters(str1)) { printf("%s 包含重复字符\n", str1); } else { printf("%s 不包含重复字符\n", str1); } if (hasDuplicateCharacters(str2)) { printf("%s 包含重复字符\n", str2); } else { printf("%s 不包含重复字符\n", str2); } return 0; } ``` 该函数中,我们使用了一个长度为256的整型数组freq来统计字符串中每个字符出现的次数。通过遍历字符串中的每个字符,将其对应的数组元素加1来记录出现次数。如果某个字符的出现次数大于1,则说明该字符重复出现,函数返回true;否则,所有字符都未重复出现,函数返回false。 在main函数中,我们调用了hasDuplicateCharacters函数来判断两个字符串str1和str2是否存在重复字符,并输出相应的结果。 需要注意的是,该函数中只能判断ASCII字符范围内的重复字符,如果处理的字符串包含非ASCII字符,可能会出现错误结果。如果需要支持更多字符集,可以使用更高级的算法或数据结构来处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值