1
#include <iostream>
using namespace std;
int mulths(int u,int v)
{
unsigned u0,v0,w0;
int u1,v1,w1,w2,t;
u0 = u & 0xFFFF;
u1 = u >> 16;
v0 = v & 0xFFFF;
v1 = v >> 16;
w0 = u0 * v0;
t = u1 * v0 + (w0 >> 16);
w1 = t & 0xFFFF;
w2 = t >> 16;
w1 = u0 * v1 + w1;
return u1 * v1 + w2 + (w1 >> 16);
}
int main()
{
int u,v;
cin >> u >> v;
cout << mulths(u, v) << endl;
return 0;
}
是否返回兩個數字的乘積是或它返回最重要的位? 因爲我輸入5和7並返回0關於乘以高位有符號的問題
結果相同 – 2010-07-13 07:25:36
請注意,如果您有32位整數,例如,您需要使用相當大的值。在十進制中,100000 x 100000會給出2的高字結果。 – 2010-07-13 07:35:34