5.0 KiB
lab1
Описание задачи
Цель: освоить базовые приёмы и абстракции функционального программирования: функции, поток управления и поток данных, сопоставление с образцом, рекурсия, свёртка, отображение, работа с функциями как с данными, списки.
В рамках лабораторной работы вам предлагается решить несколько задач проекта Эйлер. Список задач -- ваш вариант.
Для каждой проблемы должно быть представлено несколько решений:
- монолитные реализации с использованием:
- хвостовой рекурсии;
- рекурсии (вариант с хвостовой рекурсией не является примером рекурсии);
- модульной реализации, где явно разделена генерация последовательности, фильтрация и свёртка (должны использоваться функции reduce/fold, filter и аналогичные);
- генерация последовательности при помощи отображения (map);
- работа со спец. синтаксисом для циклов (Gleam не применимо);
- работа с бесконечными списками для языков, поддерживающих ленивые коллекции или итераторы как часть языка (в Gleam только через сторонние библиотеки, а не часть языка);
- реализация на любом удобном для вас традиционном языке программирования для сравнения. (Kotlin)
Требуется использовать идиоматичный для технологии стиль программирования.
Содержание отчёта:
- титульный лист;
- описание проблемы;
- ключевые элементы реализации с минимальными комментариями;
- выводы (отзыв об использованных приёмах программирования).
Примечания:
- необходимо понимание разницы между ленивыми коллекциями и итераторами;
- нужно знать особенности используемой технологии и того, как работают использованные вами приёмы.
Задачи к выполнению
Task 1
If we list all the natural numbers below 10 that are multiples of 3 or 5, we get 3, 5, 6 and 9. The sum of these multiples is 23.
Find the sum of all the multiples of 3 or 5 below 1000.
Task 30
Surprisingly there are only three numbers that can be written as the sum of fourth powers of their digits:
$$\begin{align}
1634 = 1^4 + 6^4 + 3^4 + 4^4\
8208 = 8^4 + 2^4 + 0^4 + 8^4\
9474 = 9^4 + 4^4 + 7^4 + 4^4
\end{align}$$
As 1 = 1^4 is not a sum it is not included.
The sum of these numbers is 1634 + 8208 + 9474 = 19316.
Find the sum of all the numbers that can be written as the sum of fifth powers of their digits.
Проверка
gleam run # Run the project
gleam test # Run the tests
>gleam run
Compiling lab1
Compiled in 0.50s
Running lab1.main
======================================================================
TASK 1: Sum of multiples of 3 or 5 below 1000
======================================================================
1. Tail recursion:
Result: 233168
2. Regular recursion:
Result: 233701
3. Modular (filter + fold):
Result: 233168
4. Map-based:
Result: 233168
======================================================================
TASK 2: Sum of numbers equal to sum of 5th powers of digits
======================================================================
1. Tail recursion:
Result: 443839
2. Regular recursion:
Result: 443839
3. Modular (filter + fold):
Result: 443839
4. Map-based:
Result: 443839
И референс на kotlin
fun main() {
// Task 1: Sum of multiples of 3 or 5 below 1000
val sum1 = (1 until 1000).filter { it % 3 == 0 || it % 5 == 0 }.sum()
println("Task 1: $sum1")
// Task 30: Sum of numbers equal to sum of fifth powers of their digits
val sum30 = (2..443839).filter { num ->
val digits = num.toString().map { it.digitToInt() }
val powerSum = digits.sumOf { it.toDouble().pow(5).toInt() }
powerSum == num
}.sum()
println("Task 30: $sum30")
}
Task 1: 233168
Task 30: 443839