Решение на FMI Buzz от Деян Горанов
Резултати
- 15 точки от тестове
- 0 бонус точки
- 15 точки общо
- 10 успешни тест(а)
- 0 неуспешни тест(а)
Код
fn divides(b: usize, a: usize) -> bool {
a % b == 0
}
/// Вход: променлива `n`, която описва броя елементи, които ще генерираме в резултата.
///
/// За всяко число от 1 до `n` включително, искаме съответстващия елемент в резултата да е:
///
/// - String със съдържание "Fizz" ако числото се дели на 3, но не на 5
/// - String със съдържание "Buzz" ако числото се дели на 5, но не на 3
/// - String със съдържание "Fizzbuzz" ако числото се дели и на 3, и на 5
/// - Числото конвертирано до низ, във всички други случаи
///
/// Тоест, във `fizzbuzz(3)`, първия елемент ще бъде `String::from("1")`, втория
/// `String::from("2")`, последния `String::from("Fizz")`.
///
/// Ако `n` е 0, очакваме празен вектор за резултат.
///
pub fn fizzbuzz(n: usize) -> Vec<String> {
let to_fizzbuzz =
|i: usize|
if divides(15, i) {
String::from("Fizzbuzz")
} else if divides(3, i) {
String::from("Fizz")
} else if divides(5, i) {
String::from("Buzz")
} else {
i.to_string()
}
;
(1..=n)
.map(to_fizzbuzz)
.collect()
}
/// Вход:
/// - променлива `n`, която описва броя елементи, които ще генерираме в резултата.
/// - променливи `k1` и `k2`, които са двата делителя, които ще използваме за заместване.
///
/// За всяко число от 1 до `n` включително, искаме съответстващия елемент в резултата да е:
///
/// - String със съдържание "Fizz" ако числото се дели на k1, но не на k2
/// - String със съдържание "Buzz" ако числото се дели на k2, но не на k1
/// - String със съдържание "Fizzbuzz" ако числото се дели и на k1, и на k2
/// - Числото конвертирано до низ, във всички други случаи
///
/// Ако `n` е 0, очакваме празен вектор за резултат.
/// Ако `k1` или `k2` са 0 или 1, очакваме функцията да panic-не с каквото съобщение изберете.
///
pub fn custom_buzz(n: usize, k1: u8, k2: u8) -> Vec<String> {
if [k1,k2].iter().any(
|k| [0,1].iter().any(|c| k == c)
) {
panic!("cannot fizzbuzz on 0 or 1!");
}
let to_fizzbuzz =
|i: usize|
match (divides(k1 as usize, i), divides(k2 as usize, i)) {
(true, false) => String::from("Fizz"),
(false, true) => String::from("Buzz"),
(true, true) => String::from("Fizzbuzz"),
(false, false) => i.to_string(),
};
(1..=n)
.map(to_fizzbuzz)
.collect()
}
/// Параметри:
/// - полета `k1` и `k2`, които са двата делителя, които ще използваме за заместване.
/// - поле `labels`, които са трите етикета, които съответстват на коефициентите
///
/// Ако `n` е 0, очакваме празен вектор за резултат.
/// Ако `k1` или `k1` са 0 или 1, очакваме функцията да panic-не с каквото съобщение изберете.
///
pub struct FizzBuzzer {
pub k1: u8,
pub k2: u8,
pub labels: [String; 3],
}
impl FizzBuzzer {
/// За всяко число от 1 до `n` включително, искаме съответстващия елемент в резултата да е:
///
/// - Първия String от полето `labels` ако числото се дели на k1, но не на k2
/// - Втория String от полето `labels` ако числото се дели на k2, но не на k1
/// - Третия String от полето `labels` ако числото се дели и на k1, и на k2
/// - Числото конвертирано до низ, във всички други случаи
///
pub fn take(&self, n: usize) -> Vec<String> {
if [self.k1, self.k2].iter().any(
|k| [0,1].iter().any(|c| k == c)
) {
panic!("cannot fizzbuzz on 0 or 1!");
}
let m1 = self.k1 as usize;
let m2 = self.k2 as usize;
let to_fizzbuzz =
|i: usize|
match (divides(m1, i), divides(m2, i)) {
(true, false) => self.labels[0].clone(),
(false, true) => self.labels[1].clone(),
(true, true) => self.labels[2].clone(),
(false, false) => i.to_string(),
};
(1..=n)
.map(to_fizzbuzz)
.collect()
}
/// Параметъра `index` указва кой етикет от полето `labels` променяме, от 0 до 2. Ако подадения
/// `index` е извън тези рамки, очакваме функцията да panic-не.
///
/// Стойността `value` е низа, който ще сложим на този индекс в полето `labels`.
///
pub fn change_label(&mut self, index: usize, value: &String) {
self.labels[index] = value.clone();
}
}
Лог от изпълнението
Compiling solution v0.1.0 (/tmp/d20201028-2816268-1jgo482/solution) Finished test [unoptimized + debuginfo] target(s) in 2.27s Running target/debug/deps/solution-ebb42508826ef2b4 running 0 tests test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out Running target/debug/deps/solution_test-9e954a53ed808c89 running 10 tests test solution_test::test_change_label_basic ... ok test solution_test::test_change_label_invalid ... ok test solution_test::test_classic1 ... ok test solution_test::test_classic2 ... ok test solution_test::test_coefficients1 ... ok test solution_test::test_coefficients2 ... ok test solution_test::test_coefficients_invalid ... ok test solution_test::test_struct_basic ... ok test solution_test::test_struct_invalid ... ok test solution_test::test_zeroes ... ok test result: ok. 10 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out Doc-tests solution running 0 tests test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out