- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
这是我正在尝试做的示例代码。当然,这需要很长时间才能处理 (410^8)。
编辑:
目标是允许在 0.0*/1 和 100.*/1 的近似范围内输入实数,例如.457473343788374/1, 8.5476457654/1 并使用四个分数得出最佳可能的近似值,所有分数都具有两个指定约束(例如 16 到 400)之间的整数。
分数代表机器中需要精确计时并且可以适合给定空间的齿轮齿。想想 Antikythera 装置。
主要目标是在找到近似值时不停止,而是找到即使以牺牲效率为代价也不能改进的最佳近似值。
是否有专门针对此类问题的算法?
for(auto_t num_1 = 20; num_1 != 431; num_1++)
{
for(auto_t num_2 = 20; num_2 != 431; num_2++)
{
for(auto_t num_3 = 20; num_3 != 431; num_3++)
{
for(auto_t num_4 = 20; num_4 != 431; num_4++)
{
for(auto_t num_5 = 20; num_5 != 431; num_5++)
{
for(auto_t num_6 = 20; num_6 != 431; num_6++)
{
for(auto_t num_7 = 20; num_7 != 431; num_7++)
{
for(auto_t num_8 = 20; num_8 != 431; num_8++)
{
nOutput = double(num_1*num_2*num_3*num_4)/(num_5*num_6*num_7*num_8);
}
}
}
}
}
}
}
}
我写了一些运行速度相当快并且返回看起来准确的结果的东西。
位于此处(64 位,Vista 或更新版本):http://1drv.ms/1zgpQnB
例子:
pi ~~ (323 * 379 * 413 * 388)/(235 * 283 * 229 * 410) 我如何确认使用 20 到 430 的范围是否尽可能准确?或者不是(我怀疑不是)。
更多:
pi ~~ (381 701 341 523)/(309 573 128 669) 使用 25 到 750 作为约束。
cos(45d) ~~ (617 713 723 92)/(485 734 263 442) ''
最佳答案
这种类型的循环非常低效。您正在检查 411^8 ~ 8x10^20 种可能性。正如 Ben Voigt 评论的那样,您可以通过选择一组无序的分母和一组无序的分子将其减少大约 4!^2 ~ 600,但这仍然很糟糕 (10^17)。
一个快速归约是创建一个排序的分子集合和一个排序的分母集合,然后遍历分母,只检查恰好在分母 pi 上方和下方的分子。如果分子的数量是 n,如果你能高效地完成,这大约需要 n log n 个步骤。这只有几十亿步,主要用于对列表进行排序,因此您实际上可以这样做,并且可以并行对数字进行排序,以便轻松扩展。
使用晶格缩减对此进行了改进。
但是,以这种方式通过反复试验找到这种近似值的整个想法很糟糕。有一个数学领域称为 Diophantine approximation,它包括用有理数逼近无理数。您可以使用简单连分数理论或 Farey 序列快速找到良好的近似值。这是一种快速找到大量合理近似值的方法:从 3/1 < pi < 4/1 开始。将分子和分母相加得到 7/2。将 pi 与新分数进行比较。它更低,所以我们有 3/1 < pi < 7/2。迭代。这将达到 pi 的简单连分数的所有收敛点,例如 22/7、355/113 和 5419351/1725033。在像 3.011 这样的尴尬情况下,有一些简单的方法可以稍微加快速度,在这种情况下,您反复调整一个分数而不是另一个分数。
如果出于某种原因你对分数的乘积很感兴趣(这是一个竞赛题吗?),那么我认为你最好找到所有好的有理近似值,然后将它们分解成分子和分母的分数您指定的范围。
关于c++ - 将无理分数转换为一组四个真/假分数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26039899/
这个问题在这里已经有了答案: 关闭 12 年前。 Possible Duplicate: Why can't Python handle true/false values as I expect?
我是不是遗漏了什么或者这是 ruby 中的错误? a = %w(foo bar baz) a.include? "foo" # => true a.size == 3
从 Modelica 文档来看,注释 Evaluate 似乎只对参数有影响: https://build.openmodelica.org/Documentation/ModelicaReferenc
为了避免嵌套的 if 语句并提高可读性,我想创建一个switch(true){ ... } Coldfusion 中的声明。我在 php 中经常使用这个,但是当我在 Coldfusion 中尝试这个时
嗨,我正在尝试处理 ajax json 响应 这是我的代码 success: function (j) { switch(true) { case (j.cho
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
我之前在我的 TF 代码中使用过这个: count = "${var.whatever == "true" ? 1 : 0}" 这非常适合我想要使用的东西。但是,我正在考虑如何最好地使用类似于说的
这个问题在这里已经有了答案: How can I return pivot table output in MySQL? (10 个答案) 关闭 5 年前。 我正在尝试构建一个以唯一列值作为列名的表
我制作了一个简单的 JDialog,其中包含一个标签和一个按钮,它基本上相当于信息对话框。所以在对话框中,有一个方法 display() 我在其中调用了 setVisible(true) 五次。 据我
在 bash 4.2.8(1)-release (x86_64-pc-linux-gnu) 在 Ubuntu 11.04 上这个命令 [ $(wc -l /var/www/some.log|cut -
我正在使用 c 语言进行并发处理,我有一个进程池。为此,我让每个 child 都在一个 While (True) 循环中。为了杀死 child ,我正在使用一个全局变量和一个信号处理程序来修改它来打破
我正在尝试选择填写了字段的数据库条目。数据库有两种插入数据的方式,一种输入评论,一种不输入,我希望只选择填写了评论的行。 $requete = "SELECT * FROM daysoff WHER
如何在 JavaMail session 中setDebug(true) 捕获流并在我的日志记录框架中使用它? (缺少下载源代码,更改接受流作为参数的方法,重新编译它,...) 更一般地说,Java
我是 JavaScript 的新手,我刚刚发现了我无法理解的奇怪行为: var magicVar = Math.sin; magicVar == true; // it returns false m
对此感到困惑。 在两台服务器上运行相同版本的 MySQL。 (从完全相同的 rpm 构建)- 沿线的某个地方,一些开发人员改变了一些东西...... 服务器 1: mysql> select ( no
我在查看 OpenSSL 中使用的一些预处理器宏时,从 crypto/stack/safestack.h 中发现了以下内容: #define CHECKED_STACK_OF(type, p) \
所以我遇到了一个问题,我的正则表达式看起来像这样:/true|false/。 当我检查单词 falsee 时,我从这个正则表达式中得到一个 true,有没有办法将它限制为确切的 true 或 fals
我正在对这个恶意 JavaScript 行进行一些试验:var undefined = true; JavaScript 中每个未初始化的变量都有 undefined 的值,这只是一个保存特殊值 'u
我想将 PHP 的微时间存储为我在 MySQL 中的时间戳。 我去过told最好用 DECIMAL 存储它,但我找不到理想的大小。 有谁知道 microtime(true) 返回的最大大小是多少,所以
在 PHP 中,当您在 URL 中包含诸如“var=true”之类的内容时,URL 中的“true”和“false”是否被转换为 boolean 变量,或者它们是否等于文本“true”还是“假”?例如
我是一名优秀的程序员,十分优秀!