题目链接: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");
}
}

京公网安备 11010502036488号