Leetcode 2047. 句子中的有效单词数(可以,已解决)
Published on 2022-06-08 14:41 in 暂未分类 with 萧海~

Leetcode 2047. 句子中的有效单词数(可以,已解决)

    在这里插入图片描述
    句子仅由小写字母('a' 到 'z')、数字('0' 到 '9')、连字符('-')、标点符号('!'、'.' 和 ',')以及空格(' ')组成。每个句子可以根据空格分解成 一个或者多个 token ,这些 token 之间由一个或者多个空格 ' ' 分隔。

    如果一个 token 同时满足下述条件,则认为这个 token 是一个有效单词:

    • 仅由小写字母、连字符和/或标点(不含数字)组成。
    • 至多一个 连字符 '-' 。如果存在,连字符两侧应当都存在小写字母("a-b" 是一个有效单词,但 "-ab" 和 "ab-"
      不是有效单词)。
    • 至多一个 标点符号。如果存在,标点符号应当位于 token 的 末尾 。

    这里给出几个有效单词的例子:"a-b."、"afad"、"ba-c"、"a!" 和 "!" 。

    给你一个字符串 sentence ,请你找出并返回 sentence 中 有效单词的数目 。

    示例 1:

    输入:sentence = "cat and dog"
    输出:3
    解释:句子中的有效单词是 "cat""and""dog"

    示例 2:

    输入:sentence = "!this 1-s b8d!"
    输出:0
    解释:句子中没有有效单词
    "!this" 不是有效单词,因为它以一个标点开头
    "1-s""b8d" 也不是有效单词,因为它们都包含数字

    示例 3:

    输入:sentence = "alice and bob are playing stone-game10"
    输出:5
    解释:句子中的有效单词是 "alice""and""bob""are""playing"
    "stone-game10" 不是有效单词,因为它含有数字

    提示:

    • 1 <= sentence.length <= 1000
    • sentence 由小写英文字母、数字(0-9)、以及字符(' '、'-'、'!'、'.' 和 ',')组成
    • 句子中至少有 1 个 token

    主要思路:字符串分割
    Code:

    class Solution {
    public:
    void str_split(const std::string & src, const std::string & sep, std::vector<string> & vec_str)
    {
    std::string::size_type start = 0;
    int i=0;
    for(std::string::size_type end = src.find(sep, start); end != std::string::npos; end = src.find(sep, start))
    {
    if(end > start)
    {
    string str=src.substr(start, end - start);
    vec_str.push_back(str);
    }
    start = end + sep.length();
    }
    if(start < src.length())
    {
    string str=src.substr(start, src.length() - start);
    vec_str.push_back(str);
    }
    }
    int countValidWords(string sentence) {
    int res=0;
    vector<string>vec;
    str_split( sentence," ",vec);
    for(int i=0;i<vec.size();i++)
    {
    // cout<<vec[i]<<endl;
    string str=vec[i];
    bool flag=false;
    int cnt1=0;
    int cnt2=0;
    for(int j=0;j<str.length();j++)
    {
    if(str[j]>='0'&&str[j]<='9')
    {
    flag=true;
    break;
    }
    if(str[j]=='!'||str[j]=='.'||str[j]==',')
    {
    cnt2++;
    if(cnt2>1)
    {
    flag=true;
    break;
    }
    if(j!=str.length()-1)
    {
    flag=true;
    break;
    }
    }
    if(str[j]=='-')
    {
    cnt1++;
    if(cnt1>1)
    {
    flag=true;
    break;
    }
    if(j==0 || j==(str.length()-1))
    {
    flag=true;
    break;
    }
    else
    {
    if(str[j-1]>='a'&&str[j-1]<='z'&&(str[j+1]>='a'&&str[j+1]<='z'))
    {
    }
    else
    {
    flag=true;
    break;
    }
    }
    }
    }
    if(!flag)
    {
    res++;
    }
    }
    cout<<res<<endl;
    return res;
    }
    };
    posted @   萧海~  阅读(32)  评论(0编辑  收藏  举报
    相关博文:
    阅读排行:
    · winform 绘制太阳,地球,月球 运作规律
    · AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
    · 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
    · 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
    · 上周热点回顾(3.3-3.9)
    历史上的今天:
    2021-06-08 VS+MySQL——2. 使用C API 连接MySQL数据库
    点击右上角即可分享
    微信分享提示
    电磁波切换