leetcode Reverse Integer

本文介绍了一种用于翻转整数的算法实现,并通过C++代码进行了详细说明。特别关注了特殊情况处理,如前导0的问题及0本身的情况。

Reverse digits of an integer.

Example1: x = 123, return 321
Example2: x = -123, return -321

此题主要考查几种特殊的前导0的情况,还有单独为0的情况

注意利用c++中的reverse时要加命名空间,不然该函数会递归调用自己

#include <iostream>
#include <cstdio>
#include <sstream>
#include <string>
#include <cmath>

using namespace std;

int reverse(int x){
    if (x == 0) return x;
    bool flag = (x > 0)? true : false;
    x = abs(x);
    stringstream ss;
    ss << x;
    string x_str;
    ss >>x_str;
    std::reverse(x_str.begin(),x_str.end());
    string reverse_x = x_str.substr(x_str.find_first_not_of('0'));
    int res = atoi(reverse_x.c_str());
    return flag ? res : (-res);
}

int main(){
    cout<<reverse(123)<<endl;
}

 

转载于:https://www.cnblogs.com/xiongqiangcs/p/3626267.html

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符  | 博主筛选后可见
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值