LeetCode刷题1

in 力扣 with 1634 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. buy lanoxin 250 mg online telmisartan 20mg generic molnunat medication

    Reply
  2. Thanks for all of your effort on this web page. My niece takes pleasure in getting into investigation and it's really easy to see why. We all learn all regarding the lively way you give very useful guidelines by means of the website and in addition recommend response from website visitors about this idea while my child is certainly learning a lot. Take pleasure in the rest of the new year. You are always doing a useful job.

    Reply
  3. buy acetazolamide 250mg pills brand imuran imuran 50mg ca

    Reply
  4. |You are one-of-a-kind, so your look should be, too. There are many people that follow their own sense of style, but those with a sense of originality are those with who create their own style. To pull this off yourself, you must be comfortable enough to do so. Once you decide to do this, you are probably going to enjoy all the compliments you receive.

    Reply
  5. |If you are dealing with a problem with frizzy hair, never rub it with a towel after washing it. It will damage and frizz out your hair. Instead, you should wrap it and push the towel to eliminate the moisture. When you are happy, brush and comb your hair.

    Reply
  6. I not to mention my pals came digesting the good things from your web page and so immediately I had an awful suspicion I never thanked you for those tips. All of the boys are already as a consequence warmed to study them and already have undoubtedly been loving those things. Appreciation for turning out to be really considerate and then for selecting such perfect subject areas most people are really desperate to know about. Our honest regret for not expressing gratitude to you sooner.

    Reply
  7. My husband and i ended up being quite satisfied Albert managed to finish off his preliminary research out of the ideas he received when using the site. It's not at all simplistic just to happen to be handing out steps some people have been selling. So we remember we now have the blog owner to give thanks to for this. These explanations you've made, the easy website menu, the friendships your site help to engender - it is many astonishing, and it is letting our son in addition to us imagine that that issue is amusing, and that's highly mandatory. Many thanks for the whole lot!

    Reply
  8. temovate over the counter buy clobetasol no prescription buy cordarone cheap

    Reply
  9. I not to mention my friends have been checking out the nice key points found on your web blog and then all of a sudden I had an awful suspicion I had not expressed respect to you for those tips. Most of the women ended up so excited to learn all of them and now have pretty much been using those things. Many thanks for really being considerably considerate and also for selecting this sort of nice useful guides millions of individuals are really eager to be aware of. My sincere regret for not expressing gratitude to sooner.

    Reply
  10. buy cheap benicar buy benicar sale depakote 500mg pill

    Reply