算法通关村之字符串(实战训练)经典问题:转换小写字母、字符串反转、K个一组反转、仅反转字母

基础知识(青铜挑战)

转换成小写字母
  • 遍历该字符串,依次转换为小写,存入新的字符串中

具体代码如下:
java 复制代码
  public static String toLowerCase(String s) {
        int n = s.length();
        char[] chars = s.toCharArray();
        for (int i = 0; i < n; ++i) {
            if (chars[i] >= 65 && chars[i] <= 90) {
                chars[i] += 32;
            }
        }
        String str = new String(chars);
        return str;
    }

实战训练(白银挑战)

反转字符串
  • 思路:

    • 使用双指针,一个在前,一个在后,相向移动,遍历字符串

    • 在遍历的过程中,将两指针指向的元素交换位置

    • 直到两指针相遇

具体代码如下:(2023/09/30早)
java 复制代码
 public static void reverseString(char[] s) {
        int n = s.length;
        for (int left = 0, right = n - 1; left < right; ++left, --right) {
            char tmp = s[left];
            s[left] = s[right];
            s[right] = tmp;
        }
    }
K个一组反转
仅反转字母
  • 我们有两种思路:

    • 将所有的字母压栈

    • 双指针遍历字符串

压栈法:
  • 遍整个字符串,将字母依次压入栈中

  • 创建一个新的字符串对象,再次遍历该字符串:如果是非字母,将该字符放入新字符串;如果是字母,则从存入弹出的栈顶元素

  • 直到遍历结束

具体代码如下:
java 复制代码
public static String reverseOnlyLetters(String S) {
        Stack<Character> letters = new Stack();
        for (char c : S.toCharArray())
            if (Character.isLetter(c))
                letters.push(c);
​
        StringBuilder ans = new StringBuilder();
        for (char c : S.toCharArray()) {
            if (Character.isLetter(c))
                ans.append(letters.pop());
            else
                ans.append(c);
        }
​
        return ans.toString();
    }
双指针法:
  • 定义两个指针,一个从头向后遍历,一个从后向前,维护字母字符

  • 创建一个新的字符串对象,前指针遍历字符串

  • 如果是非字母,则将该字符放入新字符串;如果是字母,则移动后指针,找到字母,将该字母存入新的字符串

  • 直到前指针遍历结束

具体代码如下:
java 复制代码
public static String reverseOnlyLetters2(String S) {
        if (S == null || S.length() == 0){
            return  S;
        }
​
        StringBuffer ans = new StringBuffer();
        int j =  S.length() - 1;
        for (int i = 0; i < S.length(); i++) {
            if(Character.isLetter(S.charAt(i))){
                while (!Character.isLetter(S.charAt(j)))
                    j--;
                ans.append(S.charAt(j--));
            }else {
                ans.append(S.charAt(i));
            }
        }
        return ans.toString();
    }
相关推荐
24k小善34 分钟前
Flink TaskManager详解
java·大数据·flink·云计算
想不明白的过度思考者40 分钟前
Java从入门到“放弃”(精通)之旅——JavaSE终篇(异常)
java·开发语言
.生产的驴1 小时前
SpringBoot 封装统一API返回格式对象 标准化开发 请求封装 统一格式处理
java·数据库·spring boot·后端·spring·eclipse·maven
猿周LV1 小时前
JMeter 安装及使用 [软件测试工具]
java·测试工具·jmeter·单元测试·压力测试
知来者逆1 小时前
计算机视觉——速度与精度的完美结合的实时目标检测算法RF-DETR详解
图像处理·人工智能·深度学习·算法·目标检测·计算机视觉·rf-detr
晨集1 小时前
Uni-App 多端电子合同开源项目介绍
java·spring boot·uni-app·电子合同
时间之城1 小时前
笔记:记一次使用EasyExcel重写convertToExcelData方法无法读取@ExcelDictFormat注解的问题(已解决)
java·spring boot·笔记·spring·excel
阿让啊1 小时前
C语言中操作字节的某一位
c语言·开发语言·数据结构·单片机·算法
এ᭄画画的北北1 小时前
力扣-160.相交链表
算法·leetcode·链表
椰羊~王小美1 小时前
LeetCode -- Flora -- edit 2025-04-25
java·开发语言