又是一道恶心的简单题。

一开始没想到这么多情况的,幸好LeetCode是个很人性化的oj,能让你知道你在哪个case上错了,否则一辈子都过不了。

考虑不周到只能一个个补了。

列举一下恶心的case

//" 010"
//" +004500"
//" -0012a42"
//"2147483648"
//" b11228552307"
//"18446744073709551617"
//" r11384376420"

所有要注意的情况是:

  • 字符串前置的空格需要清除;//读掉所有空格
  • 无视前导0
  • 数字前最多允许1个"+"或"-",出现多个时返回0;
  • 数字中出现不为数字的符号时即认为数字结束,比如"252ab","252-2","252 09"都判定为252;//找到第一个非数字的地方
  • 数字大于INT_MAX时,返回INT_MAX,小于INT_MIN时,返回INT_MIN。

其实没有考到什么算法,就是if else而已

一开始的代码(觉得有必要贴出来,让以后的自己看看-_-)

public static int myAtoi(String str) {

long temp = 0;

//空白
if(str.length()==0)
return 0;
//非数字

//单个数字
else if(str.length()==1){
//System.out.println((int)str.charAt(0)-48);

if(48<=str.charAt(0)&&str.charAt(0)<=57)
return (int)str.charAt(0)-48;
else
return 0;

}

//多个数字
else{

//读掉开头的空格
int start = 0;
for(start=0;start<str.length();start++)
if(str.charAt(start)!=' ')
break;

if(start==str.length()){
System.out.println("all blank");
return 0;
}

//除开头外判断是否全是数字
//找到非数字的地方

int end = 0;

for(end=start+1;end<str.length();end ++)
if(!(48<=str.charAt(end)&&str.charAt(end)<=57)){

System.out.println(str.charAt(start));
System.out.println("not num");
System.out.println("end-->"+end);
break;

}

if(!(48<=str.charAt(start)&&str.charAt(start)<=57)&&!(48<=str.charAt(start+1)&&str.charAt(start+1)<=57)){

System.out.println("not num");
return 0;

}

if(str.charAt(start)=='+'){

System.out.println(str.charAt(start));

if(end-start>=13)
return 2147483647;

if(start+1==end-1)
return ((int)str.charAt(start+1)-48);

for(int i=start+1;i<end;i++){

//System.out.println("temp--->"+temp);
//System.out.println((int)str.charAt(i)-48);

if(str.charAt(i)==' ')
continue;

temp = temp*10+((int)str.charAt(i)-48);

//System.out.println("now --->"+temp);

}

//System.out.println(temp);
System.out.println("zhengshu1");

if(temp>=2147483647)
return 2147483647;
if(temp<=-2147483648)
return 2147483647;

return (int)temp;

}

else if(str.charAt(start)=='-'){

if(start+1==end-1)
return -((int)str.charAt(start+1)-48);

if(end-start>=13)
return -2147483648;

for(int i=start+1;i<end;i++){

//System.out.println("temp--->"+temp);
//System.out.println((int)str.charAt(i)-48);

if(str.charAt(i)==' ')
continue;

temp = temp*10+((int)str.charAt(i)-48);

//System.out.println("now --->"+temp);

}

System.out.println(temp);

temp = -temp;

System.out.println("fushu");

if(temp>=2147483647)
return -2147483648;
if(temp<=-2147483648){

System.out.println("fushu min ");
return -2147483648;
}

return (int)temp;

}
else{

System.out.println(start-end);

if(end-start>=13)
return 2147483647;

System.out.println(str.charAt(start));
System.out.println(end);

if(!(48<=str.charAt(start)&&str.charAt(start)<=57))
return 0;

if(start==end-1)
return ((int)str.charAt(start)-48);

for(int i=start;i<end;i++){

//System.out.println("temp--->"+temp);
//System.out.println((int)str.charAt(i)-48);

if(str.charAt(i)==' ')
continue;

temp = temp*10+((int)str.charAt(i)-48);

//System.out.println("now --->"+temp);

}

System.out.println(temp);
System.out.println("zhengshu2");

if(temp>=2147483647)
return 2147483647;
if(temp<=-2147483648)
return 2147483647;

return (int)temp;

}

}

}

以下是综合了所有情况但是高度简洁的代码:

int myAtoi(string str) {

int length = str.size();

long long ret_64 = 0;

int op = 1; int p = 0;

while (str[p] == ' ') ++p;

if (str[p] == '+' || str[p] == '-')

{ if (str[p] == '-') op = -1; p++; }

for (int i = p; i < length; ++i)

if ('0' <= str[i] && str[i] <= '9')

{ ret_64 = ret_64 * 10 + (str[i] - '0');

if ((op == -1 && ret_64 > 2147483648LL))

return -2147483648;

if ((op == 1 && ret_64 > 2147483647LL))

return 2147483647; }

else

break;

return (int)ret_64 * op; }

总结一下:

没有技巧可言,就是常见的判断溢出(用long),一个个构建起一个数字(temp = temp*10+((int)str.charAt(i)-48);),字符转数字用ASCII码。

LeetCode题解 #8 String to Integer (atoi)的更多相关文章

  1. 《LeetBook》leetcode题解(8): String to Integer (atoi) [E]——正负号处理

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...

  2. 【LeetCode】8. String to Integer (atoi) 字符串转换整数

    作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 公众号:负雪明烛 本文关键词:字符串转整数,atoi,题解,Leetcode, 力扣,P ...

  3. 【一天一道LeetCode】#8. String to Integer (atoi)

    一天一道LeetCode系列 (一)题目 Implement atoi to convert a string to an integer. Hint: Carefully consider all ...

  4. 【LeetCode】008. String to Integer (atoi)

    Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input cases. ...

  5. 【LeetCode】8. String to Integer (atoi) 字符串转整数

    题目: Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input ca ...

  6. 【leetcode】8. String to Integer (atoi)

    题目描述: Implement atoi to convert a string to an integer. Hint: Carefully consider all possible input ...

  7. LeetCode(8) - String to Integer (atoi)

    虽然是easy,却是比较繁琐的一道题,需要考虑各种边界条件.在WA了好几遍之后,才把各种边界条件给补全.需要考虑到的因素如下: 输入不合法字符,非"0-9",对于首位,合法字符还包 ...

  8. leetcode day6 -- String to Integer (atoi) &amp;&amp; Best Time to Buy and Sell Stock I II III

    1.  String to Integer (atoi) Implement atoi to convert a string to an integer. Hint: Carefully con ...

  9. Kotlin实现LeetCode算法题之String to Integer (atoi)

    题目String to Integer (atoi)(难度Medium) 大意是找出给定字串开头部分的整型数值,忽略开头的空格,注意符号,对超出Integer的数做取边界值处理. 方案1 class ...

随机推荐

  1. Java之OO的特性与原则

    OO(Object-Oriented)面向对象     面向对象,有三个特性.五个原则之说. 特性 封装     顾名思义,封装就好比一个黑盒子,内部被隐藏,只有几个接口与外界相连.具体来说,所谓封装 ...

  2. 使用python处理selenium中的获取元素属性问题

    # 获取我的订单元素class属性值 at = self.driver.find_element_by_link_text('我的订单').get_attribute('class') # 判断cla ...

  3. 解决遇到Linux网络配置,从熟悉网络配置文件入手

    如果接触过Linux,网络配置是一个比较棘手的问题.但是Linux是文件为基础来构建的系统,包括我们windows中设备,Linux也视为文件.所以只要我们明白文件的作用.就能对Linux更加的熟悉, ...

  4. qt creator在Qt5中中文显示的问题

    当我们用Qt Creater时,经常出会出现如下问题: 处理方法如下:用记事本打开你的源代码,然后点另存为,utf-8,编码覆盖,这时中文就没问题了但是会乱码.在字符串前加个宏QStringLiter ...

  5. 用eclipse运行java程序显示找不到main class,网上的方法都试了,还是不行,有没有知道怎么解决的呀!

    编译器问题,jdk版本不对,Window --> Preferences -->Java --> compiler中的compiler compliance level,这里选你当前 ...

  6. easyui datagrid 基础方法和事件

    数据表格属性(DataGrid Properties) 属性继承控制面板,以下是数据表格独有的属性. 名称 类型 描述 默认值 columns array 数据表格列配置对象,查看列属性以获取更多细节 ...

  7. java 工作流

    BPM是jboss旗下遵守LGPL许可的java开源工作流,功能比较完善,从4.0开始引入了pvm的概念,支持jPDL.BPEL等流程定义语言.由于相关资料还比较少,开发自己的一个demo还不是太容易 ...

  8. 用 Linux blkid 命令查找块设备详情

    今天我们将会向你展示如何使用 lsblk 和 blkid 工具来查找关于块设备的信息,我们使用的是一台安装了 CentOS 7.0 的机器. lsblk lsblk 是一个 Linux 工具,它会显示 ...

  9. Exce信息提取

    Exce信息提取 Private Declare Sub Sleep Lib "kernel32" (ByVal dwMilliseconds As Long) Sub 信息汇总( ...

  10. (转)Inno Setup入门(二)——修改安装过程中的图片

    本文转载自:http://blog.csdn.net/augusdi/article/details/8564793 修改安装过程中的图片 一般编译之后,安装过程中出现在左边图片是是下图这个样子的: ...