FastInput is aimed to simplify reading of known input from stdin
,
mainly in a competetive programming environment. The crate exposes
the FastInput
struct which contains methods for reading and parsing
line-based input. FastInput
does no validation of the input and
uses unsafe operations and buffering to achieve great performance.
The following example creates a new FastInput
and reads some input:
``rust
// The
nextmethod comes from the
FastParse` trait.
use fast_input::{FastInput, FastParse, Str};
let input = FastInput::new(); let firstline = input.nextline();
// Type arguments can often be omitted as rust is awesome, // specified here for clarity. let (a, b): (u32, u32) = input.next();
println!("First line was: {}, a + b = {}", first_line, a + b);
// Read the next line and parse it. let age: u32 = input.next_parsed();
// Read a line of integers and collect into a Vec
let numbers: Vec
// FastInput
has implementations of FastParse
up to quintuples.
let (a, b, c, d, e) = input.next();
let sum: i32 = 0i32 + a + b + c + d + e;
// The Str
type can be used to mix string slices with parsed data.
let (name, age): (Str, u8) = input.next();
// Str
can be dereferenced into its contained string slice.
let name: &str = *name;
// Read all remaining lines and print them for line in input.lines() { println!("{}", line); } ```