leetcode58 末尾单词的长度
又是一道简单题(最近项目事情多有点偷懒),不需要贪心、不需要分治、更不需要 DP,只要最简单的递推就可以解出的题目。但第一次提交没有通过,原因在于边界条件的考虑不到位,所以想要借机总结一下如何确定边界条件。
边界条件就想数学表达式中变量的取值范围,一个数学表达式的成立一定是有限制条件的,程序也是如此,每条逻辑都有它的作用域。
我们在写一条逻辑时,应当习惯性的考虑到,是否逻辑所需的数据都是作用域之内的,是否需要在它之前将作用域外的值过滤掉。
如果不考虑边界条件,我们的逻辑是:
public final int lengthOfLastWord(String s) {int last=s.lastIndexOf(" "); return length-last-1; }
以上逻辑需要保证的是,s 为有效的 String 实例,且不能以空格结尾。
所以做判空处理,并去掉结尾的空格:
if(s==null||s.length()==0){ return 0; } int length=s.length(); while(length!=0&&s.charAt(length-1)==' '){ s=s.substring(0,length-1); length--; }
最坏的情况下,时间复杂度为 O(N),空间复杂度为 O( !N )。空间的消耗在于每次去除空格,都会产生一个长度减一的新字符串。
阶乘级的空间复杂度比较可怕,我们可以通过记录索引带替裁剪字符串:
int length=s.length(); while(length!=0&&s.charAt(length-1)==' '){ length--; } int last=-1; for(int i=length-1;i>=0;i--){ if(s.charAt(i)==' '){ last=i; break; } } return length-last-1;
最坏情况下,时间复杂度 O(N),空间复杂度 O(1)。
当你看清人们的真相,于是你知道了,你可以忍受孤独
分类:
数据结构与算法
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构