博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
把字符串转换成整数
阅读量:6800 次
发布时间:2019-06-26

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

题目描述

将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数。 数值为0或者字符串不是一个合法的数值则返回0

输入描述:

输入一个字符串,包括数字字母符号,可以为空

输出描述:

如果是合法的数值表达则返回该数字,否则返回0

输入

+2147483647    1a33

输出

2147483647    0

我的代码:

int Getn(int x,int n)    {        int res = 1;        while(n)        {            if(n&1)                res*=x;            n>>=1;            x*=x;        }        return res;    }        int StrToInt(string str) {        int len = str.length();        int res = 0;        int start = 0;        int flag = 0;        if(str[0] == '+')          start = 1;        else if(str[0]=='-')       {
       flag = 1;    start = 1; } for(int i = start; i < len;i++) { if(str[i] >= '0' && str[i] <= '9') { res += (str[i]-48)*Getn(10,len-1-i); } else return 0; } if(flag) return -res; else return res; }

Getn函数是取得x的n次幂的函数,每次判断第一个字符是否为 + 或 - ,剩下的字符判断是否为数字,然后乘以相应的幂数。

或者计算公式可以用:res=res*10+str[i]-'0';

 

转载于:https://www.cnblogs.com/Lune-Qiu/p/9255672.html

你可能感兴趣的文章
《树莓派渗透测试实战》——第1章 树莓派和Kali Linux基础知识
查看>>
《圣殿祭司的ASP.NET4.0专家技术手册》----1-7 HTML5与CSS3的支持
查看>>
数据结构之链表
查看>>
八年了必须放手了,我不是你妈妈
查看>>
Eric S. Raymond 五部曲
查看>>
《Ansible权威指南 》一2.7 本章小结
查看>>
《iOS编程指南》——2.4节安装iOS SDK
查看>>
Comparing Mongo DB and Couch DB
查看>>
《配置管理最佳实践》——1.6 工具的选择
查看>>
前端工程师如何快速的开发一个微信JSSDK应用
查看>>
Apache Spark源码走读(九)如何进行代码跟读&使用Intellij idea调试Spark源码
查看>>
mysql 主从设计
查看>>
Android应用安全开发之浅谈网页打开APP
查看>>
后退时保存表单状态
查看>>
Python简介
查看>>
泛函编程(13)-无穷数据流-Infinite Stream
查看>>
XML与HTML
查看>>
采用镜像部署LNMP 环境操作步骤
查看>>
不服?来跑个分!
查看>>
Python笔记 开发环境搭建
查看>>