Решение на упр.02 задача 3 от Венислав Трендафилов

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

Към профила на Венислав Трендафилов

Резултати

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

Код

fn split_string_at(s: String, n: usize) -> (String, String) {
let start = s[0..n].to_string();
let end = s[n..].to_string();
(start, end)
}
fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
let start = &s[..n];
let end = &s[n..];
(start, end)
}
//fn split_slice_mut_at(s: &mut str, n: usize) -> (??, ??)
//Не може да се имплементира, защото &mut str ни ограничава.
// 1.Не може да върнем изменяеми референции защото може да има само една.
// 2.Не може да върнем String, защото се налага да се
// направят референции за двете части, което води до едновременно
// съществуване на изменяеми и неизменяеми референции.

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

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-core v0.3.31
   Compiling futures-sink v0.3.31
   Compiling futures-channel v0.3.31
   Compiling pin-project-lite v0.2.16
   Compiling pin-utils v0.1.0
   Compiling futures-task v0.3.31
   Compiling syn v2.0.108
   Compiling memchr v2.7.6
   Compiling futures-io v0.3.31
   Compiling slab v0.4.11
   Compiling solution v0.1.0 (/tmp/d20251023-1757769-150hy6x/solution)
warning: function `split_string_at` is never used
 --> src/lib.rs:1:4
  |
1 | 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:7:4
  |
7 | fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
  |    ^^^^^^^^^^^^^^

warning: `solution` (lib) generated 2 warnings
   Compiling futures-macro v0.3.31
   Compiling futures-util v0.3.31
   Compiling futures-executor v0.3.31
   Compiling futures v0.3.31
    Finished `test` profile [unoptimized + debuginfo] target(s) in 8.39s
     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 коментара)

Венислав качи първо решение на 21.10.2025 21:47 (преди 9 дена)

Венислав качи решение на 22.10.2025 23:45 (преди 8 дена)

fn split_string_at(s: String, n: usize) -> (String, String) {
let start = s[0..n].to_string();
let end = s[n..].to_string();
(start, end)
}
fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
let start = &s[..n];
let end = &s[n..];
(start, end)
}
//fn split_slice_mut_at(s: &mut str, n: usize) -> (??, ??)
//Не може да се имплементира, защото &mut str ни ограничава.
// 1.Не може да върнем изменяеми референции защото може да има само една.
// 2.Не може да върнем String, защото се налага да се
// направят референции за двете части, което води до едновременно
// съществуване на изменяеми и неизменяеми референции.
-
-#[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", ""));
-}