题目描述
给你一个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要单独考虑
今日总结
- 对于算法这方面还有很多需要加强的地方,主要在于做题的思路方面,需要多加练习。
- C、Java的基础方面还很薄弱,需要加强,多加练习
- 中等难度的题目就一头雾水了[o(╥﹏╥)o],我可真菜
本文由 szr 创作,采用 知识共享署名4.0 国际许可协议进行许可
本站文章除注明转载/出处外,均为本站原创或翻译,转载前请务必署名
最后编辑时间为: Sep 14, 2021 at 04:46 pm
Найактуальніші поради https://agusha.com.ua та рекомендації батькам
ремонт айфонов в москве
Поради для батьків https://babyrost.com.ua заходи для дітей, освіти, покупки, організація дитячих свят
Join bass win now and claim your $500 welcome bonus. Play top casino games and win big today!
business cards with a qr code qr visit cards
piazza iv novembre Budva Montenegro
Read More Here zip rar
Mostbet-AZ90 https://mostbet.prostoprosport.az Join the betting platform, get attractive bonuses during registration, take advantage of a wide catalog of casino games, big winnings guaranteed to win + fast withdrawal possible.
Присоединяйтесь к казино Mostbet.com https://mostbetregistration-kz.kz лучшей букмекерской конторе и казино Казахстана. Зарегистрируйтесь сейчас и получите бонус 150% по промокоду MOSTBET-KZ24!
Остеопат – дипломированный специалист, который 4 года обучается в остеопатической школе, осваивает методики диагностики и лечения https://altermed-clinic.ru/revmatoidnyj-artrit/
И всё это на базе 7-летнего высшего медицинского образования https://altermed-clinic.ru/lechenie-meniska/
В России остеопатия - это врачебная специальность и только врач имеет право заниматься этой профессией https://altermed-clinic.ru/gryzha-poyasnichnogo-otdela/
В настоящее время в сфере остеопатии более 50% специалистов - это мошенники не имеющие к врачебному образованию никакого отношения https://altermed-clinic.ru/bolezni-detej/rodovaya-travma/
Ведущий специалист центра по общей остеопатии https://altermed-clinic.ru/mezhpozvonochnaya-gryzha/
Врач остеопат https://altermed-clinic.ru/napravleniya/gomeopatiia/
Мануальный терапевт https://altermed-clinic.ru/bolezni-detej/kosolapost/
Специализируется на работе с детьми, беременными женщинами и после родов https://altermed-clinic.ru/napravleniya/biorezonansnaia-terapiia/
Владеет остеопатическими техниками в стоматологии https://altermed-clinic.ru/skrining-muzhskogo-gormonalnogo-statusa/
Избавляем от болевого синдрома , стрессового напряжения, посттравматических стигматов https://altermed-clinic.ru/price/
Результат остеопатической техники напрямую зависит от пальцев остеопата, то есть его способности вести с организмом https://altermed-clinic.ru/napravleniya/biorezonansnaia-terapiia/
Этот навык можно приобрести только с многолетней врачебной практикой https://altermed-clinic.ru/testosteron-estradiol-i-aromataza/
Именно таким опытом обладают врачи-остеопаты нашей клиники в Москве https://altermed-clinic.ru/bolezni-detej/kosoglazie/
Следует сказать, что врачу остеопату не всегда удаётся вылечить пациента, но качество жизни всегда значительно улучшается https://altermed-clinic.ru/allergiya/
В неосложнённых случаях достаточно 1-3 сеансов с интервалом в 2 недели, в тяжёлых случаях требуется длительное лечение https://altermed-clinic.ru/chto-lechit-vrach-osteopat-hlystovye-travmy/
В среднем, курс лечения редко превышает 5-10 сеансов с интервалом 7-14 дней между сеансами https://altermed-clinic.ru/10-pravil-kotorye-dolzhna-znat-kazhdaja-zhenshhina-vizit-k-ginekologu/