【Leetcode】520. 檢測大寫字母

文章目錄

  • 題目
  • 思路
  • 代碼
  • 復雜度分析
    • 時間復雜度
    • 空間復雜度
  • 結果
  • 總結

題目

題目鏈接🔗
我們定義,在以下情況時,單詞的大寫用法是正確的:

  • 全部字母都是大寫,比如 “USA” 。
  • 單詞中所有字母都不是大寫,比如 “leetcode” 。
  • 如果單詞不只含有一個字母,只有首字母大寫, 比如 “Google” 。

給你一個字符串 word 。如果大寫用法正確,返回 true ;否則,返回 false 。

示例 1:

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

示例 2:

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

提示:

  • 1 ≤ w o r d . l e n g t h ≤ 100 1 \leq word.length \leq 100 1word.length100
  • w o r d word word 由小寫和大寫英文字母組成

思路

統計單詞中大寫字母的個數n

  • n = = w o r d . s i z e ( ) n == word.size() n==word.size() 說明全為大寫
  • n = = 1 n==1 n==1 && w o r d [ 0 ] ≤ ′ Z ′ word[0] \leq 'Z' word[0]Z && w o r d [ 0 ] ≥ ′ A ′ word[0] \geq 'A' word[0]A 說明只有一個大寫且為開頭
  • n = = 0 n==0 n==0說明單詞全小寫 除上述情況返回 t r u e true true外,其余情況都不符合,返回 f a l s e false false

代碼

class Solution {
public:bool detectCapitalUse(string word) {int n = word.size(), cnt = 0;for(auto& ch: word) {if(ch <= 'Z' && ch >= 'A') ++cnt;}return cnt == 0 || cnt == word.size() || cnt == 1 && word[0] <= 'Z' && word[0] >= 'A';}
};

復雜度分析

時間復雜度

  • 時間復雜度O(n),其中 n 是字符串 word 的長度。我們只需要遍歷一次字符串即可。
    在這里插入圖片描述

空間復雜度

  • 空間復雜度O(1),只需要常數級別的額外空間。
    在這里插入圖片描述

結果

在這里插入圖片描述

總結

本題是一個簡單的字符串處理問題,關鍵在于理解題目要求的三種大寫使用情況,并據此統計大寫字母的數量,然后進行判斷。通過一次遍歷即可解決問題,時間效率較高。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/37021.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/37021.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/37021.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Mybatis入門——語法詳解:基礎使用、增刪改查、起別名、解決問題、注釋、動態查詢,從入門到進階

文章目錄 1.基礎使用1.添加依賴2.在resouces文件下新建xml文件db.properties3.在resouces文件下新建xml文件mybatis-config-xml4.創建一個MybatisUtils工具類5.創建xml文件XxxMapper.xml映射dao層接口6.添加日志5.測試 2.增刪改查1.select2.delete3.update4.insert5.模糊查詢6.…

同心創建 共踐食安 | 趙夢澈榮獲食品安全大使

“民族要復興&#xff0c;鄉村必振興”&#xff0c;為深入貫徹落實國家鄉村振興戰略&#xff0c;推進鄉村全面振興不斷取得新成效&#xff0c;助力全國優質食品農產品的宣傳推廣、市場營銷、品牌創建工作&#xff0c;由中國食品安全報社主辦&#xff0c;商業發展中心、健康中國…

python數據分析與可視化一

公共部分 # 引入數據分析工具 Pandas import pandas as pd # 引入數據可視化工具 Matplotlib import matplotlib.pyplot as plt # 引入數據可視化工具 Seaborn (基于matplotlib) import seaborn as sns # 解決輸出時的列名對齊問題 pd.set_option(display.unicode.east_…

Python多線程編程詳解

Python多線程編程詳解 大家好&#xff0c;我是免費搭建查券返利機器人省錢賺傭金就用微賺淘客系統3.0的小編&#xff0c;也是冬天不穿秋褲&#xff0c;天冷也要風度的程序猿&#xff01; 多線程編程是利用計算機多核心和多線程處理器的優勢&#xff0c;提高程序并發性能的重要…

如何申請免費SSL證書以消除訪問網站顯示連接不安全提醒

在當今互聯網時代&#xff0c;網絡安全已成為一個不可忽視的問題。當用戶瀏覽一些網站時&#xff0c;有時會看到瀏覽器地址欄出現“不安全”的提示&#xff0c;這意味著該網站沒有安裝SSL證書&#xff0c;數據傳輸可能存在風險。那么&#xff0c;如何消除這種不安全提醒&#x…

2024年6月,Altair被Gartner魔力象限評為數據科學與機器學習平臺領導者

Altair 因其愿景完整性和執行能力被評為領導者 2024 年 6 月 20 日&#xff0c;Altair&#xff08;納斯達克股票代碼&#xff1a;ALTR&#xff09;宣布&#xff0c;Altair RapidMiner 被 Gartner Magic Quadrant?&#xff08;魔力象限&#xff09;評為數據科學與機器學習平臺領…

SpringBoot配置參數獲取

1、使用Value注解 import org.springframework.beans.factory.annotation.Value; import org.springframework.stereotype.Component;Component public class MyBean {Value("${myapp.name}") private String appName;public void printAppName() {System.out.print…

冪等生產者和事務生產者

Kafka消息交付 Kafka消息交付可靠性保障以及精確處理一次語義的實現。 所謂的消息交付可靠性保障&#xff0c;是指Kafka對Producer和Consumer要處理的消息提供什么樣的承諾。常見的承諾有以下三種&#xff1a; 最多一次&#xff08;atmost once&#xff09;&#xff1a;消息…

SpringBoot:SpringBoot 調用第三方接口的幾種方式

一、前言 在項目中調用第三方接口時&#xff0c;確實需要根據項目的技術棧、架構規范以及具體的業務需求來選擇最適合的調用方式。比如&#xff1a;RESTful API調用、Feign聲明式HTTP客戶端、Apache HttpClient等調用方式&#xff0c;每種方式都有其適用場景和優勢。下面我們就…

倉庫管理系統16--入庫管理

原創不易&#xff0c;打字不易&#xff0c;截圖不易&#xff0c;多多點贊&#xff0c;送人玫瑰&#xff0c;留有余香&#xff0c;財務自由明日實現。 1、創建物資入庫用戶控件 <UserControl x:Class"West.StoreMgr.View.InStoreView"xmlns"http://schema…

CAS自旋解析

CAS全稱CompareAndSwap(比較并交換)&#xff0c;是cpu的指令&#xff0c;調用時不涉及上下文的切換。Java中屬于樂觀鎖的一種&#xff0c;具體流程如下圖&#xff1a; 具體的實現使用的是Unsafe類去調用native修飾的compareAndSwap方法&#xff0c;4個字段分別是對象實例&#…

PTA—C語言期末復習(判斷題)

1. C語言程序是從源文件的第一條語句開始執行的 &#xff08;F&#xff09; 在 C 語言中&#xff0c;程序是從 main 函數開始執行的&#xff0c;而不是從源文件的第一條語句開始執行 2. 若變量定義為double x;&#xff0c;則x % 2是符合C語言語法的表達式 &#xff08;F&#…

通過nginx去除 api url前綴 并保持后面剩余的url不變向后臺請求

如 我前臺瀏覽器向后臺請求的接口是 http://127.0.0.1:5099/api/sample/sample/getbuttonlist 實際的請求接口傳向 http://192.168.3.71:5099/sample/sample/getbuttonlist 方法是向config中加入下面這樣一個server server {listen 5099;location /api/ {rewrite ^/a…

HTML流星雨

目錄 寫在前面 完整代碼 代碼分析 系列文章 寫在最后 寫在前面 歲月如梭&#xff0c;光陰似箭&#xff0c;不知不覺暑假就要來嘍&#xff0c;本期小編用HTML給大家手搓了一個炫酷的流星雨動畫&#xff0c;一起來看看吧。 完整代碼 <!DOCTYPE html> <html lang…

項目風險管理系統有哪些?分享11款主流項目管理系統

本文將分享11款主流項目管理系統&#xff1a;PingCode、Worktile、StandardFusion、MasterControl、ClickUp、SAI360、Netwrix Auditor、MetricStream、Wrike、Celoxis、Zoho Projects。 在項目管理中&#xff0c;風險管理不僅是一個挑戰&#xff0c;也是保證項目順利進行的關鍵…

探索Vim的文本處理能力:精通查找與替換

探索Vim的文本處理能力&#xff1a;精通查找與替換 Vim&#xff0c;作為Linux終端下的王牌文本編輯器&#xff0c;以其強大的功能和靈活性深受開發者和系統管理員的喜愛。在Vim中進行查找和替換是文本編輯中的一項基礎且重要的操作。本文將詳細解釋如何在Vim中執行查找和替換文…

Linux Redis 服務設置開機自啟動

文章目錄 前言一、準備工作二、操作步驟2.1 修改redis.conf文件2.2 創建啟動腳本2.3 設置redis 腳本權限2.4 設置開機啟動2.5 驗證 總結 前言 請各大網友尊重本人原創知識分享&#xff0c;謹記本人博客&#xff1a;南國以南i、 提示&#xff1a;以下是本篇文章正文內容&#x…

編程的難點在哪?是邏輯、算法,還是模塊、框架的掌握?

&#x1f446;點擊關注 回復『新人禮』獲取學習禮包&#x1f446; 很多新手程序員在一開始都是滿懷熱情地投入到編程的學習&#xff0c;但卻在學習過程中處處碰壁&#xff0c;導致放棄。 編程的難點在于邏輯、數學、算法&#xff0c;還是模塊、框架、接口的掌握&#xff1f;但…

idea Error running ‘Application‘

1、Error running ‘Application’ Error running ApplicationError running Application. Command line is too long.Shorten the command line via JAR manifest or via a classpath file and rerun.找到 .idea/libraies/workspace.xml 中的 PropertiesComponent 屬性&#…

Android InputDispatcher分發輸入事件

派發循環是指 InputDispatcher 不斷地派發隊列取出事件&#xff0c;尋找合適的窗口并進行發送的過程&#xff0c;是 InputDispatcher 線程的主要工作 事件發送循環是 InputDispatcher 通過 Connection 對象將事件發送給窗口&#xff0c;并接受其反饋的過程 InputDispatcher —…