diff options
| author | Andrew Guschin <guschin.drew@gmail.com> | 2023-03-17 00:13:09 +0400 |
|---|---|---|
| committer | Andrew Guschin <guschin.drew@gmail.com> | 2023-03-17 00:13:09 +0400 |
| commit | 10dc704069548def2922dea5c1795b1c3fce0c94 (patch) | |
| tree | 05e8186b1a206f1d9e557b475bab931581d43e63 | |
| parent | f99a9c20df6a1b634c7e7f877e103c24f3ee6d70 (diff) | |
Добавлено умножение
| -rw-r--r-- | sem2/src/main.rs | 22 | ||||
| -rw-r--r-- | sem2/src/mpn.rs | 33 |
2 files changed, 43 insertions, 12 deletions
diff --git a/sem2/src/main.rs b/sem2/src/main.rs index df11b2e..658bf51 100644 --- a/sem2/src/main.rs +++ b/sem2/src/main.rs @@ -62,22 +62,22 @@ fn main() { } }; - let mpn_sum_start = Instant::now(); - let mpn_sum = a - b; - let mpn_sum_elapsed = mpn_sum_start.elapsed(); + let mpn_mul_start = Instant::now(); + let mpn_mul = a * b; + let mpn_mul_elapsed = mpn_mul_start.elapsed(); - let rug_sum_start = Instant::now(); - let _rug_sum = a_rug - b_rug; - let rug_sum_elapsed = rug_sum_start.elapsed(); + let rug_mul_start = Instant::now(); + let _rug_mul = a_rug * b_rug; + let rug_mul_elapsed = rug_mul_start.elapsed(); - println!("Разность: {}", mpn_sum); + println!("Произведение: {}", mpn_mul); println!( - "Операция разности выполнена в mpn за {} наносекунд", - mpn_sum_elapsed.as_nanos() + "Операция произведения выполнена в mpn за {} наносекунд", + mpn_mul_elapsed.as_nanos() ); println!( - "Операция разности выполнена в rug за {} наносекунд", - rug_sum_elapsed.as_nanos() + "Операция произведения выполнена в rug за {} наносекунд", + rug_mul_elapsed.as_nanos() ); } diff --git a/sem2/src/mpn.rs b/sem2/src/mpn.rs index 24880ca..b9816a3 100644 --- a/sem2/src/mpn.rs +++ b/sem2/src/mpn.rs @@ -1,6 +1,6 @@ use std::cmp::max; use std::fmt; -use std::ops::{Add, Sub}; +use std::ops::{Add, Mul, Sub}; pub struct Number { radix: usize, @@ -143,3 +143,34 @@ impl Sub for Number { .fix_leading_zeros(); } } + +impl Mul for Number { + type Output = Self; + + fn mul(self, other: Self) -> Self::Output { + let n = self.len(); + let m = other.len(); + let mut digits = vec![0; n + m]; + + for j in 0..m { + let vj = other.digits[j]; + if vj == 0 { + digits[n + j] = 0; + } else { + let mut k = 0; + for i in 0..n { + let ui = self.digits[i]; + let t = ui * vj + digits[i + j] + k; + digits[i + j] = t % self.radix as u8; + k = t / self.radix as u8; + } + digits[n + j] = k; + } + } + return Number { + radix: self.radix, + digits, + } + .fix_leading_zeros(); + } +} |