Решение на упр.02 задача 3 от Илиян Гаврилов

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

Към профила на Илиян Гаврилов

Резултати

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

Код

// Тук използвам String, защото базовия тест очаква String, а не
// string slice &str
fn split_string_at(s: String, n: usize) -> (String, String) {
let (str1, str2) = s.split_at(n);
return (str1.to_string(), str2.to_string());
}
// Използвам &str, тъй като е възможно и е препоръчително, но по-детайлно:
// Защото няма промяна на ownership и промяна на големината на данните
// ние връщаме 2 части от входните данни
fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
return s.split_at(n);
}
// Тук използваме mut, тъй като ни е подаден mutable str и трябва да остане
// mutable (предполагам), затова използвам split_at_mut и съответно връщам
// двойка &mut
fn split_slice_mut_at(s: &mut str, n: usize) -> (&mut str, &mut str) {
return s.split_at_mut(n);
}

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

Updating crates.io index
     Locking 17 packages to latest compatible versions
   Compiling proc-macro2 v1.0.102
   Compiling unicode-ident v1.0.20
   Compiling quote v1.0.41
   Compiling futures-sink v0.3.31
   Compiling futures-core v0.3.31
   Compiling futures-channel v0.3.31
   Compiling futures-io v0.3.31
   Compiling memchr v2.7.6
   Compiling syn v2.0.108
   Compiling pin-project-lite v0.2.16
   Compiling futures-task v0.3.31
   Compiling pin-utils v0.1.0
   Compiling slab v0.4.11
   Compiling solution v0.1.0 (/tmp/d20251023-1757769-1cn81a5/solution)
warning: function `split_string_at` is never used
 --> src/lib.rs:3:4
  |
3 | fn split_string_at(s: String, n: usize) -> (String, String) {
  |    ^^^^^^^^^^^^^^^
  |
  = note: `#[warn(dead_code)]` on by default

warning: function `split_slice_at` is never used
  --> src/lib.rs:12:4
   |
12 | fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
   |    ^^^^^^^^^^^^^^

warning: function `split_slice_mut_at` is never used
  --> src/lib.rs:19:4
   |
19 | fn split_slice_mut_at(s: &mut str, n: usize) -> (&mut str, &mut str) {
   |    ^^^^^^^^^^^^^^^^^^

warning: `solution` (lib) generated 3 warnings
   Compiling futures-macro v0.3.31
   Compiling futures-util v0.3.31
   Compiling futures-executor v0.3.31
   Compiling futures v0.3.31
warning: function `split_slice_mut_at` is never used
  --> tests/../src/lib.rs:19:4
   |
19 | fn split_slice_mut_at(s: &mut str, n: usize) -> (&mut str, &mut str) {
   |    ^^^^^^^^^^^^^^^^^^
   |
   = note: `#[warn(dead_code)]` on by default

warning: `solution` (test "solution_test") generated 1 warning
    Finished `test` profile [unoptimized + debuginfo] target(s) in 8.34s
     Running tests/solution_test.rs (target/debug/deps/solution_test-fc1324dc0157cdc7)

running 1 test
test solution_test::test_basic ... ok

test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s

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

Илиян качи първо решение на 16.10.2025 19:49 (преди 14 дена)

Илиян качи решение на 16.10.2025 19:49 (преди 14 дена)

// Тук използвам String, защото базовия тест очаква String, а не
// string slice &str
fn split_string_at(s: String, n: usize) -> (String, String) {
let (str1, str2) = s.split_at(n);
return (str1.to_string(), str2.to_string());
}
// Използвам &str, тъй като е възможно и е препоръчително, но по-детайлно:
// Защото няма промяна на ownership и промяна на големината на данните
// ние връщаме 2 части от входните данни
fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
return s.split_at(n);
}
// Тук използваме mut, тъй като ни е подаден mutable str и трябва да остане
// mutable (предполагам), затова използвам split_at_mut и съответно връщам
// двойка &mut
fn split_slice_mut_at(s: &mut str, n: usize) -> (&mut str, &mut str) {
return s.split_at_mut(n);
-}
-
-fn main() {}
-
-#[test]
-fn test_basic() {
- assert_eq!(split_string_at("ala-bala".to_string(), 4), ("ala-".to_string(), "bala".to_string()));
- assert_eq!(split_string_at("ala-bala".to_string(), 0), ("".to_string(), "ala-bala".to_string()));
- assert_eq!(split_string_at("ala-bala".to_string(), 8), ("ala-bala".to_string(), "".to_string()));
-
- assert_eq!(split_slice_at("ala-bala", 4), ("ala-", "bala"));
- assert_eq!(split_slice_at("ala-bala", 0), ("", "ala-bala"));
- assert_eq!(split_slice_at("ala-bala", 8), ("ala-bala", ""));
}