1103 Integer Factorization


idea

题意为对于正整数n分解为k个p次方的形式,若无,则输出impossible;若有,则输出底数和最大的方案,还有多种方案时则输出字典序最大(数值最大)的方案。

首先预处理所有p次方不大于n的值;

再用深搜枚举选择(可多次)或不选择当前底数的方案,当当前选择的底数个数nowK大于k或当前所选数的p次方nowSum大于n时停止,当nowK==k且nowSum= =n时找到一种方案,判断是否需要更新已有方案

solution

cpp 复制代码
#include<iostream>
#include<cmath>
#include<vector>
using namespace std;

int n, k, p, sum = 0;
vector<int> fac, ans, temp;

void dfs(int index, int nowK, int nowSum, int facSum){
	if(nowK == k && nowSum == n){//找到一种符合条件的组合 
		if(facSum > sum){//底数和更大则更新 
			sum = facSum;
			ans = temp;
		}
		return; 
	}
	if(nowK > k || nowSum > n) return;//不符合限制,剪掉
	if(index > 0){//满足正整数,不需要考虑0 
		temp.push_back(index);
		dfs(index, nowK + 1, nowSum + fac[index], facSum + index);//选择加入
		temp.pop_back();//不加入则把上次选择加入时压入的index弹出 
		dfs(index - 1, nowK, nowSum, facSum);//选择不加入,考虑下一个底数 
	} 
}
int main(){
	scanf("%d%d%d", &n, &k, &p);
	for(int i = 1, t = 0; t <= n; i++){//初始化p次方小于等于n的记录表 
		fac.push_back(t);
		t = pow(i, p);
	} 
	dfs(fac.size() - 1, 0, 0, 0);//倒着找,以字典序更大的为先
	if(!sum) printf("Impossible");
	else{
		printf("%d = %d^%d", n, ans[0], p);
		for(int i = 1; i < ans.size(); i++)
			printf(" + %d^%d", ans[i], p);
	}
	return 0;
}
相关推荐
算法鑫探8 分钟前
C语言密码验证:3次机会解锁
c语言·数据结构·算法·新人首发
穿条秋裤到处跑23 分钟前
每日一道leetcode(2026.03.30):判断通过操作能否让字符串相等 II
算法·leetcode
Q741_14723 分钟前
每日一题 力扣 2840. 判断通过操作能否让字符串相等 II 力扣 2839. 判断通过操作能否让字符串相等 I 找规律 字符串 C++ 题解
c++·算法·leetcode·力扣·数组·找规律
xu_wenming28 分钟前
在 TinyML 场景下,如何将模型从 FP32 量化为 INT8?
arm开发·算法·iot
csdn_aspnet32 分钟前
C++ 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)
开发语言·c++·算法
深邃-43 分钟前
字符函数和字符串函数(1)
c语言·开发语言·数据结构·c++·算法·html5
我真不是小鱼44 分钟前
cpp刷题打卡记录24——路径总和 & 路径总和II
数据结构·c++·算法·leetcode
菜鸟小九1 小时前
JVM垃圾回收
java·jvm·算法
nianniannnn1 小时前
力扣 347. 前 K 个高频元素
c++·算法·leetcode
漫随流水1 小时前
c++编程:求阶乘和
数据结构·c++·算法