牛客网刷题-将字符串转化为整数

65 篇文章 0 订阅

问题描述

实现函数 atoi 。函数的功能为将字符串转化为整数
提示:仔细思考所有可能的输入情况。这个问题没有给出输入的限制,你需要自己考虑所有可能的情况。

输入描述:
输入一个字符串

输出描述:
输出字符串的整数

示例

示例1

输入
“123”

输出
123

解决思路

分析

  1. 通过遍历方式加和计算,注意需要处理正负号和字母的情况,以及数越界的情况。

方法

  1. 通过遍历方式加和计算,注意需要处理正负号和字母的情况,以及数越界的情况。

代码实现

// 思路1
public class Solution {  
    public int atoi(String str) {
        // write code here
        if (str == null || str.trim().length() < 1)
            return 0;
        //处理掉前后空格
        char[] arr = str.trim().toCharArray();

        int sign = 1, index = 0;
        //判断正负号
        if (arr[0] == '+')
            index++;
        if (arr[0] == '-') {
            sign = -1;
            index++;
        }

        int num = 0;
        for (int i = index; i < arr.length; i++) {
            if (arr[i] - '0' >= 0 && arr[i] - '9' <= 0) {
                //如果当前运算会越界的时候,直接输出结果
                if (num > Integer.MAX_VALUE / 10 || num == Integer.MAX_VALUE / 10 && arr[i] - '7' > 0) {
                    if (sign > 0)
                        return Integer.MAX_VALUE;
                    else
                        return Integer.MIN_VALUE;
                }

                num = 10 * num + arr[i] - '0';
            } else
                //如果是字母,跳出循环
                break;
        }

        return num * sign;
    }
}

时间复杂度分析:
O(N):遍历数组

空间复杂度分析:
O(N):额外的char数组空间

小伙伴如果想测试的话,可以直接到牛客网这个链接做测试

将字符串转化为整数-牛客网

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 好的,我可以回答这个问题。将整数字符串转换整数的方法是使用编程语言中的转换函数,如Python中的int()函数。int()函数可以将字符串转换整数。例如,如果要将字符串"123"转换整数,可以使用以下代码: ``` num_str = "123" num_int = int(num_str) print(num_int) ``` 输出将是整数123。 ### 回答2: 将整数字符串转换整数是一种常见的编程问题。一种简单的方法是使用编程语言中的内置函数或方法来实现。 在许多编程语言中,可以使用"int()"函数将整数字符串转换整数。该函数将字符串作为参数接收,并返回一个对应的整数值。例如,在Python中,可以使用以下代码将整数字符串转换整数: ```python num_str = "123" num_int = int(num_str) print(num_int) # 输出:123 ``` 另一种常见的方法是使用循环遍历整数字符串的每个字符,并将其转换为对应的数字。然后,根据每个数字的权重将它们相加,以获得最终的整数值。以下是使用这种方法在Python中实现的示例代码: ```python num_str = "456" num_len = len(num_str) num_int = 0 for i in range(num_len): digit = ord(num_str[i]) - ord('0') # 将字符转换为数字 weight = 10 ** (num_len - i - 1) # 计算该数字的权重 num_int += digit * weight # 根据权重将数字相加 print(num_int) # 输出:456 ``` 这些方法都可以将整数字符串转换整数,并且在许多编程语言中都可以使用。但要注意的是,当整数字符串无效时(例如包含非数字字符或过大过小时),转换可能失败或返回错误值。因此,在实际应用中需要进行有效性检查或使用异常处理来处理这些情况。 ### 回答3: 将整数字符串转换整数可以使用多种方法。一种简单的方法是使用内置的语言函数来完成转换。 首先,我们可以使用语言函数将整数字符串转换整数,例如Python中的`int()`函数、JavaScript中的`parseInt()`函数或Java中的`Integer.parseInt()`方法。这些函数可以自动识别并处理正负号,并将字符串转换为对应的整数。 例如,在Python中,我们可以使用`int()`函数将整数字符串转换整数: ```python num_str = "123" num = int(num_str) print(num) # 输出:123 ``` 如果要处理负数,只需要在字符串中包含负号即可: ```python num_str = "-456" num = int(num_str) print(num) # 输出:-456 ``` 另外,还可以使用字符串转换和运算的方法手动将整数字符串转换整数。例如,在计算机中,整数可以通过字符的ASCII码来表示,可以将字符串按照位数从高到低进行遍历,并将每一位字符转换为对应的数值,然后根据乘方运算依次相加即可。 以下是一个示例代码,可以将整数字符串转换整数: ```python num_str = "789" num = 0 for digit_char in num_str: digit = ord(digit_char) - ord('0') num = num * 10 + digit print(num) # 输出:789 ``` 无论使用哪种方法,都可以将整数字符串转换整数。通过这些方法,我们可以方便地处理整数字符串,进行数值运算和比较。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值