题目描述 Description

邪教喜欢在各种各样空间内跳。

现在,邪教来到了一个二维平面。在这个平面内,如果邪教当前跳到了(x,y),那么他下一步可以选择跳到以下4个点:(x-1,y), (x+1,y), (x,y-1), (x,y+1)。

而每当邪教到达一个点,他需要耗费一些体力,假设到达(x,y)需要耗费的体力用C(x,y)表示。

对于C(x,y),有以下几个性质:

1、若x=0或者y=0,则C(x,y)=1。

2、若x>0且y>0,则C(x,y)=C(x,y-1)+C(x-1,y)。

3、若x<0且y<0,则C(x,y)=无穷大。

现在,邪教想知道从(0,0)出发到(N,M),最少花费多少体力(到达(0,0)点花费的体力也需要被算入)。

由于答案可能很大,只需要输出答案对10^9+7取模的结果。

输入描述 Input Description

读入两个整数N,M,表示邪教想到达的点。

输出描述 Output Description

输出仅一个整数,表示邪教需要花费的最小体力对10^9+7取模的结果。

样例输入 Sample Input

1 2

样例输出 Sample Output

6

数据范围及提示 Data Size & Hint

对于10%的数据,满足N, M<=20;

对于30%的数据,满足N, M<=100;

对于60%的数据,满足min(N,M)<=100;

对于100%的数据,满足0<=N, M<=10^12,N*M<=10^12。

数学问题 组合数 lucas定理

看到那个C的表达式就觉得和组合数有关系,于是欢快地打了个小表,发现——和组合数没多大关系

以左上角为顶点,每个位置的值以杨辉三角形式增加。根据这一性质可以想出一个贪心方法:只走直线,先贴着边走到目标点所在的行/列,然后直走过去。

于是ans=max(n,m)+ Σ C(n+m,d)  (1<=d<=min(n,m))  ← C是组合数

题解说后面那个ΣC 就等于C(n+m+1,min(n,m))

看到别的题解写了lucas定理,自己想了想觉得可以暴力推过去。N*M<=10^12,根据C(n,m)=c(n,n-m)的性质可知公式求组合数最多循环10^6次,可以接受。

确实可以推过去,然而WA了几个点,原因是这样算,乘数爆longlong了。

又加了个快速乘就过了。

下附lucas定理写法:

 /*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<vector>
#define LL long long
using namespace std;
const int mod=1e9+;
LL ksmul(LL a,LL b){
a%=mod;b%=mod;LL res=;
while(b){
if(b&){res+=a;if(res>mod)res-=mod;}
a=(a<<)%mod;
b>>=;
}
return res;
}
LL ksm(LL a,LL k){
LL res=;
while(k){
if(k&)res=ksmul(res,a);
a=ksmul(a,a);
k>>=;
}
return res;
}
LL solve(LL n,LL m){
m=max(m,n-m);
LL res=,inv=;
for(LL i=m+;i<=n;i++){
res=ksmul(res,i);
inv=ksmul(inv,i-m);
// printf("res:%lld inv:%lld\n",res,inv);
}
inv=ksm(inv,mod-)%mod;
res=ksmul(res,inv);
return res;
}
LL n,m,ans=;
int main(){
int i,j;
scanf("%lld%lld",&n,&m);
if(n<m)swap(n,m);
ans+=n%mod;
(ans+=solve(n+m+,m))%=mod;
printf("%lld\n",ans);
return ;
}

lucas还是快一点

 /*by SilverN*/
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#include<vector>
#define LL long long
using namespace std;
const int mod=1e9+;
LL ksm(LL a,LL k){
LL res=;
while(k){
if(k&)res=(res*a)%mod;
a=(a*a)%mod;
k>>=;
}
return res;
}
LL clc(LL n,LL m){
if(n<m)return ;
m=min(m,n-m);
LL res=,inv=;
for(LL i=;i<=m;i++){
res=res*(n-i+)%mod;
inv=inv*i%mod;
}
res=res*(ksm(inv,mod-))%mod;
return res;
}
LL lucas(LL a,LL b){
if(!b)return ;
return clc(a%mod,b%mod)*(lucas(a/mod,b/mod)%mod)%mod;
}
LL n,m,ans=;
int main(){
int i,j;
scanf("%lld%lld",&n,&m);
if(n<m)swap(n,m);
ans+=n%mod;
(ans+=lucas(n+m+,m))%=mod;
printf("%lld\n",ans);
return ;
}

lucas

CodeVs1515 跳的更多相关文章

  1. [CodeVs1515]跳(lucas定理+费马小定理)

    嘿嘿嘿好久没写数学题了,偶尔看到一道写一写... 题目大意:一个(n+1)*(m+1)[0<=n, m<=10^12,n*m<=10^12]的矩阵,C(0,0)=1,C(x,y)=C ...

  2. 【codevs1515】 跳

    http://codevs.cn/problem/1515/ (题目链接) 题意 给出一个棋盘,规定走到(x,y)的花费C(x,y)=C(x-1,y)+C(x,y-1),x=0或y=0时C(x,y)= ...

  3. a标签点击跳转失效--IE6、7的奇葩bug

    一般运用a标签包含img去实现点击图片跳转的功能,这是前端经常要用到的东西. 今天遇到个神奇的bug:如果在img上再包裹一层div,而且div设置了width和height,则图片区域点击时,无任何 ...

  4. nginx配置反向代理或跳转出现400问题处理记录

    午休完上班后,同事说测试站点访问接口出现400 Bad Request  Request Header Or Cookie Too Large提示,心想还好是测试服务器出现问题,影响不大,不过也赶紧上 ...

  5. 移动端访问PC站点时自动跳转至移动站点

    方法一: 百度Site APP的uaredirect.js 实现手机访问,自动跳转 <script src="http://siteapp.baidu.com/static/webap ...

  6. 【HTML】Html页面跳转的5种方式

    目录结构: // contents structure [-] html实现 javascript方式实现 结合了倒数的javascript实现(IE) 解决Firefox不支持innerText的问 ...

  7. ABAP实现屏幕自己刷新和跳转功能

    ABAP开发工程中,有时候需要让跳转出的屏幕自动实现跳转和刷新的功能,该功能的实现需要在屏幕PBO 里面调用相应的事件执行. 关键代码为: SET TITLEBAR ' 屏幕自动程序'. IF g_c ...

  8. iOS - 模态Model视图跳转和Push视图跳转的混合需求实现原理

    在研发中总会遇到一些莫名的需求,本着存在即合理的态度跟大家分享一下"模态Model视图跳转和Push视图跳转的需求实现",本文仅仅传授研发技术不传授产品以及UE的思想,请大家合理对 ...

  9. iOS 10 跳转系统设置

    苦心人天不负, 为了项目终于把 iOS 10 跳转系统设置的方法给搞定了, 很欣慰. http://www.cnblogs.com/lurenq/p/6189580.html iOS 10 跳转系统设 ...

随机推荐

  1. static作用域

    当一个函数完成时,它的所有变量通常都会被删除.然而,有时候您希望某个局部变量不要被删除. 要做到这一点,请在您第一次声明变量时使用 static 关键字: <?php function myTe ...

  2. auto用法

    在C++11中,如果编译器在定义一个变量的时候可以推断出变量的类型,不用写变量的类型,你只需写auto即可. 第一种用法:自动推到内置类型 int x = 100; //C++ 11 auto x = ...

  3. [转]渗透测试tips...零碎的小知识

    1.拿到一个待检测的站,你觉得应该先做什么?收集信息whois.网站源IP.旁站.C段网站.服务器系统版本.容器版本.程序版本.数据库类型.二级域名.防火墙.维护者信息另说… 2.mysql的网站注入 ...

  4. 11 Django组件-分页器

    Django的分页器(paginator) view from django.shortcuts import render,HttpResponse # Create your views here ...

  5. 编译器错误消息: CS1617: 选项“6”对 /langversion 无效

    编译错误 说明: 在编译向该请求提供服务所需资源的过程中出现错误.请检查下列特定错误详细信息并适当地修改源代码. 编译器错误消息: CS1617: 选项“6”对 /langversion 无效:必须是 ...

  6. 剑指Offer - 九度1508 - 把字符串转换成整数

    剑指Offer - 九度1508 - 把字符串转换成整数2014-02-06 23:46 题目描述: 将一个字符串转换成一个整数,要求不能使用字符串转换整数的库函数. 输入: 输入可能包含多个测试样例 ...

  7. python学习笔记二:流程控制

    一.if else: #!/usr/bin/python x = int(raw_input('please input:')) if x >= 90: if x >= 95: print ...

  8. js valueOf和toString方法

    JavaScript原生提供一个Object对象,所有其他对象都继承自这个对象,Object对象有valueOf和valueOf方法,所以所有JS数据类型都继承了这两种方法.   valueOf:返回 ...

  9. mysql错误:Column ‘id’ in field list is ambiguous的解决方法

    [Err] 1052 - Column 'modify_time' in where clause is ambiguous 出错的语句: SELECT AVG(T.se)%60FROM( SELEC ...

  10. python 学习分享-实战篇类 Fabric 主机管理程序开发

    # 类 Fabric 主机管理程序开发: # 1. 运行程序列出主机组或者主机列表 # 2. 选择指定主机或主机组 # 3. 选择让主机或者主机组执行命令或者向其传输文件(上传/下载) # 4. 充分 ...