算法通关村第12关【青铜】| 字符串转换问题

1.转换成小写字母

思路:ASCll码中,a-z:97-122 A-Z:65-90

小写转大写-32,大写转小写+32

java 复制代码
class Solution {
    public String toLowerCase(String s) {
        int len = s.length();
        StringBuilder str = new StringBuilder();
        for(int i = 0;i<len;i++){
            char c = s.charAt(i);
            if(c >= 'A' && c <='Z'){
                c += 32;
            }
            str.append(c);
        }
        return str.toString();
    }
}

2.字符串转换整数

思路:判断各种边界值,res直接*10会溢出,需要进行大小判断,如何判断?

一般res*10>max说明越界,转换一下res>max/10说明越界

但是这里有个问题如果一个数字为2147483648,res == max/10

这时需要(max-str[i]) / 10,如果res的最后一位数大于7,那么res>max/10

java 复制代码
class Solution {
    public int myAtoi(String s) {
        char[] str = s.toCharArray();
        int sign = 1;
        int res = 0;
        int loop = 0;
        int max = Integer.MAX_VALUE;
        for(int i = 0;i<str.length;i++){
            if(loop == 1 && (str[i] == '-' || str[i] == '+'||str[i] == ' ')){
                break;
            }
            if(str[i]=='-'){
                sign = -1;
                loop = 1;
                continue;
            }
            if(str[i] == '+'){
                loop =1;
                continue;
            }
            if(str[i] != ' ' && (str[i]<'0' || str[i] >'9')){
                break;
            }
            if(str[i]>='0' && str[i] <='9'){
                int d = str[i] - '0';
                if(sign == 1 && (max- d)/10< res){
                    return max;
                }
                if(sign == -1 && (max - d) / 10 < res){
                    return -max - 1;
                }
                res = res*10 + d;
                loop = 1;
            }
                        
        }
        return res*sign;
    }
}
相关推荐
rockmelodies10 分钟前
亿赛通脚本远程调试配置技巧
java·亿赛通·debug调试
CC码码12 分钟前
前端字符串排序搜索可以更加细化了
前端·javascript·面试
喵爱吃鱼12 分钟前
kuma-ui中Flex vs FlexMin的关键区别
前端
codingMan15 分钟前
[Android Compose] 拒绝闪烁!打造丝滑的聊天页面列表(仿微信效果)
前端
你别追我跑不动17 分钟前
基于代码扫描的 Icon 优化实践
前端·性能优化
磊磊磊磊磊18 分钟前
用AI做了个排版工具,分享一下如何高效省钱地用AI!
前端·后端·react.js
❥ღ Komo·19 分钟前
K8s蓝绿发布实战:零停机部署秘籍
java·开发语言
喵爱吃鱼19 分钟前
flex 0 flex 1 flex none flex auto 应该在什么场景下使用
前端
雾散声声慢20 分钟前
解决 iOS 上 Swiper 滑动图片闪烁问题:原因分析与最有效的修复方式
前端·css·ios
小安同学iter23 分钟前
天机学堂-排行榜功能-day08(六)
java·redis·微服务·zset·排行榜·unlink·天机学堂