C++乘法的int越界问题
生活随笔
收集整理的這篇文章主要介紹了
C++乘法的int越界问题
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在做Leetcode 69. x 的平方根,出現了兩種int越界的情況:
整數相乘越界
if(mid * mid <= x)
這樣寫的話,mid * mid可能越界,因此可以改為
if(mid <= x/mid)
整數本身越界
int n_r = x;
Leetcode給了個例子,x = 2147483647,導致n_r越界,因此將int改為long long int。
long long int n_r = x;
總結
以上是生活随笔為你收集整理的C++乘法的int越界问题的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 一房一厅多少钱啊?
- 下一篇: 求一个最暖心的个性签名。