C++ C+中的sqrt函数+;问题 #包括 #包括 使用名称空间std; int main(){ int n; cin>>n; inti=sqrt(1+2*n*(n+1))-1; 无法
将C++ C+中的sqrt函数+;问题 #包括 #包括 使用名称空间std; int main(){ int n; cin>>n; inti=sqrt(1+2*n*(n+1))-1; 无法,c++,sqrt,C++,Sqrt,将int n更改为double n。您的计算1+2*n*(n+1)溢出了int的范围,32位的范围为-2147483648到2147483647 旁注:int可能不是32位,这取决于平台(但是,通常大部分时间是32位)尝试将n更改为double1+2*n*(n+1)是int类型的表达式。它似乎已溢出。如果调用sqrt(或任何其他函数)的结果没有意义,请查看调用它的参数。请尝试计算1+2*32768*(32768+1)用手你会很快注意到它是2147549185,并且很可能溢出int。没错,除了溢出
int n
更改为double n
。您的计算1+2*n*(n+1)
溢出了int
的范围,32位的范围为-2147483648到2147483647
旁注:
int
可能不是32位,这取决于平台(但是,通常大部分时间是32位)尝试将n
更改为double
1+2*n*(n+1)
是int
类型的表达式。它似乎已溢出。如果调用sqrt
(或任何其他函数)的结果没有意义,请查看调用它的参数。请尝试计算1+2*32768*(32768+1)
用手你会很快注意到它是2147549185
,并且很可能溢出int
。没错,除了溢出不能保证。试图将一个超出可表示范围的双精度值转换为int是UB。请参阅SO post。
#include <iostream>
#include <cmath>
using namespace std;
int main(){
int n;
cin >> n;
int i = sqrt(1 + 2 * n * (n + 1)) - 1;
cout << i;
}