結果
| 問題 |
No.164 ちっちゃくないよ!!
|
| コンテスト | |
| ユーザー |
agatan
|
| 提出日時 | 2015-04-26 11:52:01 |
| 言語 | D (dmd 2.109.1) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 2,000 ms |
| コード長 | 706 bytes |
| コンパイル時間 | 663 ms |
| コンパイル使用メモリ | 104,968 KB |
| 実行使用メモリ | 6,944 KB |
| 最終ジャッジ日時 | 2024-06-12 02:36:52 |
| 合計ジャッジ時間 | 1,151 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 |
ソースコード
import std.array, std.stdio, std.string, std.algorithm, std.conv;
void main()
{
int N = readln.strip.to!int;
ulong min = ulong.max;
foreach (i; 0..N) {
string s = readln.strip;
ulong ret = minNum(s);
if (ret < min) min = ret;
}
writeln(min);
}
string base36 = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ";
ulong minNum(string n)
{
char max = n.minPos!"cast(int)a > cast(int)b".front.to!char;
int base;
if ('0' <= max && max <= '9') {
base = (max - '0').to!int + 1;
} else {
base = 10 - 'A' + max + 1;
}
ulong ret = 0;
foreach (i, c; n.dup.reverse) {
ret += base36.indexOf(c) * base ^^ i;
}
return ret;
}
agatan