- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
有一个线性同余系统,我想确定它是否有解。使用简单的算法来解决此类系统是不可能的,因为答案可能呈指数级增长。
我的一个假设是,如果同余系统没有解决方案,那么其中有两个是相互矛盾的。我不知道这是否成立,如果成立,那将导致一个简单的 O(n^2 log n) 算法,因为检查一对同余是否有解决方案需要 O(log n) 时间。尽管如此,对于这个问题,我宁愿看到更接近 O(n) 的问题。
我们可以假设没有模数超过 10^6,特别是我们可以快速将它们全部分解。我们甚至可以进一步假设所有模数的总和不超过 10^6(但它们的乘积仍然可能很大)。
最佳答案
如您所料,有一种相当简单的方法可以确定同余集是否有解,而无需实际构建该解。你需要:
x = a (mod n)
形式;从评论来看,您似乎已经有了这个。n
分解为质数幂的乘积:n = p1^e1 * p2^e2 * ... * pk^ek
。x = a (mod n)
替换为一组同余 x = a (mod pi^ei)
,每个 一个k
您在第 2 步中找到的素数幂。现在,通过 Chinese Remainder Theorem独立检查每个素数的兼容性就足够了:给定任意两个同余 x = a (mod p^e)
和 x = b (mod p^f)
,它们'当且仅当 a = b (mod p^(min(e, f))
时才兼容。确定兼容性后,您可以在不丢失任何信息的情况下丢弃模数较小的同余。
使用正确的数据结构,您可以通过同余式一次性完成所有这些操作:对于遇到的每个素数 p
,您需要跟踪最大的指数 e
到目前为止找到的,连同相应的右侧(为方便起见,减少模 p^e
)。运行时间可能主要由模数分解决定,但如果没有模数超过 10^6
,那么您也可以通过从范围 1 .. 10^6
到它的最小质因数。
编辑:因为这应该是一个编程站点,这里有一些(Python 3)代码来说明上面的内容。 (对于 Python 2,将 range
调用替换为 xrange
以提高效率。)
def prime_power_factorisation(n):
"""Brain-dead factorisation routine, for illustration purposes only."""
# DO NOT USE FOR LARGE n!
while n > 1:
p, pe = next(d for d in range(2, n+1) if n % d == 0), 1
while n % p == 0:
n, pe = n // p, pe*p
yield p, pe
def compatible(old_ppc, new_ppc):
"""Determine whether two prime power congruences (with the same
prime) are compatible."""
m, a = old_ppc
n, b = new_ppc
return (a - b) % min(m, n) == 0
def are_congruences_solvable(moduli, right_hand_sides):
"""Determine whether the given congruences have a common solution."""
# prime_power_congruences is a dictionary mapping each prime encountered
# so far to a pair (prime power modulus, right-hand side).
prime_power_congruences = {}
for m, a in zip(moduli, right_hand_sides):
for p, pe in prime_power_factorisation(m):
# new prime-power congruence: modulus, rhs
new_ppc = pe, a % pe
if p in prime_power_congruences:
old_ppc = prime_power_congruences[p]
if not compatible(new_ppc, old_ppc):
return False
# Keep the one with bigger exponent.
prime_power_congruences[p] = max(new_ppc, old_ppc)
else:
prime_power_congruences[p] = new_ppc
# If we got this far, there are no incompatibilities, and
# the congruences have a mutual solution.
return True
最后一点:在上面,我们利用了模量很小的事实,因此计算素数功率因数分解并不是什么大问题。但是,如果您确实需要为更大的模数(数百或数千位)执行此操作,它仍然可行。您可以跳过因式分解步骤,而是找到模数集合的“互质基”:即成对相对质数正整数的集合,这样出现在您的同余中的每个模数都可以表示为乘积(可能有重复) 该集合的元素。现在按照上面的方法进行,但引用的是互质基而不是素数和素数的幂集。参见 this article Daniel Bernstein 提供了一种计算一组正整数的互质基数的有效方法。您最终可能会两次 遍历您的列表:一次计算互质基数,第二次检查一致性。
关于algorithm - 确定同余系统是否有解,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24740533/
我正在使用 Selenium Web 驱动程序 3.0,并且想要从打开的两个对话框(一个在后台,第二个在前台)的 Activity 对话框中单击“确定”按钮。如何从 html 下面的父 div 单击前
actions: [ FlatButton( onPressed: () {
我有一个问题有点超出我的范围(我真的很高兴我是 Beta)涉及重复项(所以 GROUP BY, HAVING, COUNT),通过将解决方案保留在 SQLite 附带的标准函数中而变得更加复杂。我正在
使用DBI是否可以确定SELECT语句的已执行语句句柄是否返回任何行而不从中获取行? IE。就像是: use DBI; ... my $sth = $dbh->prepare("SELECT ..."
是否可以为“确定”和“关闭”按钮指定回调函数? 如果是JQuery Modal,则可以在初始化时使用按钮字典指定回调函数。 Semantic-ui模态是否提供类似的功能?按下确定后,我该如何寻求其他逻
我想阅读警报中的消息。 示例:如果警报显示“错误的电子邮件地址”。怎么读呢?意味着我想将该消息存储在字符串中。 如何在“警报”中单击“确定”...?? 如何使用 Selenium 来做到这一点? 最佳
我有一个删除按钮: 我试图首先查明是否已选择一个网站,如果已选择一个网站,我需要确定是否已选择一个或多个列表项,如果是,则继续删除这些项目。 我的 if 语句不断返回“您必须首先选择您的列表”,即使它
部分出于好奇——我们想知道在我们的应用程序中发生了什么——部分是因为我们需要在我们的代码中找到一些潜在的问题,我喜欢在我们的网络应用程序运行时跟踪一些一般值。这尤其包括某些对象图的分配内存。 我们的应
我将 SweetAlert 与 Symfony 结合使用,我希望用户在完成删除操作之前进行确认。 发生的情况是,当用户单击删除按钮时,SweetAlert 会弹出,然后立即消失,并且该项目被删除。 在
我们有一个应用程序可以生成不包括字母 O 的随机基数 35 [0-9A-Z]。我正在寻找一种解决方案来查找包含任何淫秽英语单词的代码,而无需搜索包含 10,000 个条目的列表每个生成的代码。每秒生成
这是我做的: #include #include int betweenArray(int a, int b){ int *arr,i,range; range = b - a +
我知道如何创建 警报和确认框,但我不知道如何做的是实际单击“确定”。我有一个弹出确认框的页面。 我想使用 Java Script 插件单击“确定”。基本上,我希望我的代码单击页面上的链接,然后在出现提
代码: swal('Your ORDER has been placed Successfully!!!'); window.location="index.php"; 甜蜜警报工
>>> import re >>> s = "These are the words in a sentence" >>> regex = re.compile('are|words') >>> [m
使用确定的理想散列函数给出随机期望线性时间算法两个数组 A[1..n] 和 B[1..n] 是否不相交,即 A 的元素是否也是 B 的元素。 谁能告诉我如何做到这一点,甚至如何开始考虑它? 最佳答案
我在计算机科学课上有这段代码: int input=15; while (input < n ) { input = input *3;} 这段代码有 log3(n/15) 次循环的上限。我们怎样才能
我有一个允许 2 位玩家玩 TicTacToe 的程序。在每个玩家移动之后,它应该在那个点显示棋盘并返回一个名为 Status 的枚举,显示玩家是否应该继续,如果玩家赢了,还是平局。但是,该算法要么返
给定一个 y 值数组,例如 [-3400, -1000, 500, 1200, 3790],我如何确定“好的”Y 轴标签并将它们放置在网格上? ^ ---(6,000)-|---
假设我有一个检查用户登录的 SQL 语句: SELECT * FROM users WHERE username='test@example.com', password='abc123', expi
teradata中有返回表中哪一列被定义为主索引的命令吗?我没有制作一些我正在处理的表,也没有尝试优化我对这些表的连接。谢谢! 最佳答案 有dbc.IndicesV,其中IndexNumber=1表示
我是一名优秀的程序员,十分优秀!