520. 检测大写字母

题目

我们定义,在以下情况时,单词的大写用法是正确的:

  • 全部字母都是大写,比如 “USA” 。
  • 单词中所有字母都不是大写,比如 “leetcode” 。
  • 如果单词不只含有一个字母,只有首字母大写,比如 “Google” 。

给你一个字符串 word 。如果大写用法正确,返回 true ;否则,返回 false

示例 1:

输入:word = “USA”
输出:true

示例 2:

输入:word = “FlaG”
输出:false

提示:

  • 1 <= word.length <= 100
  • word 由小写和大写英文字母组成

代码

完整代码

#include <stdbool.h>
#include <string.h>
#include <stdio.h>

bool isBig(char c) {
    return (c >= 'A' && c <= 'Z');
}

bool isSmall(char c) {
    return (c >= 'a' && c <= 'z');
}

bool detectCapitalUse(char* word) {
    bool isBeginBig = isBig(word[0]);
    bool mix = false;
    for (int i = 1; i < strlen(word); i++) {
        if (isBeginBig) {
            if (!mix && isSmall(word[i])) {
                if (i != 1) { // 不是第二个开始就是小写
                    return false;
                }
                mix = true;
            }
            if (mix) {
                if (isBig(word[i])) { // 有小写且非首字母有大写
                    return false;
                }
            }
        } else {
            if (isBig(word[i])) { // 非首字母有大写
                return false;
            }
        }
    }
    return true;
}

// int main(void)
// {
//     printf("a = %d",'a');
//     printf("A = %d",'A');
// }

思路分析

这套代码用了模拟的方法。

  • 首先,判断第一个字母是否是大写字母。
  • 遍历整个字符串,检查是否符合所有大写或所有小写的规则。
  • 如果第一个字母是大写,则后续字符可以全为小写或全为大写。
  • 如果第一个字母是小写,则后续字符必须全为小写。
  • 在遍历过程中,如果发现任何不符合上述规则的情况,则返回 false,否则返回 true

拆解分析

  1. isBig函数
bool isBig(char c) {
    return (c >= 'A' && c <= 'Z');
}

判断字符是否为大写字母。

  1. isSmall函数
bool isSmall(char c) {
    return (c >= 'a' && c <= 'z');
}

判断字符是否为小写字母。

  1. detectCapitalUse函数
bool detectCapitalUse(char* word) {
    bool isBeginBig = isBig(word[0]);
    bool mix = false;
    for (int i = 1; i < strlen(word); i++) {
        if (isBeginBig) {
            if (!mix && isSmall(word[i])) {
                if (i != 1) { // 不是第二个开始就是小写
                    return false;
                }
                mix = true;
            }
            if (mix) {
                if (isBig(word[i])) { // 有小写且非首字母有大写
                    return false;
                }
            }
        } else {
            if (isBig(word[i])) { // 非首字母有大写
                return false;
            }
        }
    }
    return true;
}

主要函数,遍历字符串,判断是否符合大写规则。

复杂度分析

  • 时间复杂度:O(n),其中 n 为字符串的长度,需要遍历每个字符。
  • 空间复杂度:O(1),不需要额外的空间,仅使用了几个额外变量。

一题多解

正则表达式解法

完整代码

#include <stdbool.h>
#include <regex.h>

bool detectCapitalUse(char* word) {
    regex_t regex;
    int reti;

    // 编译正则表达式
    reti = regcomp(&regex, "^[A-Z]+$|^[a-z]+$|^[A-Z][a-z]+$", REG_EXTENDED);
    if (reti) {
        return false; // 如果正则表达式编译失败,返回 false
    }

    // 执行正则表达式
    reti = regexec(&regex, word, 0, NULL, 0);
    regfree(&regex);

    if (!reti) {
        return true; // 如果正则表达式匹配,返回 true
    } else if (reti == REG_NOMATCH) {
        return false; // 如果正则表达式不匹配,返回 false
    } else {
        return false; // 如果正则执行中发生其他错误,返回 false
    }
}


思路分析

这套代码用了正则表达式的方法。

  • 使用正则表达式来匹配符合大写规则的字符串。
  • 正则表达式 ^[A-Z]+$|^[a-z]+$|^[A-Z][a-z]+$ 分别匹配全部大写、全部小写和首字母大写的情况。

拆解分析

  1. 编译正则表达式
// 编译正则表达式
reti = regcomp(&regex, "^[A-Z]+$|^[a-z]+$|^[A-Z][a-z]+$", REG_EXTENDED);
if (reti) {
    return false; // 如果正则表达式编译失败,返回 false
}

编译用于匹配大写规则的正则表达式。

  1. 执行正则表达式

// 执行正则表达式
reti = regexec(&regex, word, 0, NULL, 0);
regfree(&regex);

if (!reti) {
    return true; // 如果正则表达式匹配,返回 true
} else if (reti == REG_NOMATCH) {
    return false; // 如果正则表达式不匹配,返回 false
} else {
    return false; // 如果正则执行中发生其他错误,返回 false
}

执行正则表达式,并根据匹配结果返回对应的布尔值。

复杂度分析

  • 时间复杂度:O(n),其中 n 为字符串的长度,正则表达式匹配需要遍历每个字符。
  • 空间复杂度:O(1),不需要额外的空间。

结果

模拟:

模拟

正则:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/751091.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

World of Warcraft [CLASSIC] plugin lua

World of Warcraft [CLASSIC] plugin lua 魔兽世界lua脚本插件 World of Warcraft API - Wowpedia - Your wiki guide to the World of Warcraft D:\World of Warcraft\_classic_\Interface\AddOns zwf.lua function CountdownFunc()CountdownFrame CreateFrame("Fram…

常见的字符串函数(包含头文件string.h)和字符函数(2)

八. strstr函数 1.strstr的定义 char *strstr( const char *str1, const char *str2 ); ->1. strstr查找子串(str2)在字符串(str2)中第一次出现的位置&#xff0c;记录并返回该位置的指针&#xff0c;如果找不到&#xff0c;则返回NULL ->2. str1&#xff1a;查找字符…

不用再找了,这是大模型实践最全的总结

随着ChatGPT的迅速出圈&#xff0c;加速了大模型时代的变革。对于以Transformer、MOE结构为代表的大模型来说&#xff0c;传统的单机单卡训练模式肯定不能满足上千&#xff08;万&#xff09;亿级参数的模型训练&#xff0c;这时候我们就需要解决内存墙和通信墙等一系列问题&am…

Mysql索引的实现原理,B+Tree,WAL

InnoDB 引擎&#xff0c;每一个数据表有两个文件 .frm和.ibd&#xff0c;分别为表结构&#xff0c;数据和索引&#xff0c;数据挂在主索引的叶子节点上&#xff0c;此主索引称为聚簇索引。 MyISAM 引擎&#xff0c;每一个数据表有三个文件.frm和.MYI和.MYD&#xff0c;分别为表…

测试报告-HTMLTestRunner报告优化(中/英文)

引用原始的HTMLTestRunner.py文件生成的测试报告在美观性不是很好&#xff0c;使用在此文件基础上优化后的HTMLTestReportCN.py文件(生成的报告为中文)、HTMLTestReportEN.py文件(生成的报告为英文)。 1 首先新建一个Python项目 例如&#xff1a;testHtmlReport 创建case包&am…

指纹浏览器是什么?跨境多账号安全如何保证?

随着电子商务的蓬勃发展&#xff0c;越来越多的商家选择开设多店来扩大经营规模。然而多店运营也带来了一系列的挑战&#xff0c;其中之一就是账号安全。 1. 了解反检测浏览器和代理服务器 在我们开始讨论如何有效地使用反检测浏览器之前&#xff0c;我们首先需要了解这两个工…

如何用亚马逊合作伙伴网络快速上线跨境电商

目前跨境电商已成为行业发展主流&#xff0c;如何快速、低成本打造品牌海外独立站和智能客服营销中心、构建全链路跨境电商体系是出海电商商家都会遇到的难题。亚马逊云科技凭借与亚马逊电商平台易于集成的先天优势成为首选的电商解决方案平台。本文介绍了如何用亚马逊云科技平…

SpringCloud分布式微服务链路追踪方案:Skywalking

一、引言 随着微服务架构的广泛应用&#xff0c;系统的复杂性也随之增加。在这种复杂的系统中&#xff0c;应用通常由多个相互独立的服务组成&#xff0c;每个服务可能分布在不同的主机上。微服务架构虽然提高了系统的灵活性和可扩展性&#xff0c;但也带来了新的挑战&#xf…

深度学习论文撰写实验对比分析时复现其它论文方法的问题

&#x1f4aa; 专业从事且热爱图像处理&#xff0c;图像处理专栏更新如下&#x1f447;&#xff1a; &#x1f4dd;《图像去噪》 &#x1f4dd;《超分辨率重建》 &#x1f4dd;《语义分割》 &#x1f4dd;《风格迁移》 &#x1f4dd;《目标检测》 &#x1f4dd;《暗光增强》 &a…

说一说ABAP CDS View的发展历史与特性

1. 背景 随着SAP Fiori应用程序的兴起&#xff0c;SAP领域的小伙伴接触和使用ABAP CDS View的机会也是越来越多。今天&#xff0c;让我们花些时间&#xff0c;一起在了解下这项技术的设计初衷和发展历史。 2. 设计初衷 说起ABAP CDS View&#xff0c;就不得不提及SAP HANA。…

Open AI限制来袭?用上这个工具轻松破局!

【导语】近日&#xff0c;AI领域掀起了一场不小的波澜。Open AI宣布&#xff0c;从7月9日起&#xff0c;将对部分地区的开发者实施API调用限制。这一消息对于许多依赖Open AI技术的国内初创团队来说&#xff0c;无疑是一个沉重的打击。 对于这些团队而言&#xff0c;Open AI的A…

Arcgis地统计分析工具灰色不可用 解决方法

使用Arcmap&#xff0c;调用地统计分析工具&#xff08;Geostatistical Analyst&#xff09;下的探索数据&#xff08;Explore Data&#xff09;&#xff0c;发现工具呈灰色不可用。这是由于扩展模块中没有将该模块做勾选设置导致的。下面介绍一下如何解决地统计分析工具不可用…

汇聚荣做拼多多运营第一步是什么?

汇聚荣做拼多多运营第一步是什么?在众多电商平台中&#xff0c;拼多多凭借其独特的社交电商模式迅速崛起&#xff0c;吸引了大量消费者和商家的目光。对于希望在拼多多上开店的商家而言&#xff0c;了解如何进行有效运营是成功的关键。那么&#xff0c;汇聚荣做拼多多运营的第…

web前端——HTML

目录 一、HTML概述 1.HTML是什么&#xff1f; 2.HTML具体化解释 二、HTML基本语法 1.声明 2. Head头标签 3.body身体标签 4.一个html的基本结构 5.标签 6.标签属性 ①属性的格式 ②属性的位置 ③添加多个属性 三、基本常用标签 1.超链接 2.图像标签 ①图像标…

C++编程(四)this指针 常函数 常对象 静态成员

文章目录 一、this指针&#xff08;一&#xff09;概念&#xff08;二&#xff09;显式使用this指针的场景1. 当形参和成员变量名一致时2. 返回对象自身的时候必须要使用this指针3. 在类中销毁一个对象 二、常函数和常对象&#xff08;一&#xff09;常函数1. 概念2. 语法格式 …

【2024.6.23】今日科技时事:科技前沿大事件

人不走空 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌赋&#xff1a;斯是陋室&#xff0c;惟吾德馨 目录 &#x1f308;个人主页&#xff1a;人不走空 &#x1f496;系列专栏&#xff1a;算法专题 ⏰诗词歌…

最新!AI大模型的研究热点!

引言 在人工智能的浪潮中&#xff0c;大模型研究如日中天&#xff0c;涵盖诸多研究方向&#xff0c;每个方向均承载着独特的研究焦点与挑战。 以下&#xff0c;我们将逐一探讨数个备受瞩目的研究方向&#xff0c;包括检索增强生成RAG、大模型Agent、Mamba、MoE、LoRA等&#…

【LeetCode】八、堆的使用:第K个最大元素 + 前K和高频单词

文章目录 1、Java中的堆结构2、leetcode215&#xff1a;数组中的第K个最大元素3、leetcode692&#xff1a;前K个高频单词 1、Java中的堆结构 PriorityQueue类取堆顶元素删除堆顶元素堆的元素个数遍历堆 2、leetcode215&#xff1a;数组中的第K个最大元素 这题应该快排来解&…

MyBatis~配置解析, 属性(properties)、设置(settings)

注意, 对应的名称一定要相同, 比如username就要对应username, 而且如果同时使用外部配置文件和property, 优先级是外部配置文件优先级更高 设置&#xff08;settings&#xff09; 这是 MyBatis 中极为重要的调整设置&#xff0c;它们会改变 MyBatis 的运行时行为。 下表描述了…

利用Python控制终端打印字体的颜色和格式

利用Python控制终端打印字体的颜色和格式—操作详解&#xff08;ANSI转义序列&#xff09; 一、问题描述二、ANSI转义序列三、具体代码和显示效果&#xff08;看懂这段代码&#xff0c;以后可随心控制字体的打印格式&#xff09; 欢迎学习交流&#xff01; 邮箱&#xff1a; z……