結果
問題 | No.637 X: Yet Another FizzBuzz Problem |
ユーザー |
![]() |
提出日時 | 2018-01-26 22:25:01 |
言語 | Rust (1.83.0 + proconio) |
結果 |
AC
|
実行時間 | 1 ms / 1,000 ms |
コード長 | 3,388 bytes |
コンパイル時間 | 12,790 ms |
コンパイル使用メモリ | 378,200 KB |
実行使用メモリ | 5,376 KB |
最終ジャッジ日時 | 2024-06-28 18:47:50 |
合計ジャッジ時間 | 11,500 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 30 |
コンパイルメッセージ
warning: use of deprecated method `core::str::<impl str>::trim_right`: superseded by `trim_end` --> src/main.rs:38:9 | 38 | buf.trim_right().parse::<T>().ok().unwrap() | ^^^^^^^^^^ | = note: `#[warn(deprecated)]` on by default help: replace the use of the deprecated method | 38 | buf.trim_end().parse::<T>().ok().unwrap() | ~~~~~~~~ warning: use of deprecated method `core::str::<impl str>::trim_right`: superseded by `trim_end` --> src/main.rs:54:22 | 54 | let mut it = buf.trim_right().split_whitespace(); | ^^^^^^^^^^ | help: replace the use of the deprecated method | 54 | let mut it = buf.trim_end().split_whitespace(); | ~~~~~~~~ warning: use of deprecated method `core::str::<impl str>::trim_right`: superseded by `trim_end` --> src/main.rs:73:22 | 73 | let mut it = buf.trim_right().split_whitespace(); | ^^^^^^^^^^ | help: replace the use of the deprecated method | 73 | let mut it = buf.trim_end().split_whitespace(); | ~~~~~~~~ warning: use of deprecated method `core::str::<impl str>::trim_right`: superseded by `trim_end` --> src/main.rs:93:9 | 93 | buf.trim_right().split_whitespace().map(|t| t.parse::<T>().ok().unwrap()).collect() | ^^^^^^^^^^ | help: replace the use of the deprecated method | 93 | buf.trim_end().split_whitespace().map(|t| t.parse::<T>().ok().unwrap()).collect() | ~~~~~~~~ warning: use of deprecated method `core::str::<impl str>::trim_right`: superseded by `trim_end` --> src/main.rs:109:9 | 109 | buf.trim_right().chars().collect() | ^^^^^^^^^^ | help: replace the use of the deprecated method | 109 | buf.trim_end().chars().collect() | ~~~~~~~~
ソースコード
#![allow(unused_imports, unused_macros, unknown_lints)]use std::collections::*;use std::cmp::Ordering::*;macro_rules! dump {($($e:expr), +) => {print!(concat!($(stringify!($e), " = {:?}\n"), +), $($e), +)}}macro_rules! max {($e0:expr, $($e:expr), +) => {{let mut r = $e0; $(r = std::cmp::max(r, $e);)+ r}}}macro_rules! min {($e0:expr, $($e:expr), +) => {{let mut r = $e0; $(r = std::cmp::min(r, $e);)+ r}}}fn main() {let xs = get::vec::<usize>();let fb = |x| {if x%3==0 && x%5== 0 {8} else if x%3!=0 && x%5 != 0 {format!("{}",x).len()} else {4}};let ans = xs.into_iter().map(|x|fb(x)).sum::<usize>();println!("{}", ans)}#[allow(dead_code)]mod get {use std::io::*;use std::str::*;use std::process::*;pub fn val<T: FromStr>() -> T {let mut buf = String::new();let s = stdin();s.lock().read_line(&mut buf).ok();if buf.is_empty() {println!("No input"); exit(0)}buf.trim_right().parse::<T>().ok().unwrap()}pub fn vals<T: FromStr>(n: usize) -> Vec<T> {let mut vec: Vec<T> = vec![];for _ in 0 .. n {vec.push(val());}vec}pub fn tuple<T1: FromStr, T2: FromStr>() -> (T1, T2) {let mut buf = String::new();let s = stdin();s.lock().read_line(&mut buf).ok();if buf.is_empty() {println!("No input"); exit(0)}let mut it = buf.trim_right().split_whitespace();let x = it.next().unwrap().parse::<T1>().ok().unwrap();let y = it.next().unwrap().parse::<T2>().ok().unwrap();(x, y)}pub fn tuples<T1: FromStr, T2: FromStr>(n: usize) -> Vec<(T1, T2)> {let mut vec: Vec<(T1, T2)> = vec![];for _ in 0 .. n {vec.push(tuple());}vec}pub fn tuple3<T1: FromStr, T2: FromStr, T3: FromStr>() -> (T1, T2, T3) {let mut buf = String::new();let s = stdin();s.lock().read_line(&mut buf).ok();if buf.is_empty() {println!("No input"); exit(0)}let mut it = buf.trim_right().split_whitespace();let x = it.next().unwrap().parse::<T1>().ok().unwrap();let y = it.next().unwrap().parse::<T2>().ok().unwrap();let z = it.next().unwrap().parse::<T3>().ok().unwrap();(x, y, z)}pub fn tuple3s<T1: FromStr, T2: FromStr, T3: FromStr>(n: usize) -> Vec<(T1, T2, T3)> {let mut vec: Vec<(T1, T2, T3)> = vec![];for _ in 0 .. n {vec.push(tuple3());}vec}pub fn vec<T: FromStr>() -> Vec<T> {let mut buf = String::new();let s = stdin();s.lock().read_line(&mut buf).ok();if buf.is_empty() {println!("No input"); exit(0)}buf.trim_right().split_whitespace().map(|t| t.parse::<T>().ok().unwrap()).collect()}pub fn mat<T: FromStr>(h: usize) -> Vec<Vec<T>> {let mut mat = vec![];for _ in 0 .. h {mat.push(vec());}mat}pub fn chars() -> Vec<char> {let mut buf = String::new();let s = stdin();s.lock().read_line(&mut buf).ok();if buf.is_empty() {println!("No input"); exit(0)}buf.trim_right().chars().collect()}}#[allow(dead_code)]mod put {use std::string::*;pub fn vec<T: ToString>(vec: &Vec<T>, sep: &str) {let out = vec.iter().map(|e| e.to_string()).collect::<Vec<_>>().as_slice().join(sep);println!("{}", out);}pub fn mat<T: ToString>(mat: &Vec<Vec<T>>, sep: &str) {for v in mat {vec(v, sep);}}}