Offer 驾到,掘友接招!我正在参与2022春招打卡活动,点击查看活动详情。
现在前端很多岗位面试需要有一定的算法基础,或者说经常刷算法的会优先考虑。
因此每天刷刷LeetCode非常有必要
在这之前我也刷过一些算法题,也希望以后也坚持刷,跟某掘友一样,我也想刷穿 LeetCode
一、题目描述
给你一个字符串 s ,将该字符串中的大写字母转换成相同的小写字母,返回新的字符串。
示例 1:
输入:s = "Hello"
输出:"hello"
示例 2:
输入:s = "here"
输出:"here"
示例 3:
输入:s = "LOVELY"
输出:"lovely"
提示:
1 <= s.length <= 100
s 由 ASCII 字符集中的可打印字符组成
来源:力扣(LeetCode) 链接:leetcode-cn.com/problems/to… 著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
二、思路分析
同一个字符的小写与大写在ASCII编码中,码值相差32,
所以我们可以遍历字符,如果该字符位小写,将其ASCII加32后再转为字符就是其大写。
三、代码实现
/**
* @param {string} s
* @return {string}
*/
var toLowerCase = function(str) {
let ret = '';
for(let i = 0; i < str.length; i++){
// 字符串第一个字符的 Unicode 编码
let code = str.charCodeAt(i);
if(code <= 90 && code >= 65){ // 65~90 a~z
// 将 Unicode 编码转为一个字符
ret += String.fromCharCode(code + 32);
}else{
ret += str[i];
}
}
return ret;
};
/**
* @param {string} s
* @return {string}
*/
var toLowerCase = function(str) {
let ret = '';
for(let i = 0; i < str.length; i++){
// 字符串第一个字符的 Unicode 编码
let code = str.charCodeAt(i);
if(code <= 90 && code >= 65){ // 65~90 a~z
// 将 Unicode 编码转为一个字符
ret += String.fromCharCode(code + 32);
}else{
ret += str[i];
}
}
return ret;
};
四、总结
以上就是本道题的所有内容了,本系列会持续更,欢迎点赞、关注、收藏,另外如有其他的问题,欢迎下方留言给我,我会第一时间回复你,感谢~