[Leetcode]第[58]题[JAVA][最后一个单词的长度][字符串]

【问题描述】[简单]

在这里插入图片描述

【解答思路】

  • 直接定位最后一个单词

  • 先找最后一个单词最后一个字母

  • 再找最后一个单词第一个字母

1. 常规做法

时间复杂度:O(N) 空间复杂度:O(1)

class Solution {public int lengthOfLastWord(String s) {int end = s.length() - 1;while(end >= 0 && s.charAt(end) == ' ') end--;if(end < 0) return 0;int start = end;while(start >= 0 && s.charAt(start) != ' ') start--;return end - start;}
}
2. 索引法

trim()去除首尾空格
lastIndexOf(int ch) 最后一个空格出现的下标
时间复杂度:O(N) 空间复杂度:O(1)

class Solution {public int lengthOfLastWord(String s) {s = s.trim();int num = s.length() -1 - s.lastIndexOf(" ");return num;}
}
3. 通用匹配最后一个单词长度

时间复杂度:O(N) 空间复杂度:O(1)

public int lengthOfLastWord(String s) {int start,end ;int index =s.length()-1;while(index>=0 && (!Character.isLetter(s.charAt(index)))){index--;}if(index< 0) return 0;end = index;while(index>=0 && Character.isLetter(s.charAt(index)) ){index--;}start =index;return end - start ;}

【总结】

1.java判断字符串是否是数字/字母

数字 Character.isDigit(char ch)
字母 Character.isLetter(char ch)在这里插入图片描述

2.String类常用函数链接
3.字符串遍历 善用while

参考链接:http://www.blogjava.net/Javaphua/archive/2007/06/05/122131.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/425334.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

The 2014 ACM-ICPC BeiJing D - Dire Wolf HDU - 5115 区间dp

题意 n个狼 排成一排 我们要把一排狼都删除掉 删除一个狼的花费是这个狼的权值和左右两个狼的附加值 求最小花费 分析 考虑区间dp dp[i][j]表示i到j的最小花费 我们可以枚举其中的k 为序列中最后一个删除的元素 然后记忆话搜索 这样下来最深层次的元素最先删除 附加元素…

50session的销毁会话和超时管理

定义一个page1 <% page language"java" import"java.util.*,java.text.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"utf-8"&…

Navicat 连接MariaDB 失败: Host '*' is not allowed to connect to this MariaDB server

Navicat 连接MariaDB 失败&#xff1a; Host * is not allowed to connect to this MariaDB server 题描述&#xff1a;Navicat 为管理方便&#xff0c;连接Linux 中Mariadb失败&#xff0c;如下如下错误&#xff1a;Host * is not allowed to connect to this MariaDB server …

[小技巧][JAVA]判断字符串某一位是否是数字/字母

三种方法 1用JAVA自带的函数 数字 Character.isDigit(char ch) 字母 Character.isLetter(char ch) public static boolean isNumeric(String str){for (int i str.length();--i>0;){ if (!Character.isDigit(str.charAt(i))){return false;}}return true;}2用正则表达式…

[密码学基础][信息安全][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第一篇]不同类型的处理器

这是每个密码学博士生应该知道的52件事系列的第一篇文章。PhD研究生在第一年结束的时候应该掌握这些问题。并且尽可能早的在他们能放弃的时候放弃(23333)无论怎样&#xff0c;我们会将这些问题在接下来的一年里表达出来&#xff0c;我自愿的为这个第一个事情的编写做出贡献。这…

android与php使用base64加密的字符串结果不一样解决方法

base64将字符串转换为字节得到同一个值 一.错误 String signString Base64.encodeToString(signContent.getBytes(),Base64.NO_WRAP); 二.正确 byte[] byteSign Base64.encode(signContent.getBytes(),Base64.NO_WRAP); String signString new String(byteSign); 大多使用ba…

CodeForces 895 B. XK Segments 二分查找

题意 定义n个数和x 让我们在这n个数中找出 多少个不同的对 分析 观察条件我们要找的是对于一个元素ai 找到另外一个元素 aj 使得a[i]<a[j] 所以我们需要排序 也就是对于每一个元素 ai 我们可以确定他后面有k个x的整数区间的范围 假设下界为lb上界为ub 那么 当a[i]除…

[密码学基础][信息安全][每个信息安全博士生应该知道的52件事][Bristol Cryptography][第11篇]DLP、CDH和DDH问题是什么?

这是一系列博客文章中最新的一篇&#xff0c;文章的主题是“做密码学每个博士生都应该知道的52件事”。这一系列问题是为了让博士生们在第一年结束时了解他们应该知道的事情。本博客是数学背景部分的第二部分&#xff0c;关注如何使用群操作设计密码原语。 就像你现在知道的那…

53pagecontext对象

建立一个test08 <% page language"java" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"ISO-8859-1"> <title>Insert title here&l…

51nod 1101 换零钱 简单dp

题意&#xff1a;问在现有面值金额下 输入一个m可以由多少种不同的金额组成 那么可以定义dp[i]表示i金额由多少种不同的金额组成方式 转移方程&#xff1a;dp[i] (dp[i] dp[i-cost[j])%mod&#xff1b; 首先要定义dp[0] 1&#xff1b; 然后枚举面值 看不同数目下该面值可…

[Leetcode][程序员面试金典][面试题16.11][JAVA][跳水板][数学][动态规划]

【问题描述】[简单] 【解答思路】 边界问题 k0 &#xff0c;不能产生跳水板&#xff0c;返回空数组shorter 等于longer&#xff0c;只有一种跳水板&#xff0c;返回longerk 思路 一般情况&#xff0c;k块木板&#xff0c;k种可能 跳水板的长度是 shorter(k-j)longer*j&#x…

54include对象

建立一个test11对象 <% page language"java" import"java.util.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8"%> <!DOCTYPE html> <html> <head> <meta charset"ISO-8859-1">…

[Objective-C语言教程]动态绑定(32)

动态绑定确定在运行时而不是在编译时调用的方法。 动态绑定也称为后期绑定。 在Objective-C中&#xff0c;所有方法都在运行时动态解析。执行的确切代码由方法名称(选择器)和接收对象确定。 动态绑定可实现多态性。例如&#xff0c;考虑一组对象&#xff0c;包括Rectangle和Squ…

55exception对象

定义exception.jsp <% page language"java" import"java.util.*" contentType"text/html; charsetUTF-8"pageEncoding"UTF-8" errorPage"File.jsp" %> <!DOCTYPE html> <html> <head> <meta c…

pta - 1132 Cut Integer

判断这个偶数长度的数平分长度后再乘起来能否被原数整除 #include<iostream> #include<cstdio> #include<cstring> #include<cmath> #include<algorithm> using namespace std; typedef long long ll; int main() {int t;ll n;ios::sync_with_s…

[小错误][JAVA][数组初始化]数组静态初始化和动态初始化不能混用

错误 return new int[1]{shorter*k};error: array creation with both dimension expression and initialization is illegal return new int[1]{shorter*k}; 数组静态初始化和动态初始化混用 解决办法 数组的使用分声明和初始化两部分&#xff0c;两者可同时进行&#xff0c…

pat-1057 Stack 树状数组+二分查找

题意 给我们一个n表示操作数量 然后三种操作 push和pop 还有求中位数的操作 让我们根据操作输出正确的解 分析 用sort排序做 或者 map标记法都会超时 考虑更快的方法 如何快速找到给定一串数的中位数 可以去索引 但是需要排序 题目中告诉我们每个元素都小于1e5 那么也…

[剑指offer]面试题第[43]题[Leetcode][第233题][JAVA][1~n整数中1出现的次数][找规律][递归]

【问题描述】[困难] 【解答思路】 1. 暴力 &#xff08;超时&#xff09; 逐个数统计’1’的数量 时间复杂度&#xff1a;O(N^2) 空间复杂度&#xff1a;O(1) public int countDigitOne(int n) {int count 0;for(int i1;i<n;i){int tmp i;while(tmp>0){if(tmp%101){c…

56jsp登录案例

链接&#xff1a;https://pan.baidu.com/s/1W4UYInbsm17V9_2rFLNGFg 提取码&#xff1a;c5g5 复制这段内容后打开百度网盘手机App&#xff0c;操作更方便哦 login.jsp <% page language"java" import"java.util.*" contentType"text/html; chars…

matplotlib的颜色和控制条

为了方便记忆&#xff0c;收藏备用 一 linestyle - solid line style -- dashed line style -. dash-dot line style : dotted line style 二marker style . point marker , pixel marker o circle marker v triangle_down mark…