99 questions/31 to 41: Difference between revisions
No edit summary |
mNo edit summary |
||
(32 intermediate revisions by 15 users not shown) | |||
Line 1: | Line 1: | ||
__NOTOC__ | __NOTOC__ | ||
This is part of [[H-99:_Ninety-Nine_Haskell_Problems|Ninety-Nine Haskell Problems]], based on [https://prof.ti.bfh.ch/hew1/informatik3/prolog/p-99/ Ninety-Nine Prolog Problems]. | |||
== Problem 31 == | == Problem 31 == | ||
<div style="border-bottom:1px solid #eee">(**) Determine whether a given integer number is prime. <span style="float:right"><small>[[99 questions/Solutions/31|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Example: | |||
<pre> | <pre> | ||
* (is-prime 7) | * (is-prime 7) | ||
T | T | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
isPrime | λ> isPrime 7 | ||
True | |||
</haskell> | </haskell> | ||
== Problem 32 == | == Problem 32 == | ||
<div style="border-bottom:1px solid #eee">(**) Determine the greatest common divisor of two positive integer numbers. <span style="float:right"><small>[[99 questions/Solutions/32|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Use [http://en.wikipedia.org/wiki/Euclidean_algorithm Euclid's algorithm]. | |||
Example: | |||
<pre> | <pre> | ||
* (gcd 36 63) | * (gcd 36 63) | ||
9 | 9 | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
λ> [myGCD 36 63, myGCD (-3) (-6), myGCD (-3) 6] | |||
[9,3,3] | |||
</haskell> | </haskell> | ||
== Problem 33 == | == Problem 33 == | ||
<div style="border-bottom:1px solid #eee">(*) Determine whether two positive integer numbers are coprime. <span style="float:right"><small>[[99 questions/Solutions/33|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Two numbers are coprime if their greatest common divisor equals 1. | Two numbers are coprime if their greatest common divisor equals 1. | ||
Example: | |||
<pre> | <pre> | ||
* (coprime 35 64) | * (coprime 35 64) | ||
Line 69: | Line 62: | ||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
coprime | λ> coprime 35 64 | ||
True | |||
</haskell> | </haskell> | ||
== Problem 34 == | == Problem 34 == | ||
<div style="border-bottom:1px solid #eee">(**) Calculate Euler's totient function phi(m). <span style="float:right"><small>[[99 questions/Solutions/34|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Euler's so-called totient function phi(m) is defined as the number of positive integers r (1 <= r < m) that are coprime to m. | Euler's so-called totient function phi(m) is defined as the number of positive integers r (1 <= r < m) that are coprime to m. | ||
Example: m = 10: r = 1,3,7,9; thus phi(m) = 4. Note the special case: phi(1) = 1. | Example: m = 10: r = 1,3,7,9; thus phi(m) = 4. Note the special case: phi(1) = 1. | ||
Example: | |||
<pre> | <pre> | ||
* (totient-phi 10) | * (totient-phi 10) | ||
4 | 4 | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
totient | λ> totient 10 | ||
4 | |||
</haskell> | </haskell> | ||
== Problem 35 == | == Problem 35 == | ||
<div style="border-bottom:1px solid #eee">(**) Determine the prime factors of a given positive integer. <span style="float:right"><small>[[99 questions/Solutions/35|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Construct a flat list containing the prime factors in ascending order. | Construct a flat list containing the prime factors in ascending order. | ||
Example: | |||
<pre> | <pre> | ||
* (prime-factors 315) | * (prime-factors 315) | ||
(3 3 5 7) | (3 3 5 7) | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
λ> primeFactors 315 | |||
primeFactors | [3, 3, 5, 7] | ||
</haskell> | </haskell> | ||
== Problem 36 == | == Problem 36 == | ||
(**) Determine the prime factors of a given positive integer. | <div style="border-bottom:1px solid #eee">(**) Determine the prime factors and their multiplicities of a given positive integer. <span style="float:right"><small>[[99 questions/Solutions/36|Solutions]]</small></span> | ||
</div> | |||
<br> | |||
Construct a list containing | Construct a list containing each prime factor and its multiplicity. | ||
Example: | |||
<pre> | <pre> | ||
* (prime-factors-mult 315) | * (prime-factors-mult 315) | ||
((3 2) (5 1) (7 1)) | ((3 2) (5 1) (7 1)) | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
prime_factors_mult | λ> prime_factors_mult 315 | ||
[(3,2),(5,1),(7,1)] | |||
</haskell> | </haskell> | ||
== Problem 37 == | == Problem 37 == | ||
<div style="border-bottom:1px solid #eee">(**) Calculate Euler's totient function phi(m) (improved). <span style="float:right"><small>[[99 questions/Solutions/37|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
See Problem 34 for the definition of Euler's totient function. If the list of the prime factors of a number m is known in the form of problem 36 then the function phi(m) can be efficiently calculated as follows: Let ((p1 m1) (p2 m2) (p3 m3) ...) be the list of prime factors (and their multiplicities) of a given number m. Then phi(m) can be calculated with the following formula: | |||
<pre> | <pre> | ||
phi(m) = (p1 - 1) * p1 ** (m1 - 1) * | |||
< | (p2 - 1) * p2 ** (m2 - 1) * | ||
(p3 - 1) * p3 ** (m3 - 1) * ... | |||
</pre> | |||
Note that a ** b stands for the b'th power of a. | |||
== Problem 38 == | == Problem 38 == | ||
<div style="border-bottom:1px solid #eee">(*) Compare the two methods of calculating Euler's totient function. <span style="float:right"><small>(no solution required)</small></span> | |||
</div> | |||
<br> | |||
Use the solutions of Problems 34 and 37 to compare the algorithms. Take the number of reductions as a measure for efficiency. Try to calculate phi(10090) as an example. | |||
== Problem 39 == | == Problem 39 == | ||
<div style="border-bottom:1px solid #eee">(*) A list of prime numbers in a given range. <span style="float:right"><small>[[99 questions/Solutions/39|Solutions]]</small></span> | |||
A list of prime numbers. | </div> | ||
<br> | |||
Given a range of integers by its lower and upper limit, construct a list of all prime numbers in that range. | Given a range of integers by its lower and upper limit, construct a list of all prime numbers in that range. | ||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
primesR | λ> primesR 10 20 | ||
[11,13,17,19] | |||
</haskell> | </haskell> | ||
== Problem 40 == | |||
< | <div style="border-bottom:1px solid #eee">(**) Goldbach's conjecture. <span style="float:right"><small>[[99 questions/Solutions/40|Solutions]]</small></span> | ||
</div> | |||
<br> | |||
Goldbach's conjecture says that every positive even number greater than 2 is the sum of two prime numbers. Example: 28 = 5 + 23. It is one of the most famous facts in number theory that has not been proved to be correct in the general case. It has been numerically confirmed up to very large numbers (much larger than we can go with our Prolog system). Write a predicate to find the two prime numbers that sum up to a given even integer. | |||
Example: | |||
<pre> | <pre> | ||
* (goldbach 28) | |||
< | (5 23) | ||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
λ> goldbach 28 | |||
(5, 23) | |||
</haskell> | </haskell> | ||
== Problem 41 == | == Problem 41 == | ||
<div style="border-bottom:1px solid #eee">(**) A list of even numbers and their Goldbach compositions in a given range. <span style="float:right"><small>[[99 questions/Solutions/41|Solutions]]</small></span> | |||
</div> | |||
<br> | |||
Given a range of integers by its lower and upper limit, print a list of all even numbers and their Goldbach composition. | |||
In most cases, if an even number is written as the sum of two prime numbers, one of them is very small. Very rarely, the primes are both bigger than say 50. Try to find out how many such cases there are in the range 2..3000. | |||
Example: | |||
<pre> | <pre> | ||
* (goldbach-list 9 20) | |||
< | 10 = 3 + 7 | ||
12 = 5 + 7 | |||
14 = 3 + 11 | |||
16 = 3 + 13 | |||
18 = 5 + 13 | |||
20 = 3 + 17 | |||
* (goldbach-list 1 2000 50) | |||
992 = 73 + 919 | |||
1382 = 61 + 1321 | |||
1856 = 67 + 1789 | |||
1928 = 61 + 1867 | |||
</pre> | |||
Example in Haskell: | Example in Haskell: | ||
<haskell> | <haskell> | ||
λ> goldbachList 9 20 | |||
[(3,7),(5,7),(3,11),(3,13),(5,13),(3,17)] | |||
λ> goldbachList' 4 2000 50 | |||
[(73,919),(61,1321),(67,1789),(61,1867)] | |||
</haskell> | </haskell> | ||
[[Category:Tutorials]] | [[Category:Tutorials]] |
Latest revision as of 02:30, 11 June 2023
This is part of Ninety-Nine Haskell Problems, based on Ninety-Nine Prolog Problems.
Problem 31
Example:
* (is-prime 7) T
Example in Haskell:
λ> isPrime 7
True
Problem 32
Use Euclid's algorithm.
Example:
* (gcd 36 63) 9
Example in Haskell:
λ> [myGCD 36 63, myGCD (-3) (-6), myGCD (-3) 6]
[9,3,3]
Problem 33
Two numbers are coprime if their greatest common divisor equals 1.
Example:
* (coprime 35 64) T
Example in Haskell:
λ> coprime 35 64
True
Problem 34
Euler's so-called totient function phi(m) is defined as the number of positive integers r (1 <= r < m) that are coprime to m.
Example: m = 10: r = 1,3,7,9; thus phi(m) = 4. Note the special case: phi(1) = 1.
Example:
* (totient-phi 10) 4
Example in Haskell:
λ> totient 10
4
Problem 35
Construct a flat list containing the prime factors in ascending order.
Example:
* (prime-factors 315) (3 3 5 7)
Example in Haskell:
λ> primeFactors 315
[3, 3, 5, 7]
Problem 36
Construct a list containing each prime factor and its multiplicity.
Example:
* (prime-factors-mult 315) ((3 2) (5 1) (7 1))
Example in Haskell:
λ> prime_factors_mult 315
[(3,2),(5,1),(7,1)]
Problem 37
See Problem 34 for the definition of Euler's totient function. If the list of the prime factors of a number m is known in the form of problem 36 then the function phi(m) can be efficiently calculated as follows: Let ((p1 m1) (p2 m2) (p3 m3) ...) be the list of prime factors (and their multiplicities) of a given number m. Then phi(m) can be calculated with the following formula:
phi(m) = (p1 - 1) * p1 ** (m1 - 1) * (p2 - 1) * p2 ** (m2 - 1) * (p3 - 1) * p3 ** (m3 - 1) * ...
Note that a ** b stands for the b'th power of a.
Problem 38
Use the solutions of Problems 34 and 37 to compare the algorithms. Take the number of reductions as a measure for efficiency. Try to calculate phi(10090) as an example.
Problem 39
Given a range of integers by its lower and upper limit, construct a list of all prime numbers in that range.
Example in Haskell:
λ> primesR 10 20
[11,13,17,19]
Problem 40
Goldbach's conjecture says that every positive even number greater than 2 is the sum of two prime numbers. Example: 28 = 5 + 23. It is one of the most famous facts in number theory that has not been proved to be correct in the general case. It has been numerically confirmed up to very large numbers (much larger than we can go with our Prolog system). Write a predicate to find the two prime numbers that sum up to a given even integer.
Example:
* (goldbach 28) (5 23)
Example in Haskell:
λ> goldbach 28
(5, 23)
Problem 41
Given a range of integers by its lower and upper limit, print a list of all even numbers and their Goldbach composition.
In most cases, if an even number is written as the sum of two prime numbers, one of them is very small. Very rarely, the primes are both bigger than say 50. Try to find out how many such cases there are in the range 2..3000.
Example:
* (goldbach-list 9 20) 10 = 3 + 7 12 = 5 + 7 14 = 3 + 11 16 = 3 + 13 18 = 5 + 13 20 = 3 + 17 * (goldbach-list 1 2000 50) 992 = 73 + 919 1382 = 61 + 1321 1856 = 67 + 1789 1928 = 61 + 1867
Example in Haskell:
λ> goldbachList 9 20
[(3,7),(5,7),(3,11),(3,13),(5,13),(3,17)]
λ> goldbachList' 4 2000 50
[(73,919),(61,1321),(67,1789),(61,1867)]