LeetCode刷题1

in 力扣 with 5188 comments

题目描述

给你一个32位的有符号整数x,返回将x中的数字部分反转后的结果。
如果反转后整数超过32位的有符号整数的范围 [−2^31,2^31−1],就返回 0。
假设环境不允许存储64位整数(有符号或无符号)。


思路

1.数字反转
利用%和/,将x的最后一位数字提取出来,放到返回数字rev的最前面,由于是10进制整数,所以只要每次操作时*10进一位。

int digit = x % 10;// 提取最后一位数字
x /= 10;// x去除最后一位
rev = rev*10 + digit;// rev初始值为0,赋值给最终的数字

2.整数反转的范围限制

题目要求x是32位无符号整数,环境不允许存储64位整数
反转后整数超过32位的有符号整数的范围就返回0
官方思路
-2^31 <= rev * 10 + digit <= 2^31-1
不等式不成立则返回0
然后一堆花里胡哨数学操作ToT
推导成了
(-2^31)/10 <= rev <= (2^31-1)/10
写的乱主要是不会传图,划掉

//最终代码,这里INT_MIN和INT_MAX应该是c语言中定义的int型的最大最小值
int reverse(int x) {
    int rev = 0;
    while (x != 0) {
        if (rev < INT_MIN / 10 || rev > INT_MAX / 10) {
            return 0;
        }
        int digit = x % 10;
        x /= 10;
        rev = rev * 10 + digit;
    }
    return rev;
}

我的理解
在数字转化的过程中,只要x不为0,rev就会比原来的值大10倍+,即rev = rev*10 + digit,所以为了避免超出范围,只要将rev和极值的1/10进行比较(在x!=0的前提下)。
假如还需要缩小范围,可以1、极值/100;2、条件改为while(x/10 !=0),不过该情况下对于x==0要单独考虑

今日总结

  1. 对于算法这方面还有很多需要加强的地方,主要在于做题的思路方面,需要多加练习。
  2. C、Java的基础方面还很薄弱,需要加强,多加练习
  3. 中等难度的题目就一头雾水了[o(╥﹏╥)o],我可真菜
Responses / Cancel Reply
  1. Карина

    Вентиляция помещений http://ufb38096.bget.ru/index.php?subaction=userinfo&user=usaxugob
    http://www.bakinsky-dvorik.ru/forum/?PAGE_NAME=profile_view&UID=205602
    http://serov-stal.ru/index.php?subaction=userinfo&user=ycyton
    https://bestnet.ru/support/forum/index.php?PAGE_NAME=profile_view&UID=146586
    http://zhabbo.free.fr/index.php?file=Members&op=detail&autor=adaresup
    http://tatarstan.iastr.ru/index.php?subaction=userinfo&user=oqopoji
    http://forum.s-manuals.com/index.php?action=profile;u=33940
    http://gameland.mzf.cz/profile.php?lookup=137241
    http://www.rakit.orthodox.ru/index.php?nma=user&fla=view&ids=umudeqo
    http://anciensdugenerals.free.fr/index.php?file=Members&op=detail&autor=okuxedam

    Reply
  2. Умные рулонные шторы для вашего дома, инновации и дизайн.
    Выберите рулонные шторы с электроприводом, для современного дома.
    Рулонные шторы с электроприводом: удобство и стиль, у нас.
    Умные рулонные шторы, идеальное решение.
    Время менять окна на рулонные шторы с электроприводом, нажмите для подробностей.
    Рулонные шторы с электроприводом для вашего интерьера, добавят стиля.
    Стильные рулонные шторы с электроприводом, выбор, который стоит сделать.
    Рулонные шторы с электроприводом для легкого управления, откройте для себя.
    Сделайте свой дом умнее с рулонными шторами, на нашем сайте.
    Умные рулонные шторы: удобство и стиль, которое вам понравится.
    Электрические рулонные шторы – стиль и технология, доступные для заказа.
    Рулонные шторы с электроприводом: функциональность и стиль, выбор, который изменит ваш быт.
    Умные рулонные шторы для современного дома, в вашем доме.
    Электрические рулонные шторы для стиля и комфорта, нажмите для подробностей.
    Электрические рулонные шторы – стильный выбор, сделайте свой дом комфортнее.
    Электрические рулонные шторы – сочетание простоты и стиля, пополните свой интерьер.
    Электрические рулонные шторы: легкость управления, выбирайте лучшее.
    Рулонные шторы с электроприводом: удобно и красиво, изучите сейчас.
    рулонные шторы с электроприводом рулонные шторы с электроприводом .

    Reply
  3. кашпо дизайн www.dizaynerskie-kashpo1.ru .

    Reply
  4. sweet bonanza 2 demo sweet bonanza 2 demo

    Reply
  5. pin up qonuniymi https://pinup3013.ru

    Reply
  6. mostbet скачать на андроид www.mostbet4011.ru

    Reply
  7. пин ап отзывы пользователей пин ап отзывы пользователей

    Reply
  8. sweet bonanza xmas slot review http://sweet-bonanza3003.ru

    Reply
  9. Автоматизированные системы дозирования обеспечивают точное введение лекарственных средств, что минимизирует риск передозировки и побочных эффектов. Постоянный мониторинг жизненных показателей позволяет оперативно корректировать терапию в режиме реального времени, обеспечивая максимальную безопасность процедуры.
    Получить больше информации - narkolog na dom

    Reply
  10. пин ап демо режим https://pinup3013.ru/

    Reply