Решение на упр.10 задача 1 от Димитър Колев
Резултати
- 2 точки от тестове
- 0 бонус точки
- 2 точки общо
- 2 успешни тест(а)
- 0 неуспешни тест(а)
Код
use std::thread;
enum Predicate {
GreaterThan100,
Even,
Prime,
DivisibleBy7,
}
fn parallel_filter(data: Vec<i32>, n_threads: usize, predicate: Predicate) -> Vec<i32> {
let bs = data.len() / n_threads;
let predicate = |&&x: &&i32| match predicate {
Predicate::GreaterThan100 => x > 100,
Predicate::Even => x % 2 == 0,
Predicate::Prime => (2..x.isqrt()).all(|d| x % d != 0),
Predicate::DivisibleBy7 => x % 7 == 0,
};
thread::scope(|s| {
(0..n_threads)
.map(|bidx| {
let data = &data;
s.spawn(move || {
let bo = bs * bidx;
let end = if bidx == n_threads - 1 {
data.len()
} else {
bo + bs
};
data[bo..end]
.into_iter()
.filter(predicate)
.map(|e| *e)
.collect::<Vec<i32>>()
})
})
.flat_map(|h| h.join().unwrap())
.collect()
})
}
Лог от изпълнението
Updating crates.io index
Locking 17 packages to latest compatible versions
Compiling proc-macro2 v1.0.103
Compiling unicode-ident v1.0.22
Compiling quote v1.0.42
Compiling futures-core v0.3.31
Compiling futures-sink v0.3.31
Compiling futures-channel v0.3.31
Compiling memchr v2.7.6
Compiling syn v2.0.111
Compiling pin-project-lite v0.2.16
Compiling pin-utils v0.1.0
Compiling futures-task v0.3.31
Compiling slab v0.4.11
Compiling futures-io v0.3.31
Compiling solution v0.1.0 (/tmp/d20251218-1757769-1gpoqj9/solution)
warning: enum `Predicate` is never used
--> src/lib.rs:3:6
|
3 | enum Predicate {
| ^^^^^^^^^
|
= note: `#[warn(dead_code)]` on by default
warning: function `parallel_filter` is never used
--> src/lib.rs:10:4
|
10 | fn parallel_filter(data: Vec<i32>, n_threads: usize, predicate: Predicate) -> Vec<i32> {
| ^^^^^^^^^^^^^^^
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.52s
Running tests/solution_test.rs (target/debug/deps/solution_test-ee0783488e12dce9)
running 2 tests
test solution_test::test_basic ... ok
test solution_test::test_uneven_split ... ok
test result: ok. 2 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
