news 2026/4/15 11:38:15

树|regex正则

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
树|regex正则

lc2047

可以三解,复习了:模拟 状态机 正则

正则+istringstream处理

这才是真正的代码😭

正则表达式 (([a-z]+-)?[a-z]+)?[!,.]? 的结构和匹配逻辑是:
- 核心部分 ([a-z]+-)?[a-z]+ :匹配“纯小写字母”(如 abc )或“小写字母+连字符+小写字母”(如 abc-def ,连字符前后至少1个字母);
- 外层 (...)? :让核心部分可选(但结合实际场景,通常是必填,避免空串);
- 末尾 [!,.]? :匹配0或1个句末标点( ! / , / . )。
整体用于匹配合法单词:允许“纯字母”“字母-连字符-字母”,且可带1个句末标点

#include <regex>

class Solution {

public:

int countValidWords(string sentence) {

regex r1("(([a-z]+-)?[a-z]+)?[!,.]?");

//定义匹配pattern

istringstream iss(sentence);

int ans=0;

string word;

while(iss>>word){

if(regex_match(word,r1)){

ans++;

}

}

return ans;

}

};

判断句子中每个单词是否合法(合法是“纯字母”“字母-字母”或这两类加句末标点),统计合法单词数

状态机 优雅的转移设计
-1:错误
0:空格
1:字母
2:字母+链接符
3:字母+链接符+字母
4:结尾

状态注意的梳理 可以画图枚举 画画就出来啦

class Solution {

public:

int countValidWords(string sentence)

{

int state=0,res=0;

sentence+=' ';

for(auto& c:sentence){

if(c==' '){

if(state==1||state==3||state==4)res++;

state=0; //重置

}

else if('a'<=c&&c<='z'){

if(state==0||state==2)state++;

else if(state==1||state==3)continue;

else state=-1;

}

else if(c=='-'){

if(state==1)state=2;

else state=-1;

}

else if(c=='.'||c==','||c=='!'){

if(state==0||state==1||state==3)

state=4;

else state=-1;

}

else state=-1;

}

return res;

}

};

lc1422

注意 覆盖所有分割点

class Solution {

//左0右1

public:

int maxScore(string s)

{

int n=s.size();

vector<int> p(n+1);

for(int i=1;i<=n;i++)

p[i]=p[i-1]+(s[i-1]-'0');

int ret=0;

for(int i=1;i<n;i++)

{

int f=i-p[i];

int b=p[n]-p[i];

ret=max(ret,f+b);

}

return ret;

}

};

lc563

int dfs

class Solution
{
public:
int findTilt(TreeNode* root)
{
int ret=0;
auto dfs=[&](this auto&& dfs,TreeNode* node)->int
{
if(!node) return 0;
int l=dfs(node->left);
int r=dfs(node->right);

ret+=abs(l-r);
return l+r+node->val;
};
dfs(root);
return ret;
}
};

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 11:26:17

iOS 26.2让用户可再次调整液态玻璃透明度

苹果发布iOS 26.2系统更新&#xff0c;再次为用户提供降低液态玻璃透明度的工具。此次更新允许用户控制锁屏时钟的透明度。此前&#xff0c;苹果已推出一个滑块来控制整个操作系统中液态玻璃元素的不透明度&#xff0c;以回应用户对新设计影响iPhone和其他苹果设备可读性的抱怨…

作者头像 李华
网站建设 2026/4/15 6:47:00

landing page文案写作:LobeChat提升留资率

LobeChat&#xff1a;如何用一个聊天窗口&#xff0c;撬动落地页的留资转化&#xff1f; 在今天这个信息过载的时代&#xff0c;用户对网页的耐心越来越短。一个访客打开你的产品页面&#xff0c;3秒内没找到答案&#xff0c;大概率就会关掉浏览器——无论你花了多少心思写文案…

作者头像 李华
网站建设 2026/4/14 19:47:56

AutoML:自动化AI Agent的模型选择与优化

AutoML&#xff1a;自动化AI Agent的模型选择与优化 关键词&#xff1a;AutoML、自动化机器学习、模型选择、超参数优化、AI Agent、神经网络架构搜索、元学习 摘要&#xff1a;本文深入探讨了AutoML&#xff08;自动化机器学习&#xff09;技术在AI Agent开发中的应用&#xf…

作者头像 李华
网站建设 2026/4/8 10:27:08

ChinaAdminDivisonSHP地理数据项目完整使用指南

ChinaAdminDivisonSHP是一个提供中国行政区划地理数据的开源项目&#xff0c;包含从国家到县级的完整shapefile数据。本文将为GIS新手和开发者提供从安装部署到实战应用的全流程指导。 【免费下载链接】ChinaAdminDivisonSHP 项目地址: https://gitcode.com/gh_mirrors/ch/C…

作者头像 李华
网站建设 2026/4/13 4:06:00

ComfyUI-Manager完整指南:5分钟学会AI绘画插件管理

ComfyUI-Manager完整指南&#xff1a;5分钟学会AI绘画插件管理 【免费下载链接】ComfyUI-Manager 项目地址: https://gitcode.com/gh_mirrors/co/ComfyUI-Manager 还在为ComfyUI复杂的插件安装流程而烦恼吗&#xff1f;ComfyUI-Manager就是你的最佳解决方案&#xff01…

作者头像 李华