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

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

Към профила на Деян Делчев

Резултати

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

Код

fn split_slice_at(s: &str, n: usize) -> (&str, &str){
(&s[..n], &s[n..])
}
fn split_string_at(s: String, n: usize) -> (String, String){
let first = s[..n].to_string();
let second = s[n..].to_string();
(first, second)
}

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

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 futures-task v0.3.31
   Compiling memchr v2.7.6
   Compiling syn v2.0.108
   Compiling pin-utils v0.1.0
   Compiling slab v0.4.11
   Compiling futures-io v0.3.31
   Compiling pin-project-lite v0.2.16
   Compiling solution v0.1.0 (/tmp/d20251023-1757769-p2y9u6/solution)
warning: function `split_slice_at` is never used
 --> src/lib.rs:1:4
  |
1 | fn split_slice_at(s: &str, n: usize) -> (&str, &str){
  |    ^^^^^^^^^^^^^^
  |
  = note: `#[warn(dead_code)]` on by default

warning: function `split_string_at` is never used
 --> src/lib.rs:5:4
  |
5 | fn split_string_at(s: String, n: usize) -> (String, String){
  |    ^^^^^^^^^^^^^^^

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.35s
     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

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

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

За fn split_slice_at(s: &str, n: usize) -> (&str, &str) e логично да върнем string slices. Това също гарантира, че ако бил предаден &String като аргумент, ние му връщаме референции , което гарантира, че низа не може бъде променен и да направи върнатия от нас отговор не валиден (out of sync).

Докато за split_string_at(s: String, n: usize) -> (String, String), да върнем (String, String) е единствената ни опция, понеже s е преместено.

Не може fn split_slice_mut_at(s: &mut str, n: usize) да връща (&mut str, &mut str), защото може да имаме само една мютабъл рефенция в даден момент

fn split_slice_mut_at(s: &mut str, n: usize) -> (&str, &str){ (&s[..n], &s[n..]) } e възможнa имплементация, която работи, но тук се срещаме с правилото за или едно &mut T или много &T. Ако не използваме мютабъл референция след това, кода ще работи.

Ако искаме да можем да използваме мютабъл референцията след това(което е много вероятно) това решение би било, много по-добро.

fn split_slice_mut_at(s: &mut str, n: usize) -> (String, String) { let first = s[..n].to_string(); let second = s[n..].to_string(); (first, second) }.

Ако трябва да сме много честни, това решение също има проблеми, защото да речем използваме мютабъл референцията и махнем първия байт, резултата от извиканата фунция вече няма да валиден (out of sync). Какво имам предвид:

let mut s = "Hello world".to_string(); let s_mut = &mut s; // s_mut е &mut String let res = split_slice_mut_at(s_mut, 5);

s_mut.remove(0); // "ello world" // res -> ("Hello", " world")