use std::cmp; use std::io::{self, Read}; #[derive(Debug)] struct Input { k: i32, n: i32, f: i32, a: Vec, } fn next_token(cin_lock: &mut io::StdinLock) -> String { cin_lock .by_ref() .bytes() .map(|c| c.unwrap() as char) .skip_while(|c| c.is_whitespace()) .take_while(|c| !c.is_whitespace()) .collect::() } fn read_input(cin_lock: &mut io::StdinLock) -> Input { let k = next_token(cin_lock).parse().unwrap(); let n = next_token(cin_lock).parse().unwrap(); let f = next_token(cin_lock).parse().unwrap(); let a = (0..f) .map(|_| next_token(cin_lock).parse().unwrap()) .collect(); Input { k, n, f, a } } fn solve(input: Input, _cin_lock: &mut io::StdinLock) { let age_sum = input.a.iter().sum::(); let bean_sum = input.k * input.n; let answer = cmp::max(bean_sum - age_sum, -1); println!("{}", answer); } fn main() { let cin = io::stdin(); let mut cin_lock = cin.lock(); let input = read_input(&mut cin_lock); solve(input, &mut cin_lock); }