結果
| 問題 |
No.164 ちっちゃくないよ!!
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2015-11-12 18:22:20 |
| 言語 | C++11(廃止可能性あり) (gcc 13.3.0) |
| 結果 |
AC
|
| 実行時間 | 1 ms / 2,000 ms |
| コード長 | 980 bytes |
| コンパイル時間 | 536 ms |
| コンパイル使用メモリ | 34,868 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-13 14:18:49 |
| 合計ジャッジ時間 | 923 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 |
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:34:8: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
34 | scanf("%d",&n);
| ~~~~~^~~~~~~~~
main.cpp:37:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
37 | scanf("%s",v);
| ~~~~~^~~~~~~~
ソースコード
#include <cstring>
#include <algorithm>
#include <cstdio>
#include <ctype.h>
#include <limits.h>
#define REP(i,a,b) for(i=a;i<b;i++)
#define rep(i,n) REP(i,0,n)
using namespace std;
typedef long long ll;
typedef unsigned long long ull;
typedef long double ld;
/* ここからが本編 */
/* */
/* 入力開始! */
/* 入力終了! */
/* ll_pow(x,n)はx^nを返すよ! */
ll ll_pow(ll x,ll n) {
ll res = 1;
while(n > 0) {
if(n&1) res = res * x;
x = x * x;
n >>= 1;
}
return res;
}
int main(void)
{
int i,j,k;
int n;
char v[15];
ll ans = LLONG_MAX;
scanf("%d",&n);
rep(i,n) {
int max = 0;
scanf("%s",v);
for(j=0; v[j]; j++) {
int tmp;
if( isdigit(v[j]) ) {
tmp = v[j] - '0';
v[j] += 7;
}
else tmp = v[j] - 'A' + 10;
if(max < tmp) max = tmp;
}
ll tmp = 0;
int m = j;
for(j=0;j<m;j++) {
tmp += (v[j] - 'A' + 10) * ll_pow(max+1,m-1-j);
}
if(ans > tmp) ans = tmp;
}
printf("%lld\n",ans);
return 0;
}