我试图找到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
如果将
两个整数值相乘,则结果将是一个整数值。那么,将整数值赋值给长整型是没有意义的。
因此,为了获得所需的结果,num 也应该很长。