7. Reverse Integer [LeetCode]

本文介绍两个经典算法题目:整数反转与判断回文数。整数反转需注意处理溢出情况;判断回文数则通过反转整数并与原数比较来实现。两题均采用C语言实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

7. Reverse Integer

/**************************************************************************
 * 
 * 7. [Reverse Integer](https://leetcode.com/problems/reverse-integer/)
 * 
 * Given a 32-bit signed integer, reverse digits of an integer.
 * if outside the signed 32-bit integer range [-231, 231 - 1], then return 0
 * 
 * Example:
 *  123 =>  321
 * -123 => -321
 *  120 =>   21
 * -2147483648 => 0
 **************************************************************************/

int reverse(int x){
    long long num = x;
    long long res = 0;

    for ( ; num; num/=10)
        res = res*10 + num % 10;
    
    if (res > INT_MAX || res < INT_MIN)
        return 0;
    else
        return res;
}

 

 

9. Palindrome Number



/**************************************************************************
 * 
 * 9. [Palindrome Number](https://leetcode.com/problems/palindrome-number/)
 * 
 * Given an integer x, return true if x is palindrome integer. 
 * An integer is a palindrome when it reads the same backward as forward. 
 * For example, 121 is palindrome while 123 is not.
 * 
 * Example 1:
 * Input: x = 121
 * Output: true
 * 
 * Example 2:
 * Input: x = -121
 * Output: false
 * 
 * Example 3:
 * Input: x = 10
 * Output: false
 **************************************************************************/


bool isPalindrome(int x){
    if (x < 0) return false;
    long long ret = 0;
    for (int num = x; num; num/=10)
        ret = ret * 10 + num % 10;
    if (ret > INT_MAX) return false;
    return ret == x;
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

luuyiran

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值