結果
| 問題 | No.1631 Sorting Integers (Multiple of K) Easy |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2021-07-30 21:12:34 |
| 言語 | C (gcc 13.3.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 789 bytes |
| 記録 | |
| コンパイル時間 | 278 ms |
| コンパイル使用メモリ | 30,080 KB |
| 実行使用メモリ | 7,040 KB |
| 最終ジャッジ日時 | 2024-09-15 22:18:03 |
| 合計ジャッジ時間 | 4,925 ms |
|
ジャッジサーバーID (参考情報) |
judge6 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 4 |
| other | AC * 10 TLE * 1 -- * 17 |
コンパイルメッセージ
main.c: In function 'next_integer':
main.c:5:16: warning: type defaults to 'int' in declaration of 'c' [-Wimplicit-int]
5 | static c[10] = {};
| ^
ソースコード
#include <stdio.h>
long long next_integer(int N, long long X)
{
static c[10] = {};
int i = X % 10, j = X / 10 % 10;
c[i]++;
while (i <= j) {
X /= 10;
c[j]++;
i = j;
j = X / 10 % 10;
}
if (j == 0) return 0;
X /= 100;
c[j]++;
for (i = j + 1; c[i] == 0; i++);
X = X * 10 + i;
c[i]--;
for (i = 1; i <= 9; i++) {
for (j = 1; j <= c[i]; j++) X = X * 10 + i;
c[i] = 0;
}
return X;
}
int main()
{
int i, j, N, K, c[10], ans = 0;
long long X;
scanf("%d %d", &N, &K);
for (i = 1, c[0] = 0; i <= 9; i++) scanf("%d", &(c[i]));
for (i = 1, X = 0; i <= 9; i++) {
for (j = 1; j <= c[i]; j++) X = X * 10 + i;
c[i] = 0;
}
do {
fflush(stdout);
if (X % K == 0) ans++;
X = next_integer(N, X);
} while (X > 0);
printf("%d\n", ans);
fflush(stdout);
return 0;
}