Movatterモバイル変換


[0]ホーム

URL:


面试题1----把字符串转换成整数

最新推荐文章于 2021-05-07 16:22:43 发布
原创最新推荐文章于 2021-05-07 16:22:43 发布·3.1k 阅读
· 0
· 2·
CC 4.0 BY-SA版权
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。
文章标签:

#面试题

本文介绍了一个将字符串转换为整数的函数实现,并详细讨论了处理空串、空指针、非数字字符及溢出等问题的方法。

题目要求:

写一个函数StrToInt实现将字符串转换为整数的功能。 

需要考虑的点
  • 字符串为空串或空指针.
  • 字符串含有非0到9的字符.
  • 特别注意字符串转换到int值,要考虑溢出的问题,正整数的最大值是0x7FFFFFFF,负数的最小值是0x80000000.
代码如下:
#include<iostream>#include<string.h>#include<limits>bool strToInt(constchar *str,int &nInt){if(str == NULL){std::cout <<"空指针"<<std::endl;returnfalse;    }elseif(str ==""){std::cout <<"空串"<<std::endl;returnfalse;    }elseif((strcmp(str,"+") ==0) || (strcmp(str,"-") ==0)){std::cout <<"字符串输入无效"<<std::endl;returnfalse;    }else{constchar *p = str;bool isFirst =true;//标记是否为字符串的第一个字符bool hasMinus =false;//标记字符串的第一个字符是否是负号.        nInt =0;while(*p !='\0'){if(isFirst && (*p) =='-' ){                hasMinus =true;                p++;continue;            }elseif(isFirst && (*p) =='+'){                p++;continue;            }if((*p) >='0' && (*p) <='9'){                nInt = nInt*10+*p-'0';if((!hasMinus && nInt >std::numeric_limits<int>::max()) || (hasMinus && nInt <std::numeric_limits<int>::min())){std::cout <<"字符串数值溢出,输入无效!"<<std::endl;returnfalse;                }                    p++;                }else{std::cout <<"字符串中包含有非数字的字符,不能转换为数字"<<std::endl;returnfalse;                }        }if(hasMinus){                        nInt = (-1) * nInt;                    }returntrue;    }}int main(int argc,char *argv[]){int nInt =0;char *str = NULL;if(strToInt("123",nInt)){std::cout << nInt<<std::endl;    }if(strToInt("",nInt)){std::cout <<nInt<<std::endl;    }if(strToInt(str,nInt)){std::cout <<nInt<<std::endl;    }if(strToInt("-123",nInt)){std::cout <<nInt<<std::endl;    }if(strToInt("+123",nInt)){std::cout <<nInt<<std::endl;    }if(strToInt("-#45466@",nInt)){std::cout <<nInt<<std::endl;    }if(strToInt("10000000000000000000000000",nInt)){std::cout <<nInt<<std::endl;    }if(strToInt("-10000000000000000000000000",nInt)){std::cout <<nInt<<std::endl;    }return0;}
确定要放弃本次机会?
福利倒计时
::

立减 ¥

普通VIP年卡可用
立即使用
1 条评论您还未登录,请先登录后发表或查看评论

博客等级

码龄10年
108
原创
516
点赞
1487
收藏
299
粉丝
关注
私信

热门文章

分类专栏

展开全部收起

上一篇:
NAT 原理与NAT穿越
下一篇:
Java NIO 学习总结

大家在看

最新文章

目录

展开全部

收起

目录

展开全部

收起

上一篇:
NAT 原理与NAT穿越
下一篇:
Java NIO 学习总结

目录

评论 1
被折叠的  条评论为什么被折叠?到【灌水乐园】发言
查看更多评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值

[8]ページ先頭

©2009-2025 Movatter.jp