当前位置: 首页 > article >正文

day2 —— 判断字符串中的字符是否唯一

目录

前言

问题描述

代码解释


前言

若是想要了解基本语法的话,请到(7条消息) C语言从练气期到渡劫期_要一杯卡布奇诺的博客-CSDN博客查看相应的语法细节

强烈安利这篇文章 —— (4条消息) 筑基五层 —— 位运算看这篇就行了_要一杯卡布奇诺的博客-CSDN博客

问题描述

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

题目来源:面试题 01.01. 判定字符是否唯一 - 力扣(Leetcode)

代码解释

        法一:暴力枚举比较

思路分析:直接循环遍历每个字符进行比较,找到了,返回false,没有找到,返回true

bool isUnique(char* astr) 
{
    for(int i=0; i<strlen(astr); i++)
    {
        for(int j=i+1; j<strlen(astr); j++)
        {
            //找到相同字符
            if(astr[i] == astr[j])
                return false;
        }
    }
    //没有找到相同字符
    return true;
}

        法二:哈希表

思路分析:把字符串中的值映射到哈希数组的下标中,字符串的每个字符在哈希数组着中有对应的下标,则该下标自增,如果哈希中有大于1的值,则说明字符串的字符不唯一

bool isUnique(char* astr) 
{
    char hash[128] = {0};//哈希数组
    memset(hash,0,sizeof(hash));//初始化
    
    //把字符的对应值映射到哈希数组中
    for(int i=0; i<strlen(astr); i++)
        hash[astr[i]]++;

    for(int i=0; i<128; i++)
    {
        //判断有没有下标的值超过1的
        if(hash[i] > 1)
            return false;
    }    
    return true;
}

         法三:排序

思路分析:进行排序,排序后比较相邻的值,如果有相同的值则说明字符串中的字符不唯一

bool isUnique(char* astr) 
{
    //空指针判断
    if(astr == NULL)
        return false;
    //空串判断                    
    if(strlen(astr) == 0)
        return true;
    
    //冒泡排序
    for(int i=0; i<strlen(astr)-1;i++)
    {
        int flag = 1;//假设有序
        for(int j=0; j<strlen(astr) - i - 1; j++)
        {
            if(astr[j] > astr[j+1])
            {
                flag = 0;//无序
                char tmp = astr[j];
                astr[j] = astr[j+1];
                astr[j+1] = tmp;
            }
        }
        //有序则跳出循环
        if(flag == 1)
            break;
    }
    
    for(int i=0; i<strlen(astr)-1; i++)
    {
        //判断相邻字符
        if(astr[i] == astr[i+1])
            return false;
    }
    return true;
}

        法四:双指针

思路分析:使用双指针进行对字符串遍历,思路和暴力枚举的思路一样 

bool isUnique(char* astr) 
{    
    char* cur = astr;
    assert(astr);//判断空指针
    //空串判断
    if (strlen(astr) == 0)
        return true;
        
    while (*astr != '\0')
    {
        cur++;//指向astr的下一个
        if (*cur != '\0')
        {
            char* tmp = cur;
            while (*tmp != '\0')
            {
                //比较
                if (*tmp == *astr)
                    return false;
                tmp++;
            }
        }
        astr++;
    }
    return true;

}

         !!恭喜你完成第二天的修仙之旅!!


http://www.kler.cn/a/1347.html

相关文章:

  • ubuntu20下编译linux1.0 (part1)
  • AAAI2023《Controllable Image Captioning via Prompting》
  • sql server cdc漏扫数据
  • 从零开始:使用VSCode搭建Python数据科学开发环境
  • 爬虫学习记录
  • 【阅读笔记】基于FPGA的红外图像二阶牛顿插值算法的实现
  • *p++,*(p++),*++p,(*p)++区别?
  • 蓝桥杯嵌入式--字符串比较在串口通信中的应用
  • GPT-4来了!看看她究竟强在哪里!
  • 大学四年..就混了毕业证的我,出社会深感无力..辞去工作,从头开始
  • ImageView(图像视图)
  • 动手实现一遍Transformer
  • 【2024考研】计算机考研,4轮复习时间安排
  • 基于stm32mp157 linux开发板ARM裸机开发教程Cortex-A7 开发环境搭建(连载中)
  • redis持久化的几种方式
  • 文心一言发布,你怎么看?chatGPT
  • python解析Java文件三方库javalang用法简介
  • MySQL索引特性
  • 【完整代码】用HTML/CSS制作一个美观的个人简介网页
  • 若依整合Easy-Es实现文章列表分页查询
  • 02-PostgreSQL 存储过程的进阶介绍(含游标、错误处理、自定义函数、事务)
  • 真实的软件测试日常工作是咋样的?
  • Delphi 一个函数实现腾讯云最新版(API3.0)短信发送
  • C++基础教程
  • PMSM矢量控制笔记(1.1)——电机的机械结构与运行原理
  • News乐鑫科技亮相德国嵌入式展 Embedded World 2023!