您现在的位置是:首页 > 编程 > 

整数拆分(c++,java)

2025-07-20 06:42:44
整数拆分(c++,java) 整数拆分一个整数总可以拆分为 2 的幂的和。例如:7可以拆分成7=1+2+4,7=1+2+2+2,7=1+1+1+4,7=1+1+1+2+2,7=1+1+1+1+1+2,7=1+1+1+1+1+1+1共计 6 种不同拆分方式。再比如:4 可以拆分成:4=4,4=1+1+1+1,4=2+2,4=1+1+2。用 f(n) 表示 n 的不同拆分的种数,例如 f(7)=6。要

整数拆分(c++,java)

整数拆分

一个整数总可以拆分为 2 的幂的和。

例如:7可以拆分成

7=1+2+4,7=1+2+2+2,7=1+1+1+4,7=1+1+1+2+2,

7=1+1+1+1+1+2,7=1+1+1+1+1+1+1

共计 6 种不同拆分方式。

再比如:4 可以拆分成:4=4,4=1+1+1+1,4=2+2,4=1+1+2。

用 f(n) 表示 n 的不同拆分的种数,例如 f(7)=6。

要求编写程序,读入 n,输出 f(n)mod109。

输入格式一个整数 n。

输出格式一个整数,表示 f(n)mod109。

数据范围 1≤≤106 输入样例: 7 输出样例: 6

提交代码

算法思路 这个题本质是一个dp问题,也就是现在又无数的物品,这些物品是2的幂,然后有多少种选择的问题。

c++

代码语言:javascript代码运行次数:0运行复制
#include<iostream>
using namespace std;

ct int  = 1e6 + 10;
ct int MOD = 1e9;

int a[];
int n, f[];

int main()
{
    cin >> n; 
    f[0] = 1; // 默认0的时候也有一种
    for (int i = 1; i <= n; i *= 2)  // 枚举2的幂 
    {
        for (int j = i; j <= n; ++ j) // 
        {
            f[j] = (f[j] + f[j - i]) % MOD;
        }
    }
    cout << f[n];
    return 0;
}

java

代码语言:javascript代码运行次数:0运行复制
import java.util.*;
public class Main
{
    static int  = 1000010, n, mod=(int)1e9;
    static int [] f = new int[];
    static int [] w = new int[21]; // 一共有2^0~2^19二十种选法
    
    public static void main(String [] args)
    {
        Scanner in = new Scanner(System.in);
        int n = ();
        f[0] = 1;
        for(int i = 1; i <= 20; ++ i) w[i] = (int)Math.pow(2, i - 1);
        for (int i = 1; i <= 20; ++ i)
        {
            for (int j = w[i]; j <= n; ++ j) f[j] = (f[j] + f[j - w[i]]) % mod;
        }
        println(f[n]);
    }
}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。 原始发表:2025-01-20,如有侵权请联系 cloudcommunity@tencent 删除算法javac++int数据

#感谢您对电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格的认可,转载请说明来源于"电脑配置推荐网 - 最新i3 i5 i7组装电脑配置单推荐报价格

本文地址:http://www.dnpztj.cn/biancheng/1144841.html

相关标签:无
上传时间: 2025-07-19 11:24:06
留言与评论(共有 11 条评论)
本站网友 配额制
13分钟前 发表
4=2+2
本站网友 web前端开发
3分钟前 发表
再比如:4 可以拆分成:4=4
本站网友 铝粉爆炸
17分钟前 发表
例如 f(7)=6
本站网友 博时基金050001
7分钟前 发表
7=1+2+2+2
本站网友 三里岛
4分钟前 发表
例如:7可以拆分成7=1+2+4
本站网友 郑月明
25分钟前 发表
7=1+2+2+2
本站网友 美罗华
13分钟前 发表
如有侵权请联系 cloudcommunity@tencent 删除前往查看算法javac++int数据
本站网友 beely唇膏怎么样
16分钟前 发表
i - 1); for (int i = 1; i <= 20; ++ i) { for (int j = w[i]; j <= n; ++ j) f[j] = (f[j] + f[j - w[i]]) % mod; } println(f[n]); } }本文参与 腾讯云自媒体同步曝光计划
本站网友 中宝投资
18分钟前 发表
例如:7可以拆分成7=1+2+4
本站网友 茅台酒网站
3分钟前 发表
java) 整数拆分一个整数总可以拆分为 2 的幂的和