Решение на FMI Buzz от Георги Катевски

Обратно към всички решения

Към профила на Георги Катевски

Резултати

  • 9 точки от тестове
  • 0 бонус точки
  • 9 точки общо
  • 6 успешни тест(а)
  • 4 неуспешни тест(а)

Код

pub fn fizzbuzz(n: usize) -> Vec<String> {
let mut vec: Vec<String> = Vec::with_capacity(n);
if n==0
{
return vec;
}
for i in 1..n+1
{
if i%3==0 && i%5!=0
{
let s=String::from("Fizz");
vec.push(s);
}
else if i%5==0 && i%3!=0
{
vec.push("Buzz".to_string());
}
else if i%5==0 && i%3==0
{
vec.push("FizzBuzz".to_string());
}
else
{
vec.push(i.to_string());
}
}
return vec;
}
pub fn custom_buzz(n: usize, k1: u8, k2: u8) -> Vec<String> {
if k1==0 || k2==0 || k2==1 || k1==1
{
panic!("Problem!");
}
let mut vec: Vec<String> = Vec::with_capacity(n);
if n==0
{
return vec;
}
for i in 1..n+1
{
if i%usize::from(k1)==0 && i%usize::from(k2)!=0
{
let s=String::from("Fizz");
vec.push(s);
}
else if i%usize::from(k2)==0 && i%usize::from(k1)!=0
{
vec.push("Buzz".to_string());
}
else if i%usize::from(k2)==0 && i%usize::from(k1)==0
{
vec.push("FizzBuzz".to_string());
}
else
{
vec.push(i.to_string());
}
}
return vec;
}
/// Параметри:
/// - полета `k1` и `k2`, които са двата делителя, които ще използваме за заместване.
/// - поле `labels`, които са трите етикета, които съответстват на коефициентите
///
/// Ако `n` е 0, очакваме празен вектор за резултат.
/// Ако `k1` или `k2` са 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> {
let mut vec: Vec<String> = Vec::with_capacity(n);
if n==0
{
return vec;
}
if self.k1==0 || self.k2==0 || self.k2==1 || self.k1==1
{
panic!("Problem!");
}
for i in 1..n+1
{
if i%usize::from(self.k1)==0 && i%usize::from(self.k2)!=0
{
vec.push(self.labels[0].to_string());
}
else if i % usize::from(self.k1)!=0 && i% usize::from(self.k2)==0
{
vec.push(self.labels[1].to_string());
}
else if i% usize::from(self.k1)==0 && i% usize::from(self.k2)==0
{
vec.push(self.labels[2].to_string());
}
else
{
vec.push(i.to_string());
}
}
return vec;
}
/// Параметъра `index` указва кой етикет от полето `labels` променяме, от 0 до 2. Ако подадения
/// `index` е извън тези рамки, очакваме функцията да panic-не.
///
/// Стойността `value` е низа, който ще сложим на този индекс в полето `labels`.
///
pub fn change_label(&mut self, index: usize, value: &String)
{
if index>2
{
panic!("Out of range!");
}
self.labels[index]=value.to_string();
}
}

Лог от изпълнението

Compiling solution v0.1.0 (/tmp/d20201028-2816268-1o0cymz/solution)
    Finished test [unoptimized + debuginfo] target(s) in 2.05s
     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 ... FAILED
test solution_test::test_classic2 ... FAILED
test solution_test::test_coefficients1 ... FAILED
test solution_test::test_coefficients2 ... FAILED
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

failures:

---- solution_test::test_classic1 stdout ----
thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `["1", "2", "Fizz", "4", "Buzz", "Fizz", "7", "8", "Fizz", "Buzz", "11", "Fizz", "13", "14", "FizzBuzz", "16"]`,
 right: `["1", "2", "Fizz", "4", "Buzz", "Fizz", "7", "8", "Fizz", "Buzz", "11", "Fizz", "13", "14", "Fizzbuzz", "16"]`', tests/solution_test.rs:19:5

---- solution_test::test_classic2 stdout ----
thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `Some("FizzBuzz")`,
 right: `Some("Fizzbuzz")`', tests/solution_test.rs:34:5

---- solution_test::test_coefficients1 stdout ----
thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `Some("FizzBuzz")`,
 right: `Some("Fizzbuzz")`', tests/solution_test.rs:48:5

---- solution_test::test_coefficients2 stdout ----
thread 'main' panicked at 'assertion failed: `(left == right)`
  left: `Some("FizzBuzz")`,
 right: `Some("Fizzbuzz")`', tests/solution_test.rs:57:5


failures:
    solution_test::test_classic1
    solution_test::test_classic2
    solution_test::test_coefficients1
    solution_test::test_coefficients2

test result: FAILED. 6 passed; 4 failed; 0 ignored; 0 measured; 0 filtered out

error: test failed, to rerun pass '--test solution_test'

История (1 версия и 0 коментара)

Георги качи първо решение на 28.10.2020 12:59 (преди почти 5 години)