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

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

Към профила на Йоан Грозев

Резултати

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

Код

fn split_string_at(s: String, n: usize) -> (String, String) {
let s1 = (&s[..n]).to_string();
let s2 = (&s[n..]).to_string();
(s1,s2)
}
//Избирах (String, String), защота когато функцията ни е с параметър без референция, s ще се унищожи и ако върнем &str,
//ще сочи към освободена памет. За това трябва да създадем нови String-ове, които ще върнем
fn split_slice_at(s: &str, n: usize) -> (&str, &str) {
let s1 = &s[..n];
let s2 = &s[n..];
(s1,s2)
}
//Понеже аргументът на функцията е с string slice, можем да върнем string slice, към първата и втората част.
//След това, ако е нужно, човекът може да си направи копия на тези стойности върнати от функцията
fn split_slice_mut_at(s: &mut str, n: usize) -> (String, String) {
let newStr = s.to_string();
(newStr[..n].to_string(), newStr[n..].to_string())
}
//За третата функция трябваше да създам нов стринг, защото не мога да сложа споделени референции, към променлива с mut референция
//След това новия стринг го разделих на два нови стринга и ги върнах
//Дефакто не разделям оригиналния стринг, но мисля, че върши работа

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

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-utils v0.1.0
   Compiling slab v0.4.11
   Compiling pin-project-lite v0.2.16
   Compiling futures-task v0.3.31
   Compiling syn v2.0.108
   Compiling futures-io v0.3.31
   Compiling memchr v2.7.6
   Compiling solution v0.1.0 (/tmp/d20251023-1757769-zbqxv1/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:10:4
   |
10 | 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) -> (String, String) {
   |    ^^^^^^^^^^^^^^^^^^

warning: variable `newStr` should have a snake case name
  --> src/lib.rs:20:9
   |
20 |     let newStr = s.to_string();
   |         ^^^^^^ help: convert the identifier to snake case: `new_str`
   |
   = note: `#[warn(non_snake_case)]` on by default

warning: `solution` (lib) generated 4 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) -> (String, String) {
   |    ^^^^^^^^^^^^^^^^^^
   |
   = note: `#[warn(dead_code)]` on by default

warning: variable `newStr` should have a snake case name
  --> tests/../src/lib.rs:20:9
   |
20 |     let newStr = s.to_string();
   |         ^^^^^^ help: convert the identifier to snake case: `new_str`
   |
   = note: `#[warn(non_snake_case)]` on by default

warning: `solution` (test "solution_test") generated 2 warnings
    Finished `test` profile [unoptimized + debuginfo] target(s) in 10.31s
     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 версия и 0 коментара)

Йоан качи първо решение на 22.10.2025 11:27 (преди 8 дена)