自己实现string转int

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/qq_24334403/article/details/82780079

最近离职加入了面试行列,连续几天的碰壁让我不得不反思自己,确实对于自己过于乐观,反思这两年,确实也过得太过于安逸了,曾经心里默默给自己定的计划,每周一篇博客,也只写了两篇就放弃了,而且写的那几篇,质量还不是那么高。我想,这段时间,会是一个很好的学习总结与反思的机会,那么就从今天开始吧,先来一个让我印象深刻的面试题。不使用任何工具类实现string转int。

当我刚看到这个题目,脑海里快速过了一遍,只想到了先判断是否含有非数字,然后呢?不能使用工具类,意味着只能自己用最基本的原理,是的,我想到了ascll码,大致思路就是先将字符串转化为char数组,然后将每个字符转换为对应的数字,并且计算它所在的位数。实现代码如下:

public int stringToInt(String mun){
    char[] nums = mun.toCharArray();
    int length =  nums.length;
    int result = 0;
    for (int i = 0; i < length; i++) {
        int temp = nums[i];
        if(temp>47 && temp < 58){
            result += ( temp - 48) * Math.pow(10, length - 1 - i));
        }
    }
    return result;
}

看起来代码没有任何难度,但是当时被问到的时候真的没有思路,所以特此记录一下。

猜你喜欢

转载自blog.csdn.net/qq_24334403/article/details/82780079