- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
所以我正在编写一个 haskell 程序来计算除阶乘的数的最大幂。
largestPower :: Int -> Int -> Int
这里 largestPower a b
找到了 b
的最大幂,它能整除 a!
。
现在我明白了它背后的数学原理,找到答案的方法是重复将a
(只是a)除以b
,忽略余数,最后将所有相加商。所以如果我们有类似的东西
largestPower 10 2
我们应该得到 8 因为 10/2=5/2=2/2=1 并且我们加上 5+2+1=8
但是,我无法弄清楚如何将其作为一个函数来实现,我是使用数组还是只使用一个简单的递归函数。
我倾向于它只是一个普通函数,但我想这可以通过将商存储在数组中并相加来完成。
最佳答案
您可以简单地编写一个递归算法并对每次调用的结果求和。这里我们有两种情况:
a
小于b
,此时最大的幂为0
。所以:
largestPower a b | a < b = 0
a
大于或等于 b
,在这种情况下,我们将 a
除以 b
>,计算该除法的 largestPower
,并将除法添加到结果中。喜欢:
| otherwise = d + largestPower d b
where d = (div a b)
或者放在一起:
largestPower a b | a < b = 1
| otherwise = d + largestPower d b
where d = (div a b)
您还可以将递归与累加器一起使用:您通过递归传递的变量,并相应地进行更新。最后,您返回该累加器(或在该累加器上调用的函数)。
这里的累加器当然是除法的运行乘积,所以:
largestPower = largestPower' <b>0</b>
所以我们将定义一个函数 largestPower'
(注意重音),将累加器作为第一个参数,初始化为 1
。
现在在递归中,有两种情况:
a
小于 b
,我们简单地返回累加器:
largestPower' r a b | a < b = r
否则,我们将累加器与 b
相乘,并通过递归调用将除法传递给 largestPower'
:
| otherwise = largestPower' (d+r) d b
where d = (div a b)
或完整版:
largestPower = largestPower' 1
largestPower' r a b | a < b = r
| otherwise = largestPower' (d+r) d b
where d = (div a b)
算法不正确。一个“天真的”算法是简单地划分每个项目并保持递减直到达到 1
,例如:
largestPower 1 _ = 0
largestPower a b = sumPower a + largestPower (a-1) b
where sumPower n | n `mod` b == 0 = 1 + sumPower (div n b)
| otherwise = 0
所以这意味着对于 largestPower 4 2
,这可以写成:
largestPower 4 2 = sumPower 4 + sumPower 3 + sumPower 2
和:
sumPower 4 = 1 + sumPower 2
= 1 + 1 + sumPower 1
= 1 + 1 + 0
= 2
sumPower 3 = 0
sumPower 2 = 1 + sumPower 1
= 1 + 0
= 1
所以 3
。
关于algorithm - 找到除以haskell的阶乘的数字的最大幂,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42862384/
你有没有注意到 Excel Vba 代码中除法 2/60 的问题?我正在使用 Excel 2013。请测试以下代码: Sub test1() Dim A As Integer Dim B As Int
我正在运行长时间的模拟。我将结果记录到 vector 中以计算有关数据的统计信息。我意识到,理论上,这些样本可能是除以零的结果。这只是理论上的,我很确定事实并非如此。为了避免修改代码后重新运行模拟,我
我有一些可以包含字母、数字和“#”符号的字符串。 我想删除除以“#”开头的单词以外的数字 下面是一个例子: "table9 dolv5e #10n #dec10 #nov8e 23 hello" 预期
我有以下代码,问题是我尝试将 Double 除以 Int factorial :: Int -> Int factorial 0 = 1 factorial e = e * (factorial e-
我有以下查询,它试图计算出某种产品占产品总数的百分比。 IE:[产品数量]/[产品总数] = 百分比 ;WITH totalCount AS( SELECT CAST(COUN
我正在解析字符串,然后需要将其转换为数字。但如果它包含除以 0 的例子 String str1 = "1+2+3-5/0+4+6" String str2 = "1+2+3-4/0.000 +4+6"
这个问题已经有答案了: Right Shift to Perform Divide by 2 On -1 (6 个回答) 已关闭 9 年前。 在阅读 Collections.reverse 的 Jav
我是 C++ 新手。我听说除以0会导致运行时错误,但是当我尝试时,它抛给我一个编译器错误C2124并且没有创建目标文件,所以编译器会自动运行代码以查看它是否可以在创建之前执行目标文件? (顺便说一句,
我试图在 codefights.com 上解决这个问题,方法是找出最大的质因数并将该数字除以质因数的幂。 int highestPower(int N, int A) { int B =A, j=0,
我对在不同计算机上运行程序有疑问。 我用 C++\windows 7 64 位\Visual Studio 编写了一个程序,该程序在我的计算机上完美运行。 当我尝试在另一台计算机(Windows 7
这个问题已经有答案了: Division in C++ not working as expected (6 个回答) 已关闭 9 年前。 Helo,我是编程新手,遇到了一个问题,我有一个整数,例如
我正在做某事,但遇到了一个我不明白的问题。 double d = 95.24 / (double)100; Console.Write(d); //Break point here 控制台输出是 0.
我需要仅使用按位运算符(例如 ! & ^ ~ 和移位)来计算数字 (a/(2**b)。我得到了以下提示,但我是 C 新手,我不知道什么是代码含义: int bias = x>0 ? 0 : ((1>b
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: Java Integer division: How do you produce a double? 当我
嗨,我正在尝试将 numpy 数组分成两部分,并在一个循环中进行此操作,例如: main_array.shape = (50, 400, 400, 3) for i = 0: sub_array_1
这是片段: String myTime = someTime / 1e9d + ","; someTime 是使用 System.nanoTime() 派生的。 1e9d 在这里做什么? 最佳答案 1
Random random = new Random(); int randomx = random.Next(0, 240); 这是我获取随机数的方式,从 0 到 240,如何才能只获取除以 5 的
我一直在处理一个应用程序,因为图像表现得很奇怪,所以我决定打开 Wall 标志,看看是否有任何奇怪的事情发生。它揭示了一个新的警告: character.cpp(364): warning C4723
我是 Android Studio 的新手,我正在开发一个计算器应用程序。现在,当我除以零时,自然会收到错误消息“Infinity”,但如果我想将其更改为“不能除以零”,我该怎么做呢? impor
如何显示每 5 日创建一个新行的表中的数据 ? 例子 data: [1,2,3,4,5,6]; 成分: {{item}} 预期的: | 1 | 2 | 3 | 4 | 5 | | 6 |
我是一名优秀的程序员,十分优秀!