题目链接:https://vjudge.net/contest/381753#problem/E
解题报告:
一开始的错误想法:一开始q跟9的幂次比较并不能说明答案是几位数,比如999就是3位数可以达到的最大值,q如果大于它只会是4位及以上。然后跟据判断答案是几位数来通过dfs凑。
啊,这...
比如75,就是两位数无法通过乘积构成,然而355就能乘起来等于75.
因此显然是个错误想法。
dfs部分没有问题,但可以更简单。
正确思路:
从9到2枚举(不需要到1,因为1完全没有作用还使得答案变大),不断把q分解,(从大到小枚举是为了使得答案的位数尽量少),然后基于统计的思想,把小的放在前面,大的放后面。
代码:
#include <iostream> #include <stdio.h> #include <string.h> #include <stack> #include <queue> #include <map> #include <set> #include <vector> #include <math.h> #include <bitset> #include <algorithm> #include <climits> using namespace std; typedef long long ll; int cnt[10]; int a[15]; int main() { int T; scanf("%d",&T); while(T--) { int q; scanf("%d",&q); if(q == 0) {printf("10\n"); continue;} //特判,又因为答案要求为正,因此是10 if(q == 1) {printf("1\n"); continue;} //特判 memset(cnt, 0, sizeof(cnt)); //cnt[i]统计i有多少个 for(int i = 9; i >= 2; i--) { while(q % i == 0) { q /= i; cnt[i]++; } } if(q != 1) {printf("-1\n"); continue;} for(int i = 2; i <= 9; i++) { while(cnt[i]) {printf("%d",i); cnt[i]--;} } printf("\n"); } }