#[allow(unused_macros)] macro_rules! invec { ( $t:ty ) => {{ let mut s = String::new(); match std::io::stdin().read_line(&mut s) { Ok(0) => Vec::<$t>::new(), Ok(n) => s.trim().split_whitespace().map(|s| s.parse::<$t>().unwrap()).collect::>(), Err(_) => Vec::<$t>::new(), } }} } #[allow(unused_macros)] macro_rules! input { ( $($t:ty),* ) => {{ let mut s = String::new(); std::io::stdin().read_line(&mut s); let mut splits = s.trim().split_whitespace(); ($( { splits.next().unwrap().parse::<$t>().unwrap() }, )*) }} } #[allow(unused_must_use)] #[allow(unused_variables)] fn solve() { let (l, r, n) = input!(u64, u64, u64); let lmod = l % n; let rmod = r % n; let a = (r - l) / n; for i in 0..n { if lmod <= i && i <= rmod { println!("{}", a + 1); } else { println!("{}", a); } } } fn main() { solve(); }