unsigned long long a,b,c;
cin>>a>>b>>c;
cout<<(a*b*c);
输入给定:512 294967268 279632277 输出:5337484673731225600
但是,当我512 * 294967268 * 279632277
在 Python 中执行时,我得到的输出是:
42230972821150328832L
为什么我得到不同的答案?
unsigned long long a,b,c;
cin>>a>>b>>c;
cout<<(a*b*c);
输入给定:512 294967268 279632277 输出:5337484673731225600
但是,当我512 * 294967268 * 279632277
在 Python 中执行时,我得到的输出是:
42230972821150328832L
为什么我得到不同的答案?
肯定会在 C++ 中溢出。
Python 具有任意大小的数据类型来存储结果。所以如果要存储的值很大,数据类型的 大小也会自动变大。
>> x = 512 * 294967268 * 279632277
>> x
42230972821150328832L
>> type(x)
<type 'long'>
>> x.__sizeof__()
36
>> x = x * x
>> x
1783455065420737763677831948901730484224L
>> type(x)
<type 'long'>
>> x.__sizeof__()
44
所以实际上对数据类型的大小没有限制。可用内存定义了理论限制。