- - - - - 更新 - - - - - -
到目前为止,codymanix 和 Moonshadow 提供了很大的帮助。我能够使用方程解决我的问题,而不是使用右移除以 29。因为使用 32 位有符号 2^31 = 溢出到 29。这有效!
PHP 原型
$r = $x - (($x - $y) & (($x - $y) / (29)));
LEADS 的实际代码(每行只能执行一个数学函数!!!啊哈哈哈!!!)
DERIVDE1 = IMAGE1 - IMAGE2;
DERIVED2 = DERIVED1 / 29;
DERIVED3 = DERIVED1 AND DERIVED2;
MAX = IMAGE1 - DERIVED3;
----------原问题------------
我认为由于我的应用程序的限制,这不太可能,但我认为值得一试。
我会尝试让这变得简单。我需要找到两个数字之间的最大值,而无法使用 IF 或任何条件语句。
为了找到最大值我只能执行以下功能
Divide, Multiply, Subtract, Add, NOT, AND ,OR
假设我有两个号码
A = 60;
B = 50;
现在,如果 A 总是大于 B,那么找到最大值就会很简单
MAX = (A - B) + B;
ex.
10 = (60 - 50)
10 + 50 = 60 = MAX
问题是 A 并不总是大于 B。我无法使用我正在使用的脚本应用程序执行 ABS、MAX、MIN 或条件检查。
有没有办法使用上面的有限运算来找到非常接近最大值的值?