Description

Partychen like to do mathematical problems. One day, when he was doing on a least common multiple(LCM) problem, he suddenly thought of a very interesting question: if given a number of S, and we divided S into some numbers , then what is the largest LCM of these numbers? partychen thought this problems for a long time but with no result, so he turned to you for help! 
Since the answer can very big,you should give the answer modulo M.

Input

There are many groups of test case.On each
test case only two integers S( 0 < S <= 3000) and M( 2<=M<=10000)
as mentioned above.

Output

Output the largest LCM modulo M of given S.

Sample Input

6 23

Sample Output

6

Hint: you can divied 6 as 1+2+3 and the
LCM(1,2,3)=6 is the largest so we output 6%23=6.

题目大意是,将一个数拆成若干数的和,然后对这些若干数求最小公倍数。求最小公倍数的最大值。

首先假设对于一个数x,我已经拆成若干数了。

对于其中两个数a和b。如果这两个数有最大公约数k。

那么这两个数个最小公倍数为a*b/k。

但是如果是a和b/k,最小公倍数依旧为a*b/k。但是两数的和更小了。这样我就可以多加一个数b-b/k,可能会使最终结果更大。

所以得到的第一个结论是,我尽量保证两两数都是互素的。

接下来,我要证明,每个数都应该是p^t的形式,p为素数。

因为当a > 1 &&
b > 1时,

(a-1)(b-1) >= 1。

即ab >= a+b。

同理来两次得到abc >= ab+c
>= a+b+c

所以,如果一个数y = p^t1*q^t2*c。p和q均为素数,且(p, q) =
(p, c) = (q, c) = 1。

那么我把拆成p^t1和q^t2和c,这三个数的最小公倍数就是y。但是这三个数的和更小了,可以再加入一个数y-p^t-q^t-c,可能会使结果更大。

所以,最终结论x = 2^c1 + 3^c2 +
5^c3 + ...,底数为素数。

到这里做法就比较多了。

有一种做法是用直接用dfs暴力搜索。

枚举对于一个素数p,加上p^i。

dfs(int now, int sum, BigInteger val)

这里now表示枚举到第几个素数,sum表示当前情况的和是多少,val表示当前最小公倍数。

这样一开始传入s,到了第二层递归树,分别为0, 2, 4,
8…,

对于2下方的一层是2, 2+3, 2+9…

首先3000以内素数有430个左右。层数可能会达到430层,就算不是满枝,复杂度也很大。

既然这样,

于是考虑p[i]数组表示i拆分的最小公倍数的最大值。

那么p[i] = max(p[i-prime[k]^t] * prime[k]^t)。

就是对于i,枚举它由i-prime[k]^t加prime[k]^t构成。然后求最值,这样之前枚举过的素数得到的最值都被记忆化了。

复杂度是:s*primeNum*log(s) ->
总和s*素数个数*枚举次方数

最差情况:3000*430*log(3000)这个复杂度不是很大,所以直接用java大数,这题也能过,不过网上也有取对数来防止数据溢出的方法。

代码:

import java.math.BigInteger;
import java.util.Scanner; public class Main
{
boolean isprime[] = new boolean[3005];
int prime[] = new int[450];
int top;
BigInteger p[] = new BigInteger[3005];
boolean vis[] = new boolean[3005];
//埃氏筛法求素数
void isPrime()
{
for (int i = 0; i < 3005; ++i)
isprime[i] = true;
isprime[0] = isprime[1] = false;//初始化
for (int i = 2; i <= 3000; ++i)//筛法
{
if (isprime[i])
{
for (int j = i*i; j <= 3000; j += i)//上界太大可能会爆int
{
isprime[j] = false;
}
}
}
top = 0;
for (int i = 0; i <= 3000; ++i)
if (isprime[i])
prime[top++] = i;
} BigInteger dp(int s)
{
BigInteger ans = new BigInteger("1");
vis[0] = true;
for (int i = 1; i <= s; ++i)
vis[i] = false;
p[0] = new BigInteger("1");
for (int i = 0; i < top && prime[i] <= s; ++i)
{
for (int j = s; j >= prime[i]; --j)
{
for (int k = prime[i]; k <= j; k *= prime[i])
{
if (j-k < 0 || !vis[j-k])
continue;
if (!vis[j])
{
p[j] = p[j-k].multiply(new BigInteger(Integer.toString(k)));
vis[j] = true;
}
else
p[j] = p[j].max(p[j-k].multiply(new BigInteger(Integer.toString(k))));
}
}
}
for (int i = 1; i <= s; ++i)
if (vis[i])
ans = ans.max(p[i]);
return ans;
} public static void main(String args[])
{
Main qt = new Main();
qt.isPrime();
BigInteger ans;
int s, m;
Scanner input = new Scanner(System.in);
while (input.hasNext())
{
s = input.nextInt();
m = input.nextInt();
ans = qt.dp(s);
System.out.println(ans.mod(new BigInteger(Integer.toString(m))));
}
}
}

ACM学习历程—HDU 3092 Least common multiple(数论 && 动态规划 && 大数)的更多相关文章

  1. 背包系列练习及总结(hud 2602 && hdu 2844 Coins && hdu 2159 && poj 1170 Shopping Offers && hdu 3092 Least common multiple && poj 1015 Jury Compromise)

    作为一个oier,以及大学acm党背包是必不可少的一部分.好久没做背包类动规了.久违地练习下-.- dd__engi的背包九讲:http://love-oriented.com/pack/ 鸣谢htt ...

  2. HDU 3092 Least common multiple 01背包

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=3092 Least common multiple Time Limit: 2000/1000 MS ...

  3. ACM学习历程—HDU5407 CRB and Candies(数论)

    Problem Description CRB has N different candies. He is going to eat K candies.He wonders how many co ...

  4. ACM学习历程—HDU 5512 Pagodas(数学)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5512 学习菊苣的博客,只粘链接,不粘题目描述了. 题目大意就是给了初始的集合{a, b},然后取集合里 ...

  5. ACM学习历程—HDU 5317 RGCDQ (数论)

    Problem Description Mr. Hdu is interested in Greatest Common Divisor (GCD). He wants to find more an ...

  6. ACM学习历程—HDU 3915 Game(Nim博弈 && xor高斯消元)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3915 题目大意是给了n个堆,然后去掉一些堆,使得先手变成必败局势. 首先这是个Nim博弈,必败局势是所 ...

  7. ACM学习历程—HDU 5536 Chip Factory(xor && 字典树)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5536 题目大意是给了一个序列,求(si+sj)^sk的最大值. 首先n有1000,暴力理论上是不行的. ...

  8. ACM学习历程—HDU 5534 Partial Tree(动态规划)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5534 题目大意是给了n个结点,让后让构成一个树,假设每个节点的度为r1, r2, ...rn,求f(x ...

  9. ACM学习历程—HDU 3949 XOR(xor高斯消元)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3949 题目大意是给n个数,然后随便取几个数求xor和,求第k小的.(重复不计算) 首先想把所有xor的 ...

随机推荐

  1. 【JavaScript专题】--- 立即执行函数表达式

    一 什么是立即执行函数表达式 立即执行函数表达式,其实也可以叫初始化函数表达式,英文名:IIFE,immediately-inovked-function expression.立即执行函数表达式就是 ...

  2. 洛谷 P3629 [APIO2010]巡逻

    题目在这里 这是一个紫题,当然很难. 我们往简单的想,不建立新的道路时,从1号节点出发,把整棵树上的每条边遍历至少一次,再回到1号节点,会恰好经过每条边两次,路线总长度为$2(n-1)$,根据树的深度 ...

  3. PAT 1065. 单身狗(25)

    “单身狗”是中文对于单身人士的一种爱称.本题请你从上万人的大型派对中找出落单的客人,以便给予特殊关爱. 输入格式: 输入第一行给出一个正整数N(<=50000),是已知夫妻/伴侣的对数:随后N行 ...

  4. ob 函数讲解

    ob的基本原则:如果ob缓存打开,则echo的数据首先放在ob缓存.如果是header信息,直接放在程序缓存.当页面履行到最后,会把ob缓存的数据放到程序缓存,然后依次返回给涉猎器.下面我说说ob的基 ...

  5. Apache Shiro 使用手册(五)Shiro 配置说明(转发:http://kdboy.iteye.com/blog/1169637)

    Apache Shiro的配置主要分为四部分: 对象和属性的定义与配置 URL的过滤器配置 静态用户配置 静态角色配置 其中,由于用户.角色一般由后台进行操作的动态数据,因此Shiro配置一般仅包含前 ...

  6. 用cocos2d-html5做的消除类游戏《英雄爱消除》(1)——系统主菜单

    系统主菜单如下图所示: 首先,介绍下这个主菜单,它包含了一个动画logo以及一个按钮选项,动画logo每隔1秒钟切换一张图片,点击相应的按钮选项会切换不同的游戏场景. 下面看下这个界面的源码: /** ...

  7. PHP-内嵌式语言(转)(未看)

    PHP,一个嵌套的缩写名称,是英文超级文本预处理语言(PHP:Hypertext Preprocessor)的缩写.PHP 是一种内嵌式的语言,PHP与微软的ASP颇有几分相似,都是一种在服务器端执行 ...

  8. dojo 官方翻译 dojo/json 版本1.10

    官方地址:http://dojotoolkit.org/reference-guide/1.10/dojo/json.html#dojo-json require(["dojo/json&q ...

  9. 一个例子看懂所有nodejs的官方网络demo

    今天看群里有人用AI技术写了个五子棋,正好用的socket.io,本身我自己很久没看nodejs了,再加上Tcp/IP的知识一直很弱,我就去官网看了下net.socket 发现之前以为懂的一个官方例子 ...

  10. [Vue] 初识Vue-常用指令

    Vue Vue是一套用于构建用户界面的渐进式框架, Vue的核心库只关注视图层,不仅易于上手,还便于与第三方库或既有项目整合.Vue是一个JavaScript MVVM库, 以数据驱动和组件化的思想构 ...