LeetCode 709. To Lower Case【字符串】简单

本文属于「征服LeetCode」系列文章之一,这一系列正式开始于2021/08/12。由于LeetCode上部分题目有锁,本系列将至少持续到刷完所有无锁题之日为止;由于LeetCode还在不断地创建新题,本系列的终止日期可能是永远。在这一系列刷题文章中,我不仅会讲解多种解题思路及其优化,还会用多种编程语言实现题解,涉及到通用解法时更将归纳总结出相应的算法模板。

为了方便在PC上运行调试、分享代码文件,我还建立了相关的仓库。在这一仓库中,你不仅可以看到LeetCode原题链接、题解代码、题解文章链接、同类题目归纳、通用解法总结等,还可以看到原题出现频率和相关企业等重要信息。如果有其他优选题解,还可以一同分享给他人。

由于本系列文章的内容随时可能发生更新变动,欢迎关注和收藏征服LeetCode系列文章目录一文以作备忘。

Given a string s, return the string after replacing every uppercase letter with the same lowercase letter.

Example 1:

Input: "Hello"
Output: "hello"

Example 2:

Input: "here"
Output: "here"

Example 3:

Input: "LOVELY"
Output: "lovely"

Constraints:

  • 1 <= s.length <= 100
  • s consists of printable ASCII characters.

题意:将字符串中的大写字母转为小写。


解法1 库函数

C++直接用 tolower 函数:

//C++ version
class Solution {
public:
    string toLowerCase(string str) { 
        for (char &c : str) c = tolower(c);
        return str;
    }
};
//执行用时:0 ms, 在所有 C++ 提交中击败了100.00% 的用户
//内存消耗:6.1 MB, 在所有 C++ 提交中击败了32.49% 的用户

Java可用 StringtoLowerCase()

//Jave version
class Solution {
    public String toLowerCase(String s) {
        return s.toLowerCase();
    }
}
//执行用时:0 ms, 在所有 Java 提交中击败了100.00% 的用户
//内存消耗:36.6 MB, 在所有 Java 提交中击败了41.90% 的用户

解法2 位运算

由ASCII码表可知,要令字母都变小写,只需 ch |= 32 ;字母都变大写,则要 ch &= -33 ,或者 ch &= 0xdf ;大小写翻转,写成 ch ^= 32

下面是以前写的代码:

class Solution {
public:
    string toLowerCase(string str) { 
        for (char &c : str) c |= 32;
        return str;
    }
};

现在过不了了,因为字符串中不仅仅只有字母,还有其他可打印字符。修改后的代码如下:

//C++ version
class Solution {
public:
    string toLowerCase(string s) {
        for (char &c : s) if (isalpha(c)) c |= 32;
        return s;
    }
};
//执行用时:0 ms, 在所有 C++ 提交中击败了100.00% 的用户
//内存消耗:5.9 MB, 在所有 C++ 提交中击败了84.58% 的用户

解法3 对不可变字符串的写法

由于Java的 String 不可变,又不想用库函数,就要写成如下形式:

//Java version
class Solution {
    public String toLowerCase(String s) {
        StringBuilder sb = new StringBuilder();
        for (char c : s.toCharArray()) {
            if (c >= 'A' && c <= 'Z') sb.append((char)(c + 32));
            else sb.append(c);
        }
        return sb.toString();
    }
}
//执行用时:0 ms, 在所有 Java 提交中击败了100.00% 的用户
//内存消耗:36.2 MB, 在所有 Java 提交中击败了96.16% 的用户
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

memcpy0

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值