算法通关村第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;
    }
}
相关推荐
云烟成雨TD几秒前
Spring AI Alibaba 1.x 系列【56】SAA Admin 平台功能介绍
java·人工智能·spring
Gauss松鼠会几秒前
GaussDB(DWS) 资源监控Topsql
java·网络·数据库·算法·oracle·性能优化·gaussdb
夏日听雨眠1 分钟前
数据结构(快速排序)
java·数据结构·算法
lihaozecq2 分钟前
Agent 开发的 skills 机制设计 - 渐进式披露
前端·agent·ai编程
薇茗2 分钟前
【初阶数据结构】 升沉有序的平仄 排序 3
c语言·开发语言·数据结构·算法·排序算法·文件归并排序
字节高级特工4 分钟前
C++11(一) 革新:右值引用与移动语义
java·开发语言·c++·人工智能·后端
薇茗4 分钟前
【初阶数据结构】 升沉有序的平仄 排序 2
c语言·数据结构·算法·排序算法·快排精讲
郝学胜-神的一滴6 分钟前
系统设计 012:从用户系统出发,吃透缓存、数据库与高并发设计
java·数据库·python·缓存·php·软件构建
安生生申6 分钟前
uni-app 连接 JDY-31 蓝牙串口模块实践
c语言·前端·javascript·stm32·单片机·嵌入式硬件·uni-app
AI科技星9 分钟前
强哥德巴赫猜想(1+1)终极证明(2026 年5月 21 日)
开发语言·人工智能·算法·计算机视觉·量子计算