C语言面试题之判定字符是否唯一

判定字符是否唯一

实例要求

  • 实现一个算法,确定一个字符串 s 的所有字符是否全都不同

实例分析

  • 1、使用一个大小为 256 的bool数组 charSet 来记录字符是否出现过;
  • 2、遍历字符串时,如果字符已经在数组中标记过,则返回 false;
  • 3、否则标记该字符为已出现;
  • 4、最终返回 true 表示字符串中的所有字符都不同;

示例代码

c 复制代码
bool isUnique(char* astr){
    if (astr == NULL) {
        return true; // 空字符串视为所有字符都不同
    }

    bool charSet[256] = {false}; // 假设字符集为 ASCII

    while (*astr != '\0') {
        int val = (int)(*astr);
        if (charSet[val]) {
            return false; // 如果字符已经出现过,则返回 false
        }
        charSet[val] = true; // 标记字符已经出现过
        astr++;
    }

    return true; // 遍历完字符串,所有字符都不同
}

运行结果


  • ASCII码表
相关推荐
想睡hhh10 分钟前
c++STL——stack、queue、priority_queue的模拟实现
开发语言·c++·stl
陶然同学10 分钟前
RabbitMQ全栈实践手册:从零搭建消息中间件到SpringAMQP高阶玩法
java·分布式·学习·rabbitmq·mq
shanzhizi12 分钟前
springboot入门-controller层
java·spring boot·后端
小鹿鹿啊18 分钟前
C语言编程--14.电话号码的字母组合
c语言·开发语言·算法
Sunlight_77720 分钟前
第六章 QT基础:6、QT的Qt 时钟编程
开发语言·qt·命令模式
cloues break.20 分钟前
C++初阶----模板初阶
java·开发语言·c++
陌殇殇37 分钟前
Java使用IText7动态生成带审批文本框的PDF文档
java·pdf
wwww.wwww41 分钟前
Qt软件开发-摄像头检测使用软件V1.1
开发语言·c++·qt
weixin_456588151 小时前
【Maven】特殊pom.xml配置文件 - BOM
xml·java·maven
bjzhang751 小时前
如何创建一个父类 Maven项目,然后在父类下再创建子项目,构建多模块 Maven 项目
java·maven