結果
| 問題 | No.8101 砂嵐 |
| コンテスト | |
| ユーザー |
iiljj
|
| 提出日時 | 2023-03-31 22:17:05 |
| 言語 | C(gnu17) (gcc 15.2.0) |
| 結果 |
AC
|
| 実行時間 | 2 ms / 1,000 ms |
| コード長 | 5,996 bytes |
| 記録 | |
| コンパイル時間 | 170 ms |
| コンパイル使用メモリ | 39,376 KB |
| 最終ジャッジ日時 | 2026-02-22 10:20:25 |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 62 |
ソースコード
#include <stdio.h>
// 以下,正の整数向け
// verified with: yukicoder No.1128 Wedding Ceremony
// int tmp, var = 0; を先に宣言する
#define rd_int(var, tmp) \
for (;;) { \
tmp = getc_unlocked(stdin); \
if (tmp < '0' || tmp > '9') break; \
var = var * 10 + tmp - '0'; \
}
// char buf[9]; int ptr = 0; を先に宣言する
#define wt_int(var, buf, ptr) \
while (var) { \
buf[ptr++] = var % 10; \
var /= 10; \
} \
while (ptr--) putc_unlocked(buf[ptr] + '0', stdout);
// 以下,負の数もOKなバージョン
// verified with: yukicoder No.1132 凸凹
// int tmp, var = 0, sign = 0; を先に宣言する
#define rd_int_s(var, tmp, sign) \
for (;;) { \
tmp = getchar_unlocked(); \
if (tmp == '-') { \
sign = 1; \
break; \
} else if ('0' <= tmp && tmp <= '9') { \
var = tmp - '0'; \
break; \
} \
} \
for (;;) { \
tmp = getc_unlocked(stdin); \
if (tmp < '0' || tmp > '9') break; \
var = var * 10 + tmp - '0'; \
} \
if (sign) var = -var;
// char buf[9]; int ptr = 0, sign = 0; を先に宣言する
#define wt_int_s(var, buf, ptr, sign) \
if (var < 0) { \
sign = 1; \
var = -var; \
} \
while (var) { \
buf[ptr++] = var % 10; \
var /= 10; \
} \
if (!ptr) buf[ptr++] = 0; \
if (sign) putc_unlocked('-', stdout); \
while (ptr--) putc_unlocked(buf[ptr] + '0', stdout);
#define rd_int_s_(var, tmp, sign) \
var = sign = 0; \
rd_int_s(var, tmp, sign);
#define wt_int_s_(var, buf, ptr, sign) \
ptr = sign = 0; \
wt_int_s(var, buf, ptr, sign);
int main() {
long long n = 0;
int k, ptr = 0;
char buf[20];
rd_int(n, k);
if (n < 10) {
putc_unlocked('0', stdout);
return 0;
}
int ans = 0;
while (n >= 10) {
long long prod = 1;
while (n > 0 && prod > 0) {
prod *= (n % 10);
n /= 10;
}
ans++;
n = prod;
}
wt_int(ans, buf, ptr);
return 0;
}
iiljj