一文搞懂如何判断字符串是否为Pangram(全字母句)

给定一个字符串 s,判断它是否为 Pangram(全字母句)

什么是 Pangram?

一个包含英语字母表中所有字母的句子。

经典例子:

  • 输入:"The quick brown fox jumps over the lazy dog" → 输出:true(包含 a-z 所有字母)
  • 输入:"The quick brown fox jumps over the dog" → 输出:false(缺少 l, z, y)

目录

  1. 朴素解法:逐个字符搜索
  2. 高效解法:使用访问数组

没想到吧,判断一个字符串是不是Pangram,背后其实藏着不少算法细节。如果你正被408考研或数据结构期末考试折磨,强烈安利一个宝藏网站------图码。它不仅有60多种算法可视化动画,还能把你自己写的代码或自定义数据一键生成交互式动画,彻底搞懂底层逻辑。无论复习还是面试,用它配合7x24小时的AI代码解析,效率直接拉满。现在就去试试吧!

图码-数据结构与算法交互式可视化平台

访问网站:https://totuma.cn

1. 朴素解法:逐个字符搜索(O(26×n) 时间,O(1) 空间)

思路:

遍历 az 所有字符,对每个字符检查它是否在输入字符串中出现。如果某个字符缺失,直接返回 false。注意大小写不敏感('a' 和 'A' 视为相同)。

代码实现:

cpp 复制代码
#include <iostream>
#include<algorithm>
using namespace std;

bool checkPangram(string &s) {
    for(char ch = 'a'; ch <= 'z'; ch++) {
        bool found = false;
        for(int i = 0; i < s.length(); i++) {
            if(ch == tolower(s[i])) {
                found = true;
                break;
            }
        }
        if(found == false)
            return false;
    }
    return true;
}

int main() {
    string s = "The quick brown fox jumps over the lazy dog";
    cout << (checkPangram(s) ? "true" : "false");
    return 0;
}

其他语言(Java, Python, C#, JavaScript)实现类似,核心都是双重循环逐个对比。

输出:

复制代码
true

2. 高效解法:使用访问数组(O(n) 时间,O(26) 空间)

思路:

创建一个大小为 26 的布尔数组 vis,用于标记每个字母是否出现。遍历字符串一次,将出现的字母(忽略大小写)标记为 true,最后检查所有字母是否都被标记过。

代码实现:

cpp 复制代码
#include <iostream>
#include<vector>
#include<algorithm>
using namespace std;

const int MAX_CHAR = 26;

bool checkPangram(string &s) {
    vector<bool> vis(MAX_CHAR, false);
    
    for (int i = 0; i < s.length(); i++) {
        // 大写字母
        if ('A' <= s[i] && s[i] <= 'Z')
            vis[s[i] - 'A'] = true;
        // 小写字母
        else if ('a' <= s[i] && s[i] <= 'z')
            vis[s[i] - 'a'] = true;
    }

    for (int i = 0; i < MAX_CHAR; i++) {
        if (vis[i] == false)
            return false;
    }
    return true;
}

int main() {
    string s = "The quick brown fox jumps over the dog";
    cout << (checkPangram(s) ? "true" : "false");
    return 0;
}

其他语言(Java, Python, C#, JavaScript)实现类似,核心是使用固定大小的布尔数组。

输出:

复制代码
false

总结

方法 时间复杂度 空间复杂度 说明
朴素解法 O(26×n) O(1) 简单但效率低
访问数组 O(n) O(26) 高效,推荐使用

关键点:

  • 忽略大小写,统一转换为小写或利用 ASCII 码差值
  • 访问数组只需 26 个布尔值,空间开销极小
  • 适合面试手写,逻辑清晰不易出错

现在你已经掌握了判断 Pangram 的两种方法,快去试试手写吧!

相关推荐
khalil10201 小时前
代码随想录算法训练营Day-43 动态规划10 | 300.最长递增子序列、674. 最长连续递增序列、718. 最长重复子数组
数据结构·c++·算法·leetcode·动态规划·子序列问题
HackTwoHub2 小时前
可视化未授权访问批量探测工具、支持批量目标、并发扫描、SOCKS5 全局代理、CSV 导出
linux·windows·macos·网络安全·网络攻击模型
AIpanda8882 小时前
数字员工助推AI销冠系统和AI提效软件系统,实现企业智能化转型与运营效率提升
算法
2401_897190552 小时前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!
java·c++·算法
多加点辣也没关系2 小时前
数据结构与算法|第十一章:跳表
数据结构·算法
晚风叙码2 小时前
归并排序:从原理到非递归实现,一文搞定
数据结构·算法
悲伤小伞2 小时前
LeetCode 热题 100_3-128. 最长连续序列
c++·算法·leetcode·哈希算法
多加点辣也没关系2 小时前
数据结构与算法|第十三章:递归与分治
数据结构·算法
梦梦代码精2 小时前
LikeShop 是否安全可靠?——从架构设计到数据表现的系统性分析
数据结构·团队开发·安全性测试