我要求一個大數的立方數,所以兩個不同的程序如下:
把三個數直接相乘得到的結果時錯誤,請各位大神解釋一下為什麼會出現這樣的現象呢?麻煩各位了。
3751*3751*3751,這個操作實際上系統在處理的時候默認是int的操作,int是32位的,其取值范圍-2147483648~2147483647,也就是說根本放不下結果,所以給出的答案是錯誤的。
你改成下面這種就對了:
#include "iostream"
using namespace std;
int main() {
long long a = 3751;
cout<<a*a*a<<endl;
}
而 pow的話是系統函數,會用double來進行運算,double有64位,完全可以放下結果,所以運算的結果是正確的。