Categories
Tags
algorithms APIT Arc arm assembly asynchronous base64 BitHacks Blogging box c clang-format client cmake compiler concat concurrency const_fn contravariant cos covariant cpp Customization cybersecurity DataStructure db debugging Demo deserialization discrete doc DP dtruss Dynamic Example FFI flat_map format FP fsanitize Functional functions futures Fuwari GATs gccrs generics gitignore glibc GUI hacking hashmap haskell heap interop invariant iterator join justfile kernel LaTeX leak LFU linux lto MachineLearning macOS Markdown math ML mmap nc OnceLock optimization OS panic parallels perf physics pin postgresql radare2 release reverse RPIT rust sanitizer science Science serialization server shift sin SmallProjects socket std strace String StringView strip strlen surrealdb SWAR swisstable synchronous tan toml traits triangulation UnsafeRust utf16 utf8 Video wsl x86_64 xilem zig
324 words
2 minutes
250101_0002_std_training_array_map
link
나만의 기능 만들기 (traits와 잘 섞어서 만든다.)
- my_sum
- my_product
fn my_squares(x: i32) -> i32 {
x * x
}
trait MySumExt: Sized {
fn my_sum(self) -> i32;
fn my_product(self) -> i32;
}
// impl<T: Iterator<Item = i32>> MySumExt for T
impl<T> MySumExt for T
where
T: Iterator<Item = i32>,
{
fn my_sum(self) -> i32 {
let mut total = 0;
for num in self {
total += num;
}
total
}
fn my_product(self) -> i32 {
let mut my_total = 1;
for num in self {
my_total *= num;
}
my_total
}
}
fn main() {
let my_arr = [10, 20, 30, 40];
println!("basic list : {my_arr:?}");
let my_idx_2 = my_arr[2];
println!("arr idx 2 : {my_idx_2:?}");
let my_arr_map_2 = my_arr.map(|c| c * 3);
println!("arr map :{my_arr_map_2:?}");
let squares_arr = my_arr.map(|c| c * c);
println!("arr squares :{squares_arr:?}");
let my_squares_2 = my_arr.map(my_squares);
println!("arr squares :{my_squares_2:?}");
let my_is_even = my_arr.iter().filter(|c| *c % 2 == 0);
println!("arr filter(isEven) :{my_is_even:?}");
print!("arr filter(isEven) : [");
for (idx, i) in my_is_even.enumerate() {
if idx > 0 {
print!(", ",);
}
print!("{}", i);
}
println!("]");
let my_arr_filter25: Vec<i32> = my_arr
.iter()
.filter_map(|c| if c > &25 { Some(*c) } else { None })
.collect();
println!("arr filter > 25 :{my_arr_filter25:?}");
// my_sum() custom method
let sum_arr: i32 = my_arr.iter().copied().my_sum();
println!("arr sum :{sum_arr:?}");
// std sum() method
let sum_arr02: i32 = my_arr.iter().sum();
println!("arr sum :{sum_arr02:?}");
// my_fn "my_product"
let my_product_arr = my_arr.iter().copied().my_product();
println!("arr product :{my_product_arr:?}");
// std "product"
let std_product_arr: i32 = my_arr.iter().product();
println!("arr product :{std_product_arr:?}");
//
// Fold : Reduce to single value (i32 -> u32 conversion)
let my_fold_arr: u32 = my_arr.iter().fold(0u32, |acc, x| acc + *x as u32);
println!("arr fold (i32->u32) :{my_fold_arr}");
// Reduce : Alternative without initial value (returns Option)
let my_reduce_arr: Option<u32> = my_arr.iter().map(|x| *x as u32).reduce(|acc, x| acc + x);
println!("arr reduce (i32->u32) :{my_reduce_arr:?}");
}같이 보면 좋은글
250101_0002_std_training_array_map
https://younghakim7.github.io/blog/posts/250101_0002_std_training_array_map/