GYM106247B[数论 构造一个数字和因子 使得等于n个因子之和=数字]

Problem - 2 - Codeforces

构造一个数字和他的因子 使得等于n个因子之和=数字

对于一个数字x 他的所有因子一定都整除他 那么就可以表示为 x/ai

当n=1 显然选择一个数字和他本身即可

当n=2 肯定不能选择1 和他本身 那么最小的因数就是2 不可能存在两个不同的因数使得因数之和等于 n

当n>=3 如果存在这样的数字 那么等式就可以写成 x=x/a1 +x/a2 +x/a3 +...... x/an

也就是1 = 1/ai +2/ai +3/ai.......

那么x就是这群ai的最小公倍数 那么要让这个最小公倍数好构造 我们可以直接拆2

1=1/2 +1/4 +1/8.. 最后会有两个相同的数字 1/2^(n-3) 我们可以把他拆成三个数字 1/2^(n-3)*(1/2+1/3+1/6) 最后构造出来的数字就是3*2^(n-2);

代码如下:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;

int main() {
    ios::sync_with_stdio(0);
    cin.tie(0);
    cout.tie(0);
    int n;
    cin>>n;
    if(n==1){
        cout<<1<<'\n';
        cout<<1<<'\n';
    }else if(n==2)cout<<-1<<'\n';
    else {
        cout<<(3<<(n-2))<<'\n';
        cout<<"1 2";
        for(int i=0;i<n-2;i++){
            cout<<' '<<(3<<i);
        }
    }
    return 0;
}
相关推荐
广州灵眸科技有限公司8 分钟前
瑞芯微(EASY EAI)RV1126B rknn-toolkit-lite2使用方法
linux·网络·人工智能·物联网·算法
旖-旎22 分钟前
深搜(二叉树剪枝)(3)
数据结构·c++·算法·力扣·剪枝·递归
流年如夢24 分钟前
结构体:定义、使用与内存布局
c语言·开发语言·数据结构·c++·算法
『昊纸』℃1 小时前
C语言学习心得集合 篇1
c语言·算法·编程基础·学习心得·实践操作
Chase_______1 小时前
LeetCode 1456:定长子串中元音的最大数目
算法·leetcode
小O的算法实验室1 小时前
2026年IEEE IOTJ,DNA序列启发相似性驱动粒子群算法+无人机与基站部署,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
谭欣辰1 小时前
Floyd算法:动态规划解最短路径
c++·算法·图论
计算机安禾1 小时前
【Linux从入门到精通】第12篇:进程的前后台切换与信号控制
linux·运维·算法
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 84. 柱状图中最大的矩形 | C++ 两次单调栈基础扫法
c++·算法·leetcode
C雨后彩虹1 小时前
文件目录大小
java·数据结构·算法·华为·面试