我的理解是否正确,即使用RubyBigDecimal类型(即使具有不同的精度和标度长度)应该准确计算还是我应该预测浮点恶作剧?我在Rails应用程序中的所有值都是BigDecimal类型,我看到了一些错误(它们确实有不同的小数长度),希望这只是我的方法而不是我的对象类型。 最佳答案 使用浮点运算时有两个常见的陷阱。第一个问题是Rubyfloat具有固定的精度。在实践中,这要么是1)对您来说没问题,要么2)灾难性的,或者3)介于两者之间。请考虑以下事项:#float1.0e+25-9999999999999999900000000.0
这看起来非常低效。谁能给我一个更好的Ruby方式。defround_valuex=(self.value*10).round/10.0#roundstotwodecimalplacesr=x.modulo(x.floor)#findsremainderf=x.floorself.value=casewhenr.between?(0,0.25)fwhenr.between?(0.26,0.75)f+0.5whenr.between?(0.76,0.99)f+1.0endend 最佳答案 classFloatdefround_point
我是Ruby的新手,我正在尝试弄清楚ceil和floor是如何工作的,因为当使用小数或小数时我会得到不同的答案(相似的值(value))。以下是我尝试过的:puts8/3.ceil==2#=>trueputs8/3.floor==2#=>trueputs2.67.ceil==2#=>falseputs2.67.floor==2#=>true根据我的理解,ceil应该返回一个更高的数字,而floor应该返回一个更低的数字。希望有人能启发我。谢谢!:) 最佳答案 一切都正确返回。puts8/3.ceil==2#=>true,becaus
我有一个float,我想截断到3个位置,但我不想四舍五入。例如,将1.0155555555555555转换为1.015(而不是1.016)。我将如何在Ruby中执行此操作? 最佳答案 您还可以转换为BigDecimal,然后对其调用truncate。1.237.to_d.truncate(2).to_f#willreturn1.23 关于ruby-截断float而不向上舍入,我们在StackOverflow上找到一个类似的问题: https://stackov
我想知道如何在Ruby中获得幂的倒数?2**4#=>16然后我想得到它的逆,但我不确定要使用哪个运算符16??2#=>4 最佳答案 指数的倒数是对数。如果ab=c,然后logac=b.您可以在Math中找到对数函数模块,特别是log()对于base-e和log10()以10为基数。要获得以不同为底的对数(例如n),请使用公式logNa=logxa/logxN,其中x是一个值,例如e或10。针对您的特定案例:log216=loge16/loge2=Math.log(16)/Math.log(2)=4你认为这个解释是好的是因为它扩展了你
在Ruby中,一切皆对象。这就是为什么我不明白为什么我们有Math模块。在我看来,Math模块中的大部分(全部?)函数应该是Integer、Float等数字类型的方法。例如而不是Math.sqrt(5)这样会更有意义5.sqrtsin、cos、tan、log10等也是如此。有谁知道为什么所有这些函数最终都在数学模块中? 最佳答案 我不知道Ruby的早期历史,但我感觉Math模块是在Cheader之后建模的。不过,它在Ruby标准库中是一只奇怪的鸭子。但是,它是Ruby!所以你总能摆脱猴子补丁!classFloatdefsqrt;Ma
我正在用Ruby创建一个箱线图生成器,我需要计算一些东西。假设我有这个数组:arr=[1,5,7,2,53,65,24]如何从上述数组中找到最低值(1)、最高值(65)、总计(157)、平均值(22.43)和中位数(7)?谢谢 最佳答案 lowest=arr.minhighest=arr.maxtotal=arr.inject(:+)len=arr.lengthaverage=total.to_f/len#to_fsowedon'tgetanintegerresultsorted=arr.sortmedian=len%2==1?so
例如,我有4800,我想查看这个数字的所有因数。#num=thenumberyouwantfactorsofdeffactors_of(num)(1..num).collect{|n|[n,num/n]if((num/n)*n)==num}.compactenddivisors_of(4800)=>[[1,4800],[2,2400],[3,1600],[4,1200],[5,960],[6,800],[8,600],[10,480],[12,400],[15,320],[16,300],[20,240],[24,200],[25,192],[30,160],[32,150],[40,
我正在尝试使用Ruby获取除法的剩余部分。假设我们要将208除以11。最终应该是“18余10”...我最终需要的是10。这是我到目前为止所得到的,但在这个用例中它会窒息(说余数是0)。division=208.to_f/11rounded=(division*10).ceil/10.0remainder=rounded.round(1).to_s.last.to_i 最佳答案 模运算符:>208%11=>10 关于ruby-如何在Ruby中找到除法的余数?,我们在StackOverflo
我正在处理货币,我想将数字向下舍入到小数点后两位。即使数字是500.0,我也希望它是500.00以保持一致。当我执行“500.00”.to_d时,它会将其转换为500.0。改变这种行为的好方法是什么?我还使用这种方法向下舍入到2位数字,并确保它始终有2位小数。defself.round_down(x,n=2)s=x.to_sl=s.index('.')?s.index('.')+1+n:s.lengths=s[0,l]s=s.index('.')?s.length-(s.index('.')+1)==1?s 最佳答案 除了mcfin