【LeetCode】1832. 判断句子是否为全字母句(C++)

1 题目描述

全字母句 指包含英语字母表中每个字母至少一次的句子。
给你一个仅由小写英文字母组成的字符串 sentence ,请你判断 sentence 是否为 全字母句 。
如果是,返回 true ;否则,返回 false 。

2 示例描述

2.1 示例1

输入:sentence = “thequickbrownfoxjumpsoverthelazydog”
输出:true
解释:sentence 包含英语字母表中每个字母至少一次。

2.2 示例2

输入:sentence = “leetcode”
输出:false

3 解题提示

1 <= sentence.length <= 1000
sentence 由小写英语字母组成

4 解题思路

简单来说就是一个哈希表,创建一个26位的数组,把出现过的小写字母作为哈希表的下标显示,然后遍历0-25的位数,若出现0的数,则表示为满足条件,若出现字符串小于26,则表示不满足26个字符全部出现一遍,可以直接枝剪掉。

5 代码详解

class Solution {
public:
    bool checkIfPangram(string sentence) {
        int ans[26] = {0};
        int ascii = 0 ;

        if( sentence.length() < 26)
        {
            return false ;
        }

        for ( int i = 0 ; i < sentence.length() ; i++ )
        {
            ascii = sentence[i];
            ascii = ascii -97 ;
            ans[ascii] ++ ;
        }
        int i = 0 ;
        while( ans[i] != 0 )
        {
            i ++ ;
            if ( i == 26 )
            {
                return true ;
            }
        }
        return false ;
    }
};
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码两年半的练习生

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值