LeetCode刷题1

in 力扣 with 2078 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. Hi there! I know this is kinda off topic nevertheless I'd figured I'd ask.
    Would you be interested in trading links or maybe guest authoring a blog article or vice-versa?
    My site discusses a lot of the same topics as yours and I feel we could greatly benefit from each other.
    If you are interested feel free to send me
    an email. I look forward to hearing from you! Great blog by the way!

    Reply
  2. https://barcampusa.com/ ATGepower

    In her free time, Aiko enjoys hiking and exploring the great
    outdoors. She believes that appreciating nature is key to understanding the importance of renewable
    energy. Aiko Tanaka is not just a blogger; she is
    a solar power enthusiast dedicated to making the world a greener place.

    Reply
  3. It is the best time to make some plans for the future and it's time to be happy.
    I've read this post and if I could I desire to suggest you some interesting things or suggestions.
    Maybe you can write next articles referring to this article.
    I want to read even more things about it!

    Reply
  4. https://bybeautydamned.net/ev-chargers/ ATGepower

    Since its inception, “Sunlit Aiko” has grown into a trusted
    platform for solar power enthusiasts globally.
    Aiko’s engaging writing style combined with her in-depth knowledge of the solar industry
    makes her blog a go-to resource for anyone interested in harnessing the power of the sun.

    Reply
  5. https://Greengen.online/energy-efficiency-grants-and-incentives-commercial-led-lightings/ ATGepower

    Aiko Tanaka is a seasoned solar power blogger with an unwavering passion for renewable energy.
    Born and raised in Tokyo, Japan, Aiko developed an interest
    in sustainable living at a young age. This led her to pursue a degree in Environmental Science from the University of Tokyo.

    Reply
  6. https://darkrifts.net/how-big-is-a-400-watt-solar-panel/ ATGepower

    Aiko Tanaka is a seasoned solar power blogger with an unwavering passion for renewable energy.
    Born and raised in Tokyo, Japan, Aiko developed an interest in sustainable living at a young age.
    This led her to pursue a degree in Environmental Science from the
    University of Tokyo.

    Reply
  7. Профессиональный сервисный центр по ремонту бытовой техники с выездом на дом.
    Мы предлагаем: сервисные центры в москве
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

    Reply
  8. https://Cyooh.com/how-to-remove-snow-from-solar-panels/ ATGepower

    Reply
  9. Hello just wanted to give you a quick heads up.

    The words in your article seem to be running off
    the screen in Safari. I'm not sure if this is a format
    issue or something to do with web browser compatibility but I figured I'd post to let you know.
    The style and design look great though! Hope you get the issue
    resolved soon. Cheers

    Reply
  10. Скачайте лучшие приложения для Андроид бесплатно на русском языке с сайта https://androidappspro.ru. Игры и программы для вашего устройства доступны в пару кликов. Установите нужное приложение прямо сейчас!

    Reply