我试图找到 a 的平方int
。我的代码如下所示:
long long sqr=0;
int num=77778;
sqr= num*num;
结果应该是6049417284
但是当我检查它显示的输出时1754449988
。我在做什么错误?
long long
应该能够存储结果,但为什么我得到不同的值?
我试图找到 a 的平方int
。我的代码如下所示:
long long sqr=0;
int num=77778;
sqr= num*num;
结果应该是6049417284
但是当我检查它显示的输出时1754449988
。我在做什么错误?
long long
应该能够存储结果,但为什么我得到不同的值?
在这种情况下,中间结果类型与第一个参数类型相同。所以这段代码把错误的值放进去sqr
(因为这里你有整数溢出)。尝试这个:
long long num = 77778;
long long sqr = num * num;
铸造的另一种方式:
int num = 77778;
long long sqr = (long long) num * num;
为了更好地理解它,您可以检查以下几行:
int ia = 1, ib = 2;
double da = 1.0, db = 2.0;
double ic = ia / ib; // c == 0.0, because intermediate result of division is 0
double dc = da / db; // c == 0.5, expected result
如果将两个整数值相乘,结果将是一个整数值。那么,将整数值赋值给 long long 是没有意义的。
因此,要获得所需的结果,num 也应该很长。