結果
| 問題 |
No.820 Power of Two
|
| コンテスト | |
| ユーザー |
kenichi
|
| 提出日時 | 2023-05-04 17:09:11 |
| 言語 | Rust (1.83.0 + proconio) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 2,800 bytes |
| コンパイル時間 | 13,708 ms |
| コンパイル使用メモリ | 383,388 KB |
| 実行使用メモリ | 6,820 KB |
| 最終ジャッジ日時 | 2024-11-22 09:13:57 |
| 合計ジャッジ時間 | 14,950 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 10 |
コンパイルメッセージ
warning: function `hex_to_binary` is never used
--> src/main.rs:8:4
|
8 | fn hex_to_binary(hex_string: &str, x: u32) -> Option<String> {
| ^^^^^^^^^^^^^
|
= note: `#[warn(dead_code)]` on by default
ソースコード
use std::io::*;
use std::str::FromStr;
//use std::num;
//use std::cmp;
//use std::collections::VecDeque;
//use std::io::{self, BufRead};
fn hex_to_binary(hex_string: &str, x: u32) -> Option<String> {
match i64::from_str_radix(hex_string, x) {
Ok(decimal) => Some(format!("{}", decimal)),
Err(_) => None,
}
}
fn main() {
let n: usize = read();
let k: usize = read();
if n < k{
print!("0");
}else{
print!("{}",2i32.pow((n - k) as u32));
}
}
pub fn my_floor(x: f64) -> f64 {
let rounded = (x * 1000.0).floor() / 1000.0;
rounded
}
pub fn upper_lower(x: char) -> char {
let result: char;
if x.is_uppercase() {
result = x.to_ascii_lowercase();
} else if x.is_lowercase() {
result = x.to_ascii_uppercase();
} else {
result = x;
}
result
}
pub fn maxf_2(x: f64, y: f64) -> f64 {
let result;
if x >= y {
result = x;
} else {
result = y;
}
result
}
pub fn max_2(x: usize, y: usize) -> usize {
let result;
if x >= y {
result = x;
} else {
result = y;
}
result
}
pub fn min_2(x: usize, y: usize) -> usize {
let result;
if x >= y {
result = y;
} else {
result = x;
}
result
}
pub fn max_3(x: isize, y: isize, z: isize) -> isize {
let result;
if x >= y && y >= z {
result = x;
} else if x >= z && z >= y {
result = x;
} else if y >= x && x >= z {
result = y;
} else if y >= z && z >= x {
result = y;
} else if z >= x && x >= y {
result = z;
} else {
result = z;
}
result
}
pub fn min_3(x: isize, y: isize, z: isize) -> isize {
let result;
if x <= y && y <= z {
result = x;
} else if x <= z && z <= y {
result = x;
} else if y <= x && x <= z {
result = y;
} else if y <= z && z <= x {
result = y;
} else if z <= x && x <= y {
result = z;
} else {
result = z;
}
result
}
pub fn read_text() -> String {
let mut word = String::new();
std::io::stdin().read_line(&mut word).ok();
let answer = word.trim().to_string();
answer
}
pub fn read<T: FromStr>() -> T {
let stdin = stdin();
let stdin = stdin.lock();
let token: String = stdin
.bytes()
.map(|c| c.expect("failed to read char") as char)
.skip_while(|c| c.is_whitespace())
.take_while(|c| !c.is_whitespace())
.collect();
token.parse().ok().expect("failed to parse token")
}
pub fn read_array() -> Vec<char> {
let array: String = read();
let chars: Vec<char> = array.trim().chars().collect::<Vec<char>>();
chars
}
pub fn get_data() -> Vec<u64> {
let mut s: String = String::new();
std::io::stdin().read_line(&mut s).ok();
let vec: Vec<u64> = s
.trim()
.split_whitespace()
.map(|e| e.parse().ok().unwrap())
.collect();
vec
}
pub fn get_chars() -> Vec<char> {
let mut s: String = String::new();
std::io::stdin().read_line(&mut s).ok();
let vec: Vec<char> = s.trim().chars().collect::<Vec<char>>();
vec
}
kenichi