refactor number generators into separate lib crate

This commit is contained in:
jacekpoz 2024-04-08 21:37:20 +02:00
parent 059c5efa6e
commit a486679bba
Signed by: poz
SSH key fingerprint: SHA256:JyLeVWE4bF3tDnFeUpUaJsPsNlJyBldDGV/dIKSLyN8
12 changed files with 157 additions and 27 deletions

View file

@ -12,7 +12,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
name = "gen_asc" name = "gen_asc"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"rand", "libgen",
] ]
[[package]] [[package]]
@ -32,6 +32,13 @@ version = "0.2.153"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd"
[[package]]
name = "libgen"
version = "0.1.0"
dependencies = [
"rand",
]
[[package]] [[package]]
name = "ppv-lite86" name = "ppv-lite86"
version = "0.2.17" version = "0.2.17"

View file

@ -4,4 +4,4 @@ version = "0.1.0"
edition = "2021" edition = "2021"
[dependencies] [dependencies]
rand = "0.8.5" libgen = { path = "../libgen" }

View file

@ -1,6 +1,6 @@
use std::{env::args, io}; use std::{env::args, io};
use rand::Rng; use libgen::gen_asc;
fn main() -> io::Result<()> { fn main() -> io::Result<()> {
@ -11,13 +11,9 @@ fn main() -> io::Result<()> {
println!("{}", amount); println!("{}", amount);
let mut last = -1; gen_asc(amount)
.iter()
for i in 1..=amount { .for_each(|x| println!("{}", x));
let current = rand::thread_rng().gen_range((last + 1)..=(2 * amount - (amount - i)) as i64);
println!("{}", current);
last = current;
}
Ok(()) Ok(())
} }

View file

@ -12,7 +12,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
name = "gen_desc" name = "gen_desc"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"rand", "libgen",
] ]
[[package]] [[package]]
@ -32,6 +32,13 @@ version = "0.2.153"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd"
[[package]]
name = "libgen"
version = "0.1.0"
dependencies = [
"rand",
]
[[package]] [[package]]
name = "ppv-lite86" name = "ppv-lite86"
version = "0.2.17" version = "0.2.17"

View file

@ -4,4 +4,4 @@ version = "0.1.0"
edition = "2021" edition = "2021"
[dependencies] [dependencies]
rand = "0.8.5" libgen = { path = "../libgen" }

View file

@ -1,6 +1,6 @@
use std::{env::args, io}; use std::{env::args, io};
use rand::Rng; use libgen::gen_desc;
fn main() -> io::Result<()> { fn main() -> io::Result<()> {
@ -11,14 +11,9 @@ fn main() -> io::Result<()> {
println!("{}", amount); println!("{}", amount);
let mut last = rand::thread_rng().gen_range((amount)..(2 * amount)); gen_desc(amount)
println!("{}", last); .iter()
.for_each(|x| println!("{}", x));
for i in 1..amount {
let current = rand::thread_rng().gen_range((amount - i)..(last));
println!("{}", current);
last = current;
}
Ok(()) Ok(())
} }

View file

@ -12,7 +12,7 @@ checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
name = "gen_rand" name = "gen_rand"
version = "0.1.0" version = "0.1.0"
dependencies = [ dependencies = [
"rand", "libgen",
] ]
[[package]] [[package]]
@ -32,6 +32,13 @@ version = "0.2.153"
source = "registry+https://github.com/rust-lang/crates.io-index" source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd" checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd"
[[package]]
name = "libgen"
version = "0.1.0"
dependencies = [
"rand",
]
[[package]] [[package]]
name = "ppv-lite86" name = "ppv-lite86"
version = "0.2.17" version = "0.2.17"

View file

@ -4,4 +4,4 @@ version = "0.1.0"
edition = "2021" edition = "2021"
[dependencies] [dependencies]
rand = "0.8.5" libgen = { path = "../libgen" }

View file

@ -1,6 +1,6 @@
use std::{env::args, io}; use std::{env::args, io};
use rand::Rng; use libgen::gen_rand;
fn main() -> io::Result<()> { fn main() -> io::Result<()> {
@ -11,9 +11,9 @@ fn main() -> io::Result<()> {
println!("{}", amount); println!("{}", amount);
for _ in 1..=amount { gen_rand(amount)
println!("{}", rand::thread_rng().gen_range(0..(2 * amount))); .iter()
} .for_each(|x| println!("{}", x));
Ok(()) Ok(())
} }

75
lab2/zad1/libgen/Cargo.lock generated Normal file
View file

@ -0,0 +1,75 @@
# This file is automatically @generated by Cargo.
# It is not intended for manual editing.
version = 3
[[package]]
name = "cfg-if"
version = "1.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "baf1de4339761588bc0619e3cbc0120ee582ebb74b53b4efbf79117bd2da40fd"
[[package]]
name = "getrandom"
version = "0.2.14"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "94b22e06ecb0110981051723910cbf0b5f5e09a2062dd7663334ee79a9d1286c"
dependencies = [
"cfg-if",
"libc",
"wasi",
]
[[package]]
name = "libc"
version = "0.2.153"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c198f91728a82281a64e1f4f9eeb25d82cb32a5de251c6bd1b5154d63a8e7bd"
[[package]]
name = "libgen"
version = "0.1.0"
dependencies = [
"rand",
]
[[package]]
name = "ppv-lite86"
version = "0.2.17"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "5b40af805b3121feab8a3c29f04d8ad262fa8e0561883e7653e024ae4479e6de"
[[package]]
name = "rand"
version = "0.8.5"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "34af8d1a0e25924bc5b7c43c079c942339d8f0a8b57c39049bef581b46327404"
dependencies = [
"libc",
"rand_chacha",
"rand_core",
]
[[package]]
name = "rand_chacha"
version = "0.3.1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "e6c10a63a0fa32252be49d21e7709d4d4baf8d231c2dbce1eaa8141b9b127d88"
dependencies = [
"ppv-lite86",
"rand_core",
]
[[package]]
name = "rand_core"
version = "0.6.4"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "ec0be4795e2f6a28069bec0b5ff3e2ac9bafc99e6a9a7dc3547996c5c816922c"
dependencies = [
"getrandom",
]
[[package]]
name = "wasi"
version = "0.11.0+wasi-snapshot-preview1"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "9c8d87e72b64a3b4db28d11ce29237c246188f4f51057d65a7eab63b7987e423"

View file

@ -0,0 +1,7 @@
[package]
name = "libgen"
version = "0.1.0"
edition = "2021"
[dependencies]
rand = "0.8.5"

View file

@ -0,0 +1,36 @@
use rand::Rng;
pub fn gen_rand(amount: u64) -> Vec<u64> {
(1..=amount)
.map(|_| rand::thread_rng().gen_range(0..(2 * amount)))
.collect()
}
pub fn gen_desc(amount: u64) -> Vec<u64> {
let mut ret = vec![];
let mut last = rand::thread_rng().gen_range((amount)..(2 * amount));
ret.push(last);
for i in 1..amount {
let current = rand::thread_rng().gen_range((amount - i)..(last));
ret.push(current);
last = current;
}
ret
}
pub fn gen_asc(amount: u64) -> Vec<u64> {
let mut ret = vec![];
let mut last = -1;
for i in 1..=amount {
let current = rand::thread_rng().gen_range((last + 1)..=(2 * amount - (amount - i)) as i64);
ret.push(current as u64);
last = current;
}
ret
}