阿亮的算法之路——8. 字符串转换整数 (atoi)

2024-01-07 02:59

本文主要是介绍阿亮的算法之路——8. 字符串转换整数 (atoi),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

题目描述1
题目描述2

这题目难度被归为了中等,但其实我觉得没那么难,当然,我指的是用暴力方法。无非就是判断一下,然后将其拼成一个数字。

首次尝试

按着思路来,将这个字符串转成一个字符数组,先判断第一个字符,正负号、数字或是其它,然后再往后依次判断后面的字符,将满足要求的数字放在一起,最后将其转成一个数字返回即可

public static int myAtoi(String str){if (str == null || str.trim().length() == 0) { return 0; }str = str.trim();boolean isMinus = false;StringBuilder reString = new StringBuilder();char[] chars = str.toCharArray();char firstChar = chars[0];if (firstChar == '-'){isMinus = true;if (chars.length == 1) return 0;}else if (firstChar == '+'){ if (chars.length == 1) return 0; }else if (firstChar >= '0' && firstChar <= '9') { reString.append(firstChar); }else { return 0; }for (int i = 1; i < chars.length; i++){char eachChar = chars[i];if (eachChar >= '0' && eachChar <= '9'){ reString.append(eachChar); }else { break; }}if ("".equals(reString.toString())) return 0;long re;try{re = Long.valueOf(reString.toString());}catch (NumberFormatException e){if (isMinus) return Integer.MIN_VALUE;else return Integer.MAX_VALUE;}if (re > Integer.MAX_VALUE){if (isMinus) return Integer.MIN_VALUE;else return Integer.MAX_VALUE;}else{if (isMinus) return (int)-re;else return (int) re;}}

逻辑不复杂,只是各种判断,代码写得有点多。值得一提的是,其中用了异常处理机制,如果转化失败了,肯定是超过了范围,因为我是将其转化成一个long类型的整数的,那就直接返回0。

提交结果

提交结果1

暴力破解,效率一般都不高,习以为常了。

自己没想别的思路,那就看看大佬的思路叭。

大佬思路

噢噢,原来这题压根没有考察什么很强的算法知识,只是模拟了一下平时的业务场景。所以思路都差不多,只是大佬们用了一个更专业的术语描述:自动机

而且这题,题目中描述环境中只能存储32位的有符号数,意思就是用long类型的变量来存储,已经不符号题意了?算了,就算不能用long类型,也就是在判断每个字符的时候,判断其是否越界,就不去折腾了。下一题,加油 ,噢力给。

这篇关于阿亮的算法之路——8. 字符串转换整数 (atoi)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/578509

相关文章

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Springboot3+将ID转为JSON字符串的详细配置方案

《Springboot3+将ID转为JSON字符串的详细配置方案》:本文主要介绍纯后端实现Long/BigIntegerID转为JSON字符串的详细配置方案,s基于SpringBoot3+和Spr... 目录1. 添加依赖2. 全局 Jackson 配置3. 精准控制(可选)4. OpenAPI (Spri

使用Python实现base64字符串与图片互转的详细步骤

《使用Python实现base64字符串与图片互转的详细步骤》要将一个Base64编码的字符串转换为图片文件并保存下来,可以使用Python的base64模块来实现,这一过程包括解码Base64字符串... 目录1. 图片编码为 Base64 字符串2. Base64 字符串解码为图片文件3. 示例使用注意

在Java中将XLS转换为XLSX的实现方案

《在Java中将XLS转换为XLSX的实现方案》在本文中,我们将探讨传统ExcelXLS格式与现代XLSX格式的结构差异,并为Java开发者提供转换方案,通过了解底层原理、性能优势及实用工具,您将掌握... 目录为什么升级XLS到XLSX值得投入?实际转换过程解析推荐技术方案对比Apache POI实现编程

Python使用FFmpeg实现高效音频格式转换工具

《Python使用FFmpeg实现高效音频格式转换工具》在数字音频处理领域,音频格式转换是一项基础但至关重要的功能,本文主要为大家介绍了Python如何使用FFmpeg实现强大功能的图形化音频转换工具... 目录概述功能详解软件效果展示主界面布局转换过程截图完成提示开发步骤详解1. 环境准备2. 项目功能结

使用Python实现网页表格转换为markdown

《使用Python实现网页表格转换为markdown》在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,本文将使用Python编写一个网页表格转Markdown工具,需... 在日常工作中,我们经常需要从网页上复制表格数据,并将其转换成Markdown格式,以便在文档、邮件或

golang float和科学计数法转字符串的实现方式

《golangfloat和科学计数法转字符串的实现方式》:本文主要介绍golangfloat和科学计数法转字符串的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望... 目录golang float和科学计数法转字符串需要对float转字符串做处理总结golang float

Python如何判断字符串中是否包含特殊字符并替换

《Python如何判断字符串中是否包含特殊字符并替换》这篇文章主要为大家详细介绍了如何使用Python实现判断字符串中是否包含特殊字符并使用空字符串替换掉,文中的示例代码讲解详细,感兴趣的小伙伴可以了... 目录python判断字符串中是否包含特殊字符方法一:使用正则表达式方法二:手动检查特定字符Pytho

MySQL 字符串截取函数及用法详解

《MySQL字符串截取函数及用法详解》在MySQL中,字符串截取是常见的操作,主要用于从字符串中提取特定部分,MySQL提供了多种函数来实现这一功能,包括LEFT()、RIGHT()、SUBST... 目录mysql 字符串截取函数详解RIGHT(str, length):从右侧截取指定长度的字符SUBST

Python将字符串转换为小写字母的几种常用方法

《Python将字符串转换为小写字母的几种常用方法》:本文主要介绍Python中将字符串大写字母转小写的四种方法:lower()方法简洁高效,手动ASCII转换灵活可控,str.translate... 目录一、使用内置方法 lower()(最简单)二、手动遍历 + ASCII 码转换三、使用 str.tr