- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我需要确定 a*b >= c*d
其中 a,b,c,d
是否是带符号的 32 位整数(我的 'int'机)。
是否可以仅使用 32 位有符号整数来比较这些产品而不会溢出,以便结果对于所有可能的值都是正确的?
我想到了 a/d >= c/b
。
但是它在 '2*7 >= 3*5'(假)时失败,因为 '2/5 >= 3/7'('0 >= 0')为真。
最佳答案
目前,我假设输入是有符号整数。
既然如此,我们要从检查标志开始。如果一侧为负,另一侧为正,这足以告诉我们结果(负值明显小于正值),所以我们完成了。
如果等式的两边都是正数或都是负数,我们缓存结果的符号,然后去掉符号,这样我们就可以处理乘法本身的无符号数。
一旦我们有了无符号数,我们就可以通过将每个 32 位整数视为两个不同数字的总和来进行乘法运算,一个代表输入数字的低位,一个代表高位。因此,您会将 a
、b
、c
和 d
中的每一个转换为两个只有 16 位有效位的数字位。所以,对于左侧,我们有:
al = a & 0xffff;
au = a >> 16;
bl = b & 0xffff;
bu = b >> 16;
所以:
a * b
...等同于:
(al + au << 16) * (bl + bu << 16)
并使用分配属性,我们可以将其转化为:
al * bl + au<<16 * bl + al * bu<<16 + au<<16 * bu<<16
由于 a * (b * c)
= (a * b) * c
,我们可以在 之后进行所有位移我们做其他乘法,所以这变成:
al * bl + // we'll call this intermediate result "lower"
(au * bl) << 16 +
(al * bu) << 16 + // we'll call the sum of these two "mid"
(au * bu) << 32 // we'll call this one "upper"
现在重要的一点是:我们的位掩码确保每个乘法步骤的输入只有 16 个有效位,因此每个中间结果将只有 32 个有效位,因此每个结果都适合一个 32 位整数而不溢出。
从那里,我们必须对各项进行求和。这有点不平凡,但仍然相当容易处理。首先,我们必须弄清楚一项的总和是否会产生进位。一种方法是这样的:
bool carry(unsigned a, unsigned b) {
return a > (std::number_limits<unsigned>::max() - b);
}
然后我们的结果是 lower + mid<<16 + upper << 32。因为我们处理的是 32 位整数,所以可能最简单的方法是将 mid
分成 upper 和下半部分。它的下半部分将被添加到lower
,它的上半部分将被添加到upper
。然后,我们的结果将分布在两个(无符号)32 位整数中,一个包含 lower + mid_lower
,另一个包含 upper + mid_upper + carries
。
从那里恢复我们在开始时存储的符号是一件简单的事情,然后比较上半部分,当且仅当它们相等时,比较下半部分。
如果您的数字一开始是无符号的,那么您可以稍微跳过涉及符号的部分。
关于c++ - 比较两个整数乘积而不会溢出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27303904/
我希望我的问题有一个非常简单的解决方案。我只是找不到它: 假设您有两个向量(一个是列向量,一个是行向量)A、B: A = [1,2,3] B = [4;5;6] 如果我们按如下方式将它们相乘,我们会得
我有一个 Tuple 的列表: "dog", 25 "cat", 5 "cat", 7 "rat", 4 "dog", 10 我需要的 Linq 查询规则必须满足以下条件:我需要按字符串值对元组进行分
给定 2 个不同的 NDarray,A 和 B,形状相同但尺寸任意,我如何获得 NDarray C,其中 C 是 A 和 B(含)范围内所有整数的乘积。 我的意思是A是起始数组,B是结束数组,我想要数
假设我需要为某些输入构建一个真值表,它要求我提供逻辑和、算术和和逻辑乘积。它们之间有什么区别? 最佳答案 逻辑和 - 一种计算机加法,当一个或两个输入变量为 1 时,结果为 1;当输入变量均为 0 时
我正在尝试执行一个简单的矩阵乘法 vector 乘法,但出于某种原因,我在几次乘法的结果中得到了错误的符号。我不知道为什么会这样,任何指针将不胜感激。 这是我的全部代码,即矩阵 * vector 函数
我在上一个主题中找到了一些关于 cuda 矩阵 vector 积的代码: Matrix-vector multiplication in CUDA: benchmarking & performanc
我遇到的第一个问题是显示三个数字中的最小和最大。出现两个单独的警报 - 第一个警报说第二大数字是最大的(因为它还没有考虑第三个数字),第二个警报正确地指出三个中最大的数字是最大的.不确定为什么会这样—
我有两个矩阵 a = np.matrix([[1,2], [3,4]]) b = np.matrix([[5,6], [7,8]]) 我想得到元素乘积,[[1*5,2*6], [3*7,4*8]],等
我有一个数组和一个 vector : ArrayXd m1(3, 1337); ArrayXd v1(1, 1337); ArrayXd result(3, 1337); 现在我想将 m1 的每一行与
我有两个 3D 矩阵: a = np.random.normal(size=[3,2,5]) b = np.random.normal(size=[5,2,3]) 我想要每个切片分别沿 2 轴和 0
我正在创建一个 C++ 软件,我需要一个包装器,它基于 Eigen 库,实现类似于官方网页中解释的运算符* https://eigen.tuxfamily.org/dox/group__Matrixf
我正在尝试将张量 (m, n, o) 分解为矩阵 A(m, r)、B (n, r) 和 C (k, r)。这被称为 PARAFAC 分解。 Tensorly已经做了这种分解。 一个重要的步骤是将 A、
我目前正面临这个问题。我有两个矩阵 MatrixXf答: 0.5 0.5 0.5 0.50.694496 0.548501 0.680067 0.7171110
我有以下 df: df = pd.DataFrame({'A': ['foo', 'bar', 'dex', 'tru'], 'B': ['abc', 'def'
假设我们有 2 个 2X2 numpy 数组: X=np.array([[0,1],[1,0]]) 和 I=np.array([[1,0],[0,1]]) 考虑一下克罗内克产品 XX=X^X 我让符号
我想弄清楚这是 Eigen 中的错误还是我做错了什么。我只想要两个复数 vector [1,i] 和 [1,-i] 的点积。答案是 1*1 + i*(-i) = 2。但是 Eigen 给出的答案是零。
我的 C 代码有问题。我所做的就是这样: #include int main() { float zahlen[2]; for (int i = 0; i < 2; i++) {
为了找到数字的因数,我正在使用函数 void primeFactors(int n) # include # include # include # include using namespa
我是一名优秀的程序员,十分优秀!