- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我需要一个公式来计算变量和常量乘积的最大总和,然后将整个总和乘以某个数字进行取模。
X = (C1*x1 + C2*x2 + C3*x3..... )%M,我们这里要最大化'X',给定Ci和M的值,所有xi都是变量(非- 负整数,包括零),简而言之,我可以说我们必须改变 xi,以便我们获得最大可能的 X,例如
X = (10*i + 3*j)%18(这里i和j是变量,即非负整数)
答案:- X = 17(取 j = 1 和 i = 5)
是否存在找到 X 的最大可能值的公式?
对不起,如果你不明白这个问题(我的英语不好),如果你有任何疑问,请在评论部分提问
最佳答案
如果存在一个与 M 互质的 C,则存在一个 x 使得 Cx = M - 1 (mod M);将所有其他 x 设置为 0,并将与我们的特殊 C 对应的那个设置为所需的值。没有比 M - 1 (mod M) 更好的了。
否则,如果有两个互质 C,比如 C1 和 C2,则可以获得任何大于 (C1 - 1)(C2 - 1) - 1 的和(查看硬币问题,或 Frobenius 数);因为一定存在比 M - 1 (mod M) 更大的数,所以这已经是你能做的最好的了;将其他所有x设为0,求得M-1所需的x1、x2。
否则,通过首先将所有 C 与 M 直接比较,然后将所有 C 相互比较,找到最小最大公约数。设这个最小最大公分母为m。然后,可以使用上述方法修改得到M - m (mod M)。但是,不可能达到 M - 1 或任何高于 M - m (mod M) 的值,因为所有数字都有一个公因数。
要真正找到这些案例中的数字,我认为首先要确定案例;然后,按照策略(1 或 2 个非零项)简单地迭代可能性。由于我们已将其缩小到一到两个术语,因此这并不可怕。可能有更聪明的方法来完成此任务...如果需要比检查可能性更复杂的方法,请发表评论,我将重新讨论。
更新
评论表明对第三种情况(没有互质系数)的处理是不正确的,而且是不正确的。考虑 C1 = 14,C2 = 21,M = 6 的情况。上面概述的方法发现最小成对 GCD 为 2,并表示可达到的最大值为 6 - 2 = 4;但是,您只需取 x1 = 1 和 x2 = 1 即可得到 5 (mod M)。也许要获得正确答案真正需要做的是考虑所有成对 GCD 并对它们应用相同的推理。也就是说,我们的成对 GCD 是 2、3 和 7。通过 n = 2 的硬币问题的解决方案,这意味着通过组合每一对我们可以获得这些 GCD 的足够大倍数的任何数字。这意味着,模 M,GCD 本身是可以实现的;所以我们可以递归地将上述解决方案应用于成对的 GCD,直到所有成对的 GCD 共享一个共同的术语(那么我的原始案例分析是正确的);或者,成对 GCD 之一变为 1,在这种情况下答案为 M - 1。
请注意,沿途跟踪递归和案例以根据原始 C 重建正确答案可能是可能的。留作练习。
更新:
根据评论,我现在将尝试将此(固定的?)方法应用于真实示例。
M, C1, C2 = 385, 42, 30
GCD(M, C1) = 7
GCD(M, C2) = 5
GCD(C1, C2) = 6
7 and 5 are coprime so we can get any number greater than (7-1)(5-1)-1
any number greater than 23 is obtainable
384 = 2*[7] + 74*[5]
7 is obtainable
7 = 46*[42]
5 is obtainable
5 = 13*[30]
combining, we get
384 = 2*[7] + 74*[5]
= 2*46*[42] + 74*13*[30]
= 92*[42] + 962[30]
~ 92*C1 + 192C2
关于algorithm - 最大化由乘积之和组成的方程,然后用一个数取模,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55664852/
我希望我的问题有一个非常简单的解决方案。我只是找不到它: 假设您有两个向量(一个是列向量,一个是行向量)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
我是一名优秀的程序员,十分优秀!