結果

問題 No.775 tatyamと素数大富豪(hard)
ユーザー pekempey
提出日時 2018-12-22 01:47:35
言語 C++11(廃止可能性あり)
(gcc 13.3.0)
結果
WA  
(最新)
AC  
(最初)
実行時間 -
コード長 1,257 bytes
コンパイル時間 651 ms
コンパイル使用メモリ 64,984 KB
実行使用メモリ 5,248 KB
最終ジャッジ日時 2024-10-14 01:32:27
合計ジャッジ時間 1,284 ms
ジャッジサーバーID
(参考情報)
judge3 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 5
other AC * 9 WA * 1
権限があれば一括ダウンロードができます

ソースコード

diff #
プレゼンテーションモードにする

#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
#include <set>
#include <cstdlib>
using namespace std;
int n, K, m;
int a[100];
int cnt[100];
string curr;
int ju(int k) {
int res = 0;
for (int i = 0; i < 10; i++) {
res += cnt[k * 10 + i];
}
return res;
}
void dfs(int d) {
if (curr.size() == m) {
cout << curr << endl;
K--;
if (K == 0) exit(0);
return;
}
if (d == -1) {
for (int i = 9; i >= 1; i--) {
dfs(i);
}
} else {
for (int i = 9; i >= 0; i--) {
int x = d * 10 + i;
if (cnt[x] > 0) {
cnt[x]--;
curr += to_string(x);
dfs(-1);
curr.pop_back();
curr.pop_back();
cnt[x]++;
} else if (i > 0 && cnt[d] > 0 && (cnt[i] > 0 || ju(i) > 0)) {
cnt[d]--;
curr += to_string(d);
dfs(i);
curr.pop_back();
cnt[d]++;
}
}
}
}
int main() {
cin >> n >> K;
for (int i = 0; i < n; i++) {
cin >> a[i];
cnt[a[i]]++;
m += to_string(a[i]).size();
}
dfs(-1);
}
הההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההההה
XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX
0