String类相关oj练习

1.第一次只出现一次的字符

做题首先看清要求和提示:

给定一个字符串 s ,找到 它的第一个不重复的字符,并返回它的索引 。如果不存在,则返回 -1 。

提示:

  • 1 <= s.length <= 105
  • s 只包含小写字母

 这就要用到我们所学的字符串的知识了,我们可以通过String的常用方法chatAt,直接查找当前位置的字符。

接下来有两种思路,一种就是暴力求解,另外一种就是运用哈希的思想

暴力求解:
定义两个变量,i和j,i从0下标开始遍历,j从1下标开始遍历,当j遍历完之后,没有找到相同的,直接退出循环。如果找到相同的,则i++。如下图(这种方式极力不推荐,因为时间复杂度较大,我们说另一种方式)

哈希思想

 可以先,定义一个0到122的count数组。

由题目可知,s只包含小写字母,a的Ascii码值为97,可以将字符存在对应下标下面。

 通过字符对应的数组下标自增加1,做好标记。

 然后找到数组中为1,且第一次出现的字符。

1.1定义一个计数数组

下标0~96的空间无法利用,可以对他进行优化

 通过当前字符与‘a’相减,从而缩小数组范围

代码如下:

 int[] count = new int [26];

1.2.遍历字符串 记录次数

//遍历字符串,记录次数
     for(int i = 0;i < n;i++){
         
        count[s.charAt(i) - 'a']++;
     }

 

1.3.再次遍历字符串

这时不要遍历count数组,这个做法是错误的。

//再次遍历
     for(int i = 0;i < n;i++){
         
         if(count[s.charAt(i)-'a']==1)
             return i;
         
        }
        return -1;    

 跳出循环,没有只出现一次的字符,返回-1.

1.4 代码实例

 public static int firstUniqChar(String s) {
        //定义一个计数数组
        int[] chars = new int[26];
        //遍历字符串,记录次数
        for(int i = 0; i < s.length(); i++){
            chars[s.charAt(i) - 'a']++;
        }
        //再次遍历
        for (int i = 0; i < s.length(); i++) {
            if(chars[s.charAt(i) - 'a'] == 1)return i;
        }
        return -1;
    }

 

我们可以看到通过时间是6ms,但我觉得还有改进的空间。

于是进行了下列的改进:

1. 我直接求出字符串的长度,并通过ch接收,减少循环条件求字符串长度的时间

2.将定义数组放在后面,可以减少一毫秒的运算速度,这个原因,现在还不知道。zu

改进的代码如下:

    int ch = s.length();
    int[] count = new int [26];
    //遍历字符串,记录次数
     for(int i = 0;i < ch;i++){
         
        count[s.charAt(i) - 'a']++;
     }
     //再次遍历
     for(int i = 0;i < ch;i++){
         
         if(count[s.charAt(i)-'a']==1)
             return i;
         
        }
        return -1;                              
    }

 

2.最后一个单词的长度

题目:

计算字符串最后一个单词的长度,单词以空格隔开,字符串长度小于5000。(注:字符串末尾不以空格为结尾)

 本题我采用三种方式来做,当然还有更多的方式可供大家探索。

2.1.第一种方式运用String常用方法split进行分割

通过split函数将原字符串分割为字符串数组。如下图示例:

 字符串数组最后一个元素即是原字符串的最后一个单词,直接输出其长度。

代码如下:

import java.util.Scanner;
 
public class Main{
    public static void main(String[] args){
        //标准输入
        Scanner sc=new Scanner(System.in);
        //键盘输入字符串
        String str=sc.nextLine();
        //以空格分割为字符串数组
        String[] arr=str.split(" ");
        //字符串数组最后一个元素即是原字符串的最后一个单词,直接输出其长度
        System.out.println(arr[arr.length-1].length());
    }
}

  • 时间复杂度:字符串分割需要遍历整个字符串,所以时间复杂度为O(n)。
  • 空间复杂度:最坏情况下需要大小为n-1的字符串数组存储所有的单词,所以空间复杂度为O(n)。

2.2.第二种方法指针

 解题思路

  1. 定义一个指针变量。
  2. 从后往前遍历字符串,当遇到空格时,用指针记录位置信息,并终止循环。
  3. 总长度减去指针到开头一段的长度,即得到最后一个单词的长度。

代码实例:  

import java.util.Scanner;

public class Main{
    public static void main(String[] args){
        //标准输入
        Scanner sc=new Scanner(System.in);
        //键盘输入字符串
        String str=sc.nextLine();
        //定义指针变量
        int index=-1;
        for(int i=s.length()-1;i>=0;i--){
            //从后往前第一个空格的位置
            if(s.charAt(i)==' '){
                index=i;
                break;
            }
        }
        //总长度减去指针到开头一段的长度,即得到最后一个单词的长度
        System.out.println(s.length()-index-1);
    }
}
  • 时间复杂度:最坏情况下遍历整个字符串,所以时间复杂度为O(n)。
  • 空间复杂度:需要额外常数级别的空间,所以空间复杂度为O(1)。

2.3 第三种方式,用lastlndexOf和substring方法

  解题思路

  1. 用lastlndexOf找最后一个空格出现的位置,将位置传给index
  2. 然后用substring方法,从index+1,截取到str字符串末尾
  3. 最后一个单词长度就为,截取的字符串ret的长度

 代码实例: 

public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        // 注意 hasNext 和 hasNextLine 的区别
        while (in.hasNextInt());// 注意 while 处理多个 case
            String str = in.nextLine();
            int index = str.lastIndexOf(" ");
            String ret = str.substring(index+1);
           System.out.println(ret.length());
        }
    

3.检查字符串是否为回文

3.1题目:

如果在将所有大写字符转换为小写字符并移除所有非字母数字字符之后,短语正着读和反着读都一样。则可以认为该短语是一个 回文串 。

字母和数字都属于字母数字字符

这题采用双指针的做法来做

3.2解题思路:

初始时,左右指针分别指向 字符串 的两侧,随后我们不断地将这两个指针相向移动,每次移动一步,并判断这两个指针指向的字符是否相同。当这两个指针相遇时,就说明 字符串 是回文串。

 

先判断条件,由题目可知。移除所有非字母数字字符,字母数字都属于字母数字字符

 if((ch >= 'a' && ch <= 'z')||(ch >= '0' && ch <= '9')){
            return false;
        }

 运用toLowerCase:方法将字符串转换为小写字母,以便在判断回文时不区分大小写。

 

3.3代码示例

public boolean isPalindrome(String s) {
        s = s.toLowerCase();
        int left =  0;
        int right = s.length()-1;
        while(left < right){
            while(left < right && isCharacterNum(s.charAt(left))){
                left ++;
            }
            while(left < right && isCharacterNum(s.charAt(right))){
                right --;
            }
            if(s.charAt(left)!= s.charAt(right)){
                return false;
            }else{
                left++;
                right--;
            }
            
            }
            return true; 
            
        }
    private  boolean isCharacterNum(char ch){
        if((ch >= 'a' && ch <= 'z') ||(ch >= '0' && ch <= '9')){
            return false;
        }
        return true;
    
    }

通过以下两种方法,可以直接获取字母和数字

 

 优化代码如下:

public boolean isPalindrome(String s) {
        s = s.toLowerCase();
        int left =  0;
        int right = s.length()-1;
        while(left < right){
            while(left < right && isCharacterNum(s.charAt(left))){
                left ++;
            }
            while(left < right && isCharacterNum(s.charAt(right))){
                right --;
            }
            if(s.charAt(left)!= s.charAt(right)){
                return false;
            }else{
                left++;
                right--;
            }
            
            }
            return true; 
            
        }
    private  boolean isCharacterNum(char ch){
        if(Character.isDigit(ch) || Character.isLetter(ch)){
            return false;
        }
        return true;
    
    }

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

win11 查看 wifi 密码

** win11 查看 wifi 密码 ** 第一种方法&#xff1a; 1.点击桌面左下角的开始菜单&#xff0c;选择“设置”。 2.在网络和internet中选择“高级网络设置”。 3.在相关设置下方点击“更多网络适配器选项”。 4.右击“WLAN”&#xff0c;在WLAN信息窗口点击“状态”。 5.…

月入10.5k;36岁生物专业转行网优,选择真的比努力更重要!

张雪峰说&#xff1a;普通家庭的孩子选择专业首要要考虑的是能不能就业&#xff1f;能不能拿到高薪&#xff1f;因为除了你的父母&#xff0c;没人会对你的未来负责。 学历和专业哪个更重要&#xff1f;不同的人往往会有不同的解答&#xff0c;今天故事的主人公H先生毕业于武汉…

关于使用vscode搭建c/c++编程环境

目录 关于使用vscode搭建c/c编程环境一、前言二、安装 IDE 二、安装TDM-GCC安装三、安装C/C环境四、编写代码并进行编译 关于使用vscode搭建c/c编程环境 一、前言 一直觉得vscode是生产强有力的生产工具&#xff0c;基于此&#xff0c;做一篇学习笔记进行记录。 二、安装 ID…

centos7系统下nginx1.24.0升级

如果没有这些目录&#xff0c;请先创建: mkdir /data/software mkdir /data/program提前下载所需的软件&#xff1a; cd /data/software wget https://ftp.pcre.org/pub/pcre/pcre-8.42.tar.gz wget https://nginx.org/download/nginx-1.24.0.tar.gz安装nginx cd /data/soft…

正弦实时数据库(SinRTDB)使用(3)-用户管理

通过实时数据库管理工具登录后&#xff0c;在头部功能区的用户管理或左侧导航菜单的用户管理都可以打开用户管理功能界面&#xff0c;用户管理功能界面展示在中部主窗口区。 用户管理界面如下所示&#xff1a; 用户管理顶部包含刷新、添加用户、修改角色、修改密码及删除用户等…

【CASS精品教程】CASS添加标准图幅(50×50cm+50×40cm)

大比例尺地形图图幅一般分为正方形和矩形分幅两种,本文讲解CASS中添加标准图幅(5050cm、5040cm)的方法。 文章目录 一、CASS参数配置二、添加标准图幅(5050cm)三、添加标准图幅(5040cm)打开基于CASS自带案例数据study.dat绘制好的地形图study.dwg,如下图所示,下面来演示两种…

近年来,常见5大软件开发项目管理工具

时代进步&#xff0c;技术进步&#xff0c;汇总下近几年5大常用的软件开发项目管理工具。 1、微软项目管理软件 Microsoft Project&#xff08;或MSP&#xff09;是由微软开发销售的项目管理软件程序。软件设计目的在于协助项目经理制定发展计划、为任务分配资源、跟踪进度、管…

2024年给Mac电脑提速小妙招

经常听到小伙伴在抱怨PC电脑很慢&#xff0c;但是其实Mac电脑随着用的时间增长&#xff0c;运行速度也会越来越慢&#xff0c;那么造成Mac运行慢的原因有很多&#xff0c;可能是操作系统过时未更新&#xff0c;也可能是内存&#xff08;RAM&#xff09;不足&#xff0c;以下小编…

IDEA2023版本整合SpringBoot热部署

✅作者简介&#xff1a;大家好&#xff0c;我是Leo&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Leo的博客 &#x1f49e;当前专栏&#xff1a; 开发环境篇 ✨特色专栏&#xff1a; M…

Avue-crud表格操作栏不显示修改、删除按钮

2024-03-28 奇了怪了&#xff0c;CSDN自动把我之前的文章设置为VIP了&#xff0c;怪不得有时候搜东西看着看着要收费&#xff0c;现在找东西都不好找&#xff0c;我已经反馈不同意了&#xff0c;看看能不能给我取消吧 今天用Avue的时候发现操作栏的按钮没了&#xff0c;按照文…

mysql进阶查询

按关键字排序 PS:类比于windows 任务管理器 使用 SELECT 语句可以将需要的数据从 MySQL 数据库中查询出来&#xff0c;如果对查询的结果进行排序&#xff0c;可以使用 ORDER BY 语句来对语句实现排序&#xff0c;并最终将排序后的结果返回给用户。这个语句的排序不光可以针对某…

vue3动态绑定style

vue3动态绑定style :style"{属性名&#xff1a;变量}"直接引用对象 :style"对象"绑定一个含多个样式的数组 :style"[styleA, styleB]" :style“{属性名&#xff1a;变量}” 变量的赋值可以根据自己的业务做出调整 直接引用对象 :style“对象”…

Transformer的前世今生 day06(Self-Attention和RNN、LSTM的区别)

Self-Attention和RNN、LSTM的区别 RNN的缺点&#xff1a;无法做长序列&#xff0c;当输入很长时&#xff0c;最后面的输出很难参考前面的输入&#xff0c;即长序列会缺失上文信息&#xff0c;如下&#xff1a; 可能一段话超过50个字&#xff0c;输出效果就会很差了 LSTM通过忘…

fuzzywuzzy,一个好用的 Python 库!

目录 前言 安装 基本功能 1. 字符串相似度比较 2. 模糊匹配与排序 实际应用场景 1. 数据清洗 2. 文本匹配与搜索 3. 搜索引擎优化 总结 前言 大家好&#xff0c;今天为大家分享一个好用的 Python 库 - fuzzywuzzy Github地址&#xff1a;https://github.com/seatgeek/fu…

计算机网络基础——网络安全/ 网络通信介质

chapter3 网络安全与管理 1. 网络安全威胁 网络安全&#xff1a;目的就是要让网络入侵者进不了网络系统&#xff0c;及时强行攻入网络&#xff0c;也拿不走信息&#xff0c;改不了数据&#xff0c;看不懂信息。 事发后能审查追踪到破坏者&#xff0c;让破坏者跑不掉。 网络…

MySQL进阶-----索引的语法与SQL性能分析

目录 前言 一、索引语法 1.SQL语法 2.案例演示 二、SQL性能分析 三、慢查询日志 1.开启日志 2.测试样例 四、profile详情 1.开启profile 2.profile测试SQL语句 五、explain详情 1.语法结构 2.执行顺序示例&#xff08;id&#xff09; 3.执行性能示例(type) 前言 本…

常用的苹果应用商店上架工具推荐

摘要 移动应用app上架是开发者关注的重要环节&#xff0c;但常常会面临审核不通过等问题。为帮助开发者顺利完成上架工作&#xff0c;各种辅助工具应运而生。本文探讨移动应用app上架原理、常见辅助工具功能及其作用&#xff0c;最终指出合理使用工具的重要性。 引言 移动应…

考研数学|汤家凤1800基础部分要做完吗?

我教你一个方法&#xff0c;保证让你高质量的做完1800基础部分&#xff0c;而且还不用把所有题目都做了 我当然不是教你如何投机取巧&#xff0c;投机取巧是考不了高分的&#xff0c;我教你的都是我在实际考研过程中实际运用到的方法&#xff01; 其实这个方法也是我在二战的时…

StatefulBuilder 和 Builder

前言 果然了解的越多&#xff0c;越发现自己狗屁都不是。StatefulBuilder 和 Builder 之前真的不知道。还是在 对话框状态管理 中了解到了这两个东西。 简介 以下内容来自通义灵码 在Flutter中&#xff0c;StatefulBuilder 和 Builder 都是用来动态构建 widget 树的组件&am…

2024年第十届国际虚拟现实大会(ICVR 2024)即将召开!

会议面向虚拟现实、增强现实、人工智能等互联网新技术领域的专家及学者&#xff0c; 致力于共同促进国内外虚拟现实的发展与应用。 2014年至今&#xff0c;ICVR在全球新加坡&#xff0c;美国洛杉矶&#xff0c;中国成都&#xff0c;香港等国家及地区召开&#xff0c;面向虚拟现…