题目描述
给你一个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
Тут можно преобрести взломостойкие сейфы купить сейфы офисные взломостойкие
Sale of non ferrous metal alloys
At Cliffton Trading, we pride ourselves on being a leading international supplier of non-ferrous metals. Based in Dubai, our company specializes in providing high-quality materials such as copper powder, copper ingots, selenium powder, and nickel wire to industries around the world. Our commitment to excellence ensures that every product we offer meets the highest standards, backed by certifications from top chemical laboratories.
Copper powder
Pure high-quality copper powder (Cu) with consistent particle size.
Copper ingots
These bullions have high purity and excellent conductivity, making them indispensable in electronics manufacturing, construction and mechanical engineering.
Selenium powder
Our products include high purity metal dust and microfine powder.
Nickel wire
Nickel wire is ideal for use in a variety of industrial applications.
With a strong global distribution network, we serve over 15 countries, catering to diverse sectors like construction, automotive, and electronics. Our approach is centered on reliability, quality, and customer satisfaction, which allows us to build lasting relationships with our clients. We understand the importance of tailored solutions, so we work closely with our customers to meet their specific needs, ensuring that they receive the best possible value.
Our team of experienced professionals is dedicated to maintaining the integrity and efficiency of our supply chains, allowing us to deliver products consistently and on time. Competitive pricing, combined with our extensive product range, makes us a preferred partner for businesses seeking dependable suppliers of non-ferrous metals. At Cliffton Trading, we are not just about transactions; we are about building partnerships that drive success for both our company and our clients.
You can view the products and place an order on our website cliffton.ae
I like the valuable information you provide
in your articles. I will bookmark your weblog and check again here regularly.
I'm quite sure I will learn lots of new stuff right
here! Good luck for the next!
bs2best.at
Blacksprut
bsme.at
кайт школа хургада
I want to to thank you for this good read!! I absolutely enjoyed every bit of it. I have you saved as a favorite to check out new things you
additional resources
Affordable virtual SMS verification numbers
Как выбрать платформу, которая не подведет, не обманет и принесет максимум прибыли? Мы проанализировали десятки криптобирж, сравнили их комиссии, безопасность, удобство и поддержку пользователей, чтобы вы могли торговать с уверенностью.
Сколько вы уже потеряли из-за неправильного выбора биржи? Пора это исправить! Узнайте, какие платформы возглавляют рейтинг в 2025 году и почему именно они стали фаворитами миллионов трейдеров по всему миру. рейтинг бирж криптовалют с выгодным стейкингом