LeetCode刷题1

in 力扣 with 4854 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. click this site https://vitalityshop.space/ita/sluh/otovitalor-means-for-restoration-of-hearing-acuity,-elimination-of-tinnitus,-normalization-of-hearing-organs/

    Reply
  2. мостбет.сом mostbet33012.ru

    Reply
  3. Мобильный выездной шиномонтаж https://shinomontazh-vyezdnoj.ru

    Reply
  4. mostbet приложение http://mostbet33012.ru

    Reply
  5. Юридическая компания Екатеринбург yuristy ekaterinburga

    Reply
  6. proekt perep

    где согласовать перепланировку квартиры где согласовать перепланировку квартиры .

    Reply
  7. proekt perep

    проект перепланировки квартиры проект перепланировки квартиры .

    Reply
  8. ?? У кого в дипломе хоть раз была правда?

    Вот реально: вы когда-нибудь открывали свой диплом и думали — "да, всё, что здесь написано, я действительно знаю и умею"?
    У многих — только сертификат. Корочка, глянцевая, с гербом и подписями, которую HR смотрит за 1,5 секунды. А потом начинается: опыт, кейсы, компетенции, "что умеешь по факту?". Диплом где-то там, в мнимом мире.

    Но реалия в том, что без диплома тебе даже не дадут шанс доказать, что ты умеешь.
    Ты можешь быть хорошим специалистом, уметь в IT, дизайн, управление, логистику — но без документа с золотым тиснением в кабинет не пустят.

    ?? Нормально ли это? Нет. Реальность ли это? Да.

    Вот потому и появляются услуги, которые говорят:

    "Не хочешь тратить 5 лет ради корочки? Мы решим вопрос. Тебе нужен не вуз — тебе нужен диплом."

    Ты его получаешь, кладёшь в резюме, и дальше всё зависит от твоих мозгов, а не от шрифта на бумаге.
    Кто-то скажет: "Это обман!"
    А кто-то — "Это адаптация к системе, которая обманывает тебя с детства".

    ?? И что в итоге?

    Диплом становится не подтверждением знаний, а входным билетом. Как QR-код в метро — проверили, что есть, и пропустили.
    Поэтому люди и ищат как купить диплом.
    Не потому что глупые. А потому что взрослые, занятые, уставшие от лишнего.
    Потому что хотят не учиться "ради процесса", а работать по делу.

    ?? Ирония в том, что большинство таких дипломов — работают.
    Даже если ты их не учил — ты знаешь, как применить. А вот "настоящие выпускники" потом всё равно идут на курсы и стажировки, потому что ничего не помнят.

    И что важнее: корочка или то, как ты справляешься с задачей?

    ?? У кого были такие мысли — пишите. У кого был опыт — делитесь.
    Кто оформлял диплом с курсовыми и оценками? Какой сервис делает с деталями, чтобы документ прошёл визуальную и цифровую проверку? Купить диплом о среднем профессиональном образовании

    Reply
  9. Harveypok

    посетить веб-сайт https://tripscanwin28.top/

    Reply
  10. proekt perep

    услуги по узакониванию перепланировки услуги по узакониванию перепланировки .

    Reply