题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3157

   https://www.lydsy.com/JudgeOnline/problem.php?id=3516

题解:http://blog.miskcoo.com/2014/06/bzoj-3157

没管 O(m) 的方法……

UPD(2019.2.20):这样构造的思想大概是想要用 \( f(j) \) (j<=i) 来表示出 \( f(i) \) 。

  考虑 \( f(m)=\sum\limits_{i=1}^{n}i^m*m^i \) ,那么要令 \( f(i) = \sum\limits_{k=1}^{n} k^i*i^k \) 还是 \( f(i) = \sum\limits_{k=1}^{n} k^i*m^k \) 还是 \( f(i) = \sum\limits_{k=1}^{n} k^m*i^k \) 呢?

  想构造出那个递推关系,一种方法是乘上一个 ( * - 1 ) ,然后用二项式定理拆开,再把一些项合并成 \( f(j) \) 。

  如果是这种方法的话, \( k^i \) 很好,因为在二项式的式子里,指数会变成一些较小的指数;而 \( i^k \) 则没有什么优势,所以令 \( f(i) = \sum\limits_{k=1}^{n}k^i*m^k \)

  现在想从 \( k^i \) 入手,弄出一个 \( (k-1)^i \) 或者 \( (k+1)^i \);一种方法是让后面那个 \( m^k \) 的指数变化1,也就是变成 \( m^{k+1} \) 或者 \( m^{k-1} \) ,这样改变一下枚举 k 的范围,就出现了 \( (k-1)^i \) 或者 \( (k+1)^i \) 了。

  让 \( m^k \) 指数变化就是给 \( f(i) \) 乘上一个 m 。再要有一个作对比的 \( \sum\limits_k \) ,才能实现让乘了 m 的那部分的 \( \sum\limits_k \) 改变。所以乘上 ( m-1 ) 或者 ( m+1 ) 。然后就可以考虑推式子了。

注意特判 m==1 的时候。因为那个式子不支持 m==1 。

UPD(2019.3.22):关于扰动法:https://www.cnblogs.com/meowww/p/6410869.html

  大概就是把 \( \sum\limits_{i=1}^{n} \) 的式子写成 \( \sum\limits_{i=1}^{n+1} \) 的样子,放在等号两边。

  然后一边把 i=n+1 的项拿出来,另一边把 i=1 的项拿出来。则另一边可以写成 \( \sum\limits_{i=1}^{n}(i+1)... \) ,就可以用二项式定理了。

  对于这道题,生搬硬套一下,式子就可以这样推:

  令 \( S_t=\sum\limits_{i=1}^{n}i^t * m^i \) ,则有

  \( S_t + (n+1)^t m^{n+1} = m + \sum\limits_{i=2}^{n+1}i^t * m^i \)

            \( = m + \sum\limits_{i=1}^{n}(i+1)^t * m^{i+1} \)

            \( = m + m \sum\limits_{i=1}^{n}\sum\limits_{j=0}^{t}\binom{t}{j}i^j * m^i \)

            \( = m + m \sum\limits_{j=0}^{t}\binom{t}{j}S_j \)

            \( = m + m*S_t + m \sum\limits_{j=0}^{t-1}\binom{t}{j}S_j \)

  所以 \( (m-1)S_t = (n+1)^t m^{n+1} - m - m \sum\limits_{j=0}^{t-1}\binom{t}{j}S_j \)

  实测和之前那个式子输出结果一样。

#include<cstdio>
#include<cstring>
#include<algorithm>
#define ll long long
using namespace std;
const int N=,mod=1e9+;
int n,m,s[N],c[N][N];
void upd(int &x){x>=mod?x-=mod:;}
int pw(int x,int k)
{int ret=;while(k){if(k&)ret=(ll)ret*x%mod;x=(ll)x*x%mod;k>>=;}return ret;}
void init()
{
for(int i=;i<=m;i++)c[i][]=;
for(int i=;i<=m;i++)
for(int j=;j<=i;j++)
c[i][j]=c[i-][j]+c[i-][j-],upd(c[i][j]);
}
int main()
{
scanf("%d%d",&n,&m);init();
if(m==){printf("%lld\n",((ll)(+n)*n>>1ll)%mod);return ;}
s[]=(ll)m*(-pw(m,n))%mod*pw(-m,mod-)%mod+mod,upd(s[]);
for(int i=,ml=(ll)n*pw(m,n+)%mod;i<=m;i++,ml=(ll)ml*n%mod)
{
int pls=;
for(int j=,fx=(i&?-:);j<i;j++,fx=-fx)
pls=(pls+(ll)c[i][j]*s[j]*fx)%mod+mod,upd(pls);
s[i]=(ll)(ml+pls)*pw(m-,mod-)%mod;
}
printf("%d\n",s[m]);
return ;
}

bzoj 3157 && bzoj 3516 国王奇遇记——推式子的更多相关文章

  1. bzoj 3157 & bzoj 3516 国王奇遇记 —— 推式子

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3157 https://www.lydsy.com/JudgeOnline/problem.p ...

  2. BZOJ 3516 国王奇遇记加强版(乱推)

    题意 求\(\sum_{k=1}^{n}k^mm^k (n\leq1e9,m\leq1e3)\) 思路 在<>中有一个方法用来求和,称为摄动法. 我们考虑用摄动法来求这个和式,看能不能得到 ...

  3. 3157: 国王奇遇记 & 3516: 国王奇遇记加强版 - BZOJ

    果然我数学不行啊,题解君: http://www.cnblogs.com/zhuohan123/p/3726933.html const h=; var fac,facinv,powm,s:..]of ...

  4. BZOJ3157: 国王奇遇记 & 3516: 国王奇遇记加强版

    令\[S_i=\sum_{k=1}^n k^i m^k\]我们有\[\begin{eqnarray*}(m-1)S_i & = & mS_i - S_i \\& = & ...

  5. bzoj3157 3516 国王奇遇记

    Description Input 共一行包括两个正整数N和M. Output 共一行为所求表达式的值对10^9+7取模的值. 特判m=1 m≠1时: 设S[u]=sigma(i^u*m^i) m*S ...

  6. 【BZOJ】【3157】&【BZOJ】【3516】国王奇遇记

    数论 题解:http://www.cnblogs.com/zhuohan123/p/3726933.html copy一下推导过程: 令$$S_i=\sum_{k=1}^{n}k^im^k$$ 我们有 ...

  7. 【BZOJ3157/3516】国王奇遇记(数论)

    [BZOJ3157/3516]国王奇遇记(数论) 题面 BZOJ3157 BZOJ3516 题解 先考虑怎么做\(m\le 100\)的情况. 令\(f(n,k)=\displaystyle \sum ...

  8. bzoj3157国王奇遇记(秦九韶算法+矩乘)&&bzoj233AC达成

    bz第233题,用一种233333333的做法过掉了(为啥我YY出一个算法来就是全网最慢的啊...) 题意:求sigma{(i^m)*(m^i),1<=i<=n},n<=10^9,m ...

  9. bzoj3157: 国王奇遇记

    emmm...... 直接看题解好了: BZOJ-3157. 国王奇遇记 – Miskcoo's Space O(m)不懂扔掉 总之,给我们另一个处理复杂求和的方法: 找到函数之间的递推公式! 这里用 ...

随机推荐

  1. 捕获enter键盘事件绑定到登录按钮

    /** *捕获enter键盘事件绑定到登录按钮 */ function keyLogin(event) { if (event.keyCode == 13) { document.getElement ...

  2. ansible入门五

    一.Ansible条件测试 在ansible中还可以进行条件测试.如果需要根据变量.facts或此前任务的执行结果来做为某task执行与否的前提时要用到条件测试. 1. when语句 在task后添加 ...

  3. 005-对象——对象的 final const

    <?php /** * */ /*class shouji { public $pinpai; final function chongdian() { //final 最终的 return $ ...

  4. HDU 3473 Minimum Sum 划分树,数据结构 难度:1

    http://acm.hdu.edu.cn/showproblem.php?pid=3473 划分树模板题目,需要注意的是划分树的k是由1开始的 划分树: 参考:http://blog.csdn.ne ...

  5. centos静默安装oracle12c

    配置系统和安装所需软件包 关闭selinux 临时关闭(不用重启) [root@SVR-3-125 ~]# setenforce 0 修改配置文件(需要重启):  将SELINUX=enforcing ...

  6. kvm虚拟主机安装速度很慢

    在c6220 II上部署虚拟化遇到的问题: 1.部署完kvm后,安装虚拟主机的过程非常缓慢,但是最终能成功 原因:宿主机BIOS的virtualization technology设置为Disable ...

  7. Unity 3D插入MySql中文无法显示问题

    使用Unity3D向mySql中插入数据,然后进入mySql查看数据库,吓我一跳中文全部乱码. 随后各种查阅资料,网站上给出解释,MySql应该使用utf8编码,查看我的mySql默认是使用utf8编 ...

  8. MoreEffectiveC++Item35(效率)(条款16-24)

    条款16 谨记80-20法则 条款17 考虑使用 lazy evaluation(缓释评估) 条款18 分期摊还预期的计算成本 条款19 了解临时对象的来源 条款20 协助完成"返回值的优化 ...

  9. 使用nrm管理npm仓库

    使用nrm管理npm仓库 用npm装包的时候,经常碰到太慢或者npm官网被墙的情况,有时候凑合一下就改一下 "~/.npmrc" 文件,但是经常改来改去也挺麻烦的,于是找到了可以使 ...

  10. EasyAACEncoder海思/ARM平台优化G711、G726转AAC的CPU占用高问题

    本文转自EasyDarwin开源团队成员Kim的博客:http://blog.csdn.net/jinlong0603/article/details/75645378 引言 目前EasyDarwin ...