LeetCode 每日一题笔记 日期:2026.05.26 题目:3120. 特殊字母的数量

LeetCode 每日一题笔记

0. 前言

  • 日期:2026.05.26
  • 题目:3120. 特殊字母的数量
  • 难度:简单
  • 标签:字符串、计数、数组

1. 题目理解

问题描述

给你一个字符串 word。如果一个字母在字符串中同时出现了小写和大写形式 ,那么这个字母就是特殊字母

返回字符串中特殊字母的数量。

示例

输入:word = "aaAbcBC"

输出:3

解释:a、b、c 都同时出现了大小写。

2. 解题思路

核心观察

  • 只需要统计每个字母小写是否出现、大写是否出现
  • 两者都出现,就是特殊字母。

算法步骤

  1. 遍历字符串,标记每个字母的大小写是否出现。
  2. 遍历26个字母,统计同时出现大小写的字母数量。

3. 代码实现

java 复制代码
package lc3120;

public class Solution {
    public int numberOfSpecialChars(String word) {
        int res = 0;
        int[][] arr = new int[26][2];
        for (int i = 0; i < word.length(); i++) {
            int a = word.charAt(i) - 'a';
            int A = word.charAt(i) - 'A';
            //小的
            if (a >= 0) {
                arr[a][0] = 1;
            }
            //大的
            else {
                arr[A][1] = 1;
            }
        }
        for (int i = 0; i < 26; i++) {
            if (arr[i][0] == 1 && arr[i][0] == arr[i][1]) {
                res++;
            }
        }
        return res;
    }
}

4. 代码优化说明

(代码未做任何修改,仅添加注释讲解)

java 复制代码
class Solution {
public int numberOfSpecialChars(String word) {
// 长度52:0-25存小写,26-51存大写
int [] sum = new int [52];
// 转为字符数组遍历更快
char [] arr = word.toCharArray();
for(char s:arr){
    // 小写字母:存在 0~25
    if(s >='a' && s<='z' ){
        sum[ s-'a']++;
    }
    // 大写字母:存在 26~51
    else if(s>='A' && s<='Z'){
        sum[26+s-'A']++;
    }
}
int count=0;
// 遍历26个字母,判断小写位和大写位是否都>0
for(int i =0;i<(sum.length)/2;i++){
    if(sum[i] >0 && sum[i+26] > 0 ){
        count++;
    }
}
return count;
}
}

5. 复杂度分析

  • 时间复杂度 :O(n)O(n)O(n)
    一次遍历字符串 + 一次遍历26个字母。
  • 空间复杂度 :O(1)O(1)O(1)
    固定长度52的计数数组,常数空间。

6. 总结

  • 核心:单个数组统计大小写出现次数
  • 优化点:减少判断、减少二维数组,逻辑更清晰。
  • 关键:小写占前26位,大写占后26位,一一对应检查即可。
相关推荐
绿算技术20 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
想吃火锅100521 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
qeen8721 小时前
【C++】类与对象之类的默认成员函数(二)
android·c语言·开发语言·c++·笔记·学习
m0_7360348521 小时前
存储基础和虚拟化
笔记
net3m331 天前
一阶软件低通滤波器算法
人工智能·算法
水木流年追梦1 天前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt
J-Tony111 天前
【JVM】三色标记法
java·jvm·算法
wengad1 天前
机器学习实践理论基础|算法、模型和数据集
人工智能·算法·机器学习
AOwhisky1 天前
MySQL 学习笔记(第六期):MySQL 备份与恢复
运维·数据库·笔记·学习·mysql·云计算