- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我得到的东西似乎没有多大意义。我正在通过编写一个小程序来练习编码,该程序可以让我在纸牌游戏的特定时间范围内获得某些纸牌的概率。为了计算机会,我需要创建一个执行除法的方法,并将机会报告为分数和小数。所以我设计了这个:
from fractions import Fraction
def time_odds(card_count,turns,deck_size=60):
chance_of_occurence = float(card_count)/float(deck_size)
opening_hand_odds = 7*chance_of_occurence
turn_odds = (7 + turns)*chance_of_occurence
print ("Chance of it being in the opening hand: %s or %s" %(opening_hand_odds,Fraction(opening_hand_odds)))
print ("Chance of it being acquired by turn %s : %s or %s" %(turns,turn_odds,Fraction(turn_odds) ))
然后我像这样使用它:
time_odds(3,5)
但无论出于何种原因,我得到了这个答案:
"Chance of it being in the opening hand: 0.35000000000000003 or
6305039478318695/18014398509481984"
"Chance of it being acquired by turn 5 : 0.6000000000000001 or
1351079888211149/2251799813685248"
所以,几乎是正确的,只是小数点稍有偏差,大约有 0.0000000000003 差异或 0.000000000000000000001 差异。
当我让它像这样进行除法时,Python 不会这样做:
print (7*3/60)
这给了我 0.35,这是正确的。我可以观察到的唯一区别是,当我除以变量而不仅仅是数字时,我得到的值稍微不正确。
我环顾四周寻找答案,大多数不正确的除法问题都与整数除法有关(或者我认为它可以称为地板除法),但我没有找到任何解决这个问题的方法。
当我除以非常大的数字时,我也遇到了类似的问题。这是怎么回事?
为什么会这样呢?我该怎么做才能纠正它?
最佳答案
您看到的额外数字是浮点精度错误。随着您对 float 进行越来越多的运算,错误有可能会复合。
当您尝试手动复制计算时看不到它们的原因是您的复制以不同的顺序执行操作。如果您计算 7 * 3/60
,乘法首先发生(没有错误),除法会引入一个足够小的错误,Python 的 float
类型会为您隐藏它它的 repr
(因为 0.35
明确指代与计算相同的浮点值)。如果您执行 7 * (3/60)
,则首先进行除法(引入错误),然后乘法将错误的大小增加到无法隐藏的程度(因为 0.35000000000000003
是与 0.35
不同的浮点值。
为了避免打印出可能出错的额外数字,您可能需要明确指定将数字转换为字符串时使用的精度。例如,您可以使用 %.3f
,而不是使用 %s
格式代码(对值调用 str
),这将将数字四舍五入到小数点后三位。
您的分数
还有另一个问题。您直接从浮点值创建分数
,该浮点值已经计算出了误差。这就是为什么您看到分数打印出来时带有一个非常大的分子和分母(它准确地代表了与不准确的 float 相同的数字)。如果您将整数分子和分母值传递给 Fraction
构造函数,它将负责为您简化分数,而不会出现任何浮点不准确:
print("Chance of it being in the opening hand: %.3f or %s"
% (opening_hand_odds, Fraction(7*card_count, deck_size)))
这应该打印出数字 0.350
和 7/20
。您当然可以选择您想要的任何小数位数。
与浮点误差完全分开,计算实际上并没有得到正确的概率。您使用的公式可能足够适合您在玩游戏时在头脑中计算,但它并不完全准确。如果您使用计算机来计算数字,那么您不妨做对。
在D
抽牌后,从一副尺寸为M
的牌中抽出至少一张N
特定牌的概率为:
1 - (comb(M-N, D) / comb(M, D))
其中comb
是二元系数或“组合”函数(在数学中通常读作“N选R”,写作“nCr”)。 Python 在标准库中没有该函数的实现,但是您可能已经安装了许多附加模块来提供该函数,或者您可以很容易地编写自己的函数。请参阅this earlier question了解更多详情。
对于您的示例参数,正确的赔率是“5397/17110”或0.315
。
关于python - 算术错误: Python is incorrectly dividing variables,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45071158/
for /f "tokens=*" %%a in ('find /v ":" "%appdata%\gamelauncher\options.txt" ^| find "menu=a"') do (
我在 Javascript 中有一组全局计数器变量: var counter_0 = 0; var counter_1 = 0; var counter_2 = 0; 等等 然后我有一个 Javasc
好的,我正在阅读一些有关 RedBlackTrees 的代码。我注意到这一行“v1 = v2 = v3 = v4;”我理解类似“v1 += v2”(将 v2 添加到 v1 的当前值)和“v1 = v2
我正在为 C# 中的游戏数据加载制作一个 csv 阅读器,我想做的就是从数组(变量)的值声明一个变量,我们可以在 php 中像 $$foo 那样做。喜欢 void csvReader(string s
假设我有变量 内容为“ 123 ”和变量 b123 里面有一些文字。出于某种原因,我想使用变量 作为第二个 var 名称的一部分。像这样的东西: SET a=123 SET b123=some_tex
我对 javascript 有点陌生,我无法通过谷歌搜索找到任何内容,我正在编写一个程序,并且能够执行我所要求的操作: if (Variable == 1 或 Variable == 2 或 Vari
我发现我自己在做这种类型的 IF 语句分配。例如: if($variable == 1 || $variable == "whatever" || $variable == '492') { ...
我的虚拟 PC 在 MS-DOS 6.22 上运行时出现问题。 我需要使用变量 Date ,但我无法得到它,因为每当我尝试回显变量时,它都会显示 %variable%反而。 我在 Windows 控制
尝试运行此代码时: List list = em.createQuery("select balance b from Users where b.userName = '" + user_name.
我有一些代码,其中变量可以是 undefined、null 或正常值。无论变量是 undefined 还是 null,代码都需要做同样的事情。说有没有危险 for (var cur = this.bu
我正在编写一个批处理命令脚本,其中检查环境变量。我需要通过传递所有必需的变量来编写一个 FOR 循环,然后验证它是否已定义,如果未定义,则提示该键的值并永久设置该变量。 问题是我无法取消引用循环变量并
我知道这些是 Rails 的基础知识,但我仍然不知道 = 符号和 => 之间的全部区别以及 @some_variable 之间的区别、@@some_variable 和 :some_variable
我正在使用以下内容创建一个动态变量(PHP 术语中的“变量变量”): foo: "test1" set to-word (rejoin [foo "_result_data"]) array 5 但是
我一直在啃 PHP 套接字服务器和客户端的基础知识 here . 然后我偶然发现了这些行(摘自上面链接的第一个示例,发生在 while 中): if (false === ($buf = socket
这个问题在这里已经有了答案: What does "|=" mean? (pipe equal operator) (6 个答案) 关闭 9 年前。 我正在寻找一些编码来扩展我在 Java 方面的知
如何在 C++ 中从其他变量的值打印变量我只是 C++ 的新手。 在 php 中,我们可以通过其他变量的值来制作/打印一个变量。像这样。 $example = 'foo'; $foo = 'abc';
作为 Ruby on Rails 新手,我明白“@”和“:”引用有不同的含义。我看到了this post在 SO 中,其中描述了一些差异。 @ 表示实例变量(例如@my_selection) :表示别
编程新手/甚至更新。一个小的 go 程序有问题 - 不会编译带有 undefined variable 错误。代码: package main import ( "fmt" "io" "o
我知道其他一些语言,如PHP,支持“变量变量名”的概念--即,字符串的内容可以用作变量名的一部分。。我听说总的来说这不是一个好主意,但我认为它可以解决我在Python代码中遇到的一些问题。。有没有可能
我有两个版本的代码。 版本 1 Launcher.java class Launcher { public static void main(String[] args) {
我是一名优秀的程序员,十分优秀!