博客
关于我
12.把字符串转换成整数
阅读量:192 次
发布时间:2019-02-27

本文共 906 字,大约阅读时间需要 3 分钟。

要解决这个问题,我们需要将一个字符串转换成整数,并确保该字符串是合法的数值表达。如果字符串不是合法的数值,或者数值为0,则返回0。

方法思路

  • 检查空字符串:如果输入字符串为空,直接返回0。
  • 处理正负号:检查字符串的第一个字符是否为'+'或'-',记录符号并将符号字符替换为'0',以便后续处理。
  • 遍历字符:逐个检查字符串中的每个字符是否为数字。如果发现非数字字符,返回0。
  • 计算数值:将字符串中的每个字符转换为对应的数字值,并累加得到总和。
  • 应用符号:根据记录的符号,调整数值的正负,返回最终结果。
  • 解决代码

    int StrToInt(string str) {    if (str.empty()) {        return 0;    }    int flag = 1;    if (str[0] == '-') {        flag = -1;        str[0] = '0';    } else if (str[0] == '+') {        str[0] = '0';    }    int sum = 0;    for (int i = 0; i < str.size(); ++i) {        if (str[i] < '0' || str[i] > '9') {            return 0;        }        sum = sum * 10 + (str[i] - '0');    }    return flag * sum;}

    代码解释

  • 空字符串检查:如果输入字符串为空,直接返回0。
  • 符号处理:检查字符串的第一个字符是否为'-'或'+',记录符号并将符号替换为'0',以避免后续处理中出现非数字字符。
  • 字符遍历:逐个检查每个字符是否为数字。如果发现非数字字符,返回0,表示字符串不合法。
  • 数值计算:将每个字符转换为对应的数字值,并累加得到总和。
  • 符号应用:根据记录的符号,调整数值的正负,最终返回结果。
  • 这个方法确保了我们能够正确且安全地将字符串转换为整数,同时处理了各种边界情况,如空字符串、非法字符和前导零等。

    转载地址:http://npbb.baihongyu.com/

    你可能感兴趣的文章
    oracle.dataaccess 连接池,asp.net使用Oracle.DataAccess.dll连接Oracle
    查看>>
    oracle00205报错,Oracle控制文件损坏报错场景
    查看>>
    Oracle10g EM乱码之快速解决
    查看>>
    Oracle10g下载地址--多平台下的32位和64位
    查看>>
    Oracle10g安装了11g的ODAC后,PL/SQL连接提示TNS:无法解析指定的连接标识符
    查看>>
    oracle11g dataguard物理备库搭建(关闭主库cp数据文件到备库)
    查看>>
    Oracle11G基本操作
    查看>>
    Oracle11g服务详细介绍及哪些服务是必须开启的?
    查看>>
    Oracle11g静默安装dbca,netca报错处理--直接跟换操作系统
    查看>>
    oracle12安装软件后安装数据库,然后需要自己配置监听
    查看>>
    Oracle——08PL/SQL简介,基本程序结构和语句
    查看>>
    Oracle——distinct的用法
    查看>>
    Oracle、MySQL、SQL Server架构大对比
    查看>>
    oracle下的OVER(PARTITION BY)函数介绍
    查看>>
    Oracle中DATE数据相减问题
    查看>>
    Oracle中merge into的使用
    查看>>
    oracle中sql查询上月、本月、上周、本周、昨天、今天的数据!
    查看>>
    oracle中sql的case语句运用--根据不同条件去排序!
    查看>>
    Oracle中Transate函数的使用
    查看>>
    oracle中关于日期问题的汇总!
    查看>>