UVa 1649 Binomial coefficients 数学
题意:
\(C(n, k) = m(2 \leq m \leq 10^{15})\),给出\(m\)求所有可能的\(n\)和\(k\)。
分析:
设\(minK = min(k, n - k)\),容易看出\(minK\)的值绝对不会太大。
因为\(n \geq 2minK\),经过简单的计算可以知道\(minK\)不超过\(26\)。
所以,可以枚举\(minK\),二分\(n\)来求解,二分的范围是\([minK,m]\)。
二分的过程中需要比较\(C(n,k)\)和\(m\)的大小,因为\(C(n,k)\)可能会太大超过\(long \, long\)的范围,不能直接计算。
所以可以做除法来比较,\(C(n,k)=\prod\limits _{i=1}^k \frac{n-i+1}{i}\)。
用\(m\)逐个去除以\(\frac{n-i+1}{k}\),如果过程中变为了\(0\),说明\(C(n,k)>m\)。
否则\(C(n,k)\)在\(long \, long\)的范围,可以直接计算去比较。
- 还想到一种(没卵用)优化:
因为\(C(m,1)\)和\(C(m,m-1)\)是显然的一组解,直接加到答案里就好了。
可以从\(minK=2\)开始枚举,\(C(n,2)=\frac{n(n-1)}{2}=m\)。
所以如果有解的话,\(n\)的取值大概在\(\sqrt{2m}\)附近,减少了大概一半的二分次数。
进一步\(minK=3\)的话,\(n\)的范围就更小了,从这个角度我们也可以验证解不会太多。
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <vector>
#include <utility>
#include <cmath>
using namespace std;
typedef long long LL;
typedef pair<LL, LL> PLL;
vector<PLL> ans;
int cmp(LL n, int k, LL m) {
LL C = 1;
for(int i = 1; i <= k; i++) {
if(m * i / (n - i + 1) / C == 0) return 1;
C = C * (n - i + 1) / i;
}
return C == m ? 0 : -1;
}
void output(const PLL& x) {
printf("(%lld,%lld)", x.first, x.second);
}
int main()
{
int T; scanf("%d", &T);
while(T--) {
LL m; scanf("%lld", &m);
ans.clear();
ans.push_back(make_pair(m, 1LL));
ans.push_back(make_pair(m, m - 1LL));
for(int i = 2; i <= 30; i++) {
LL L = i, R = m;
while(L <= R) {
LL mid = (L + R) / 2;
int c = cmp(mid, i, m);
if(c == 0) {
ans.push_back(make_pair(mid, i));
ans.push_back(make_pair(mid, mid - i));
break;
} else if(c == 1) R = mid - 1;
else L = mid + 1;
}
}
sort(ans.begin(), ans.end());
ans.resize(unique(ans.begin(), ans.end()) - ans.begin());
printf("%d\n", ans.size());
if(!ans.empty()) output(ans[0]);
for(int i = 1; i < ans.size(); i++) {
printf(" "); output(ans[i]);
}
printf("\n");
}
return 0;
}
UVa 1649 Binomial coefficients 数学的更多相关文章
- UVA 1649 Binomial coefficients
https://vjudge.net/problem/UVA-1649 题意: 输入m,求所有的C(n,k)=m m<=1e15 如果枚举n,那么C(n,k)先递增后递减 如果枚举k,那么C(n ...
- UVA - 1649 Binomial coefficients (组合数+二分)
题意:求使得C(n,k)=m的所有的n,k 根据杨辉三角可以看出,当k固定时,C(n,k)是相对于n递增的:当n固定且k<=n/2时,C(n,k)是相对于k递增的,因此可以枚举其中的一个,然后二 ...
- UVa 1639 - Candy(数学期望 + 精度处理)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 12898 - And Or 数学
题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem ...
- UVA 10668 - Expanding Rods(数学+二分)
UVA 10668 - Expanding Rods 题目链接 题意:给定一个铁棒,如图中加热会变成一段圆弧,长度为L′=(1+nc)l,问这时和原来位置的高度之差 思路:画一下图能够非常easy推出 ...
- UVa 1639 Candy (数学期望+组合数学+高精度存储)
题意:有两个盒子各有n个糖,每次随机选一个(概率分别为p,1-p),然后吃掉,直到有一次,你打开盒子发现,没糖了! 输入n,p,求另一个盒子里糖的个数的数学期望. 析:先不说这个题多坑,首先要用lon ...
- UVa 10288 - Coupons(数学期望 + 递推)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- 51nod1245 Binomial Coefficients Revenge
题目来源: HackerRank 基准时间限制:2 秒 空间限制:131072 KB 分值: 640 C(M,N) = M! / N! / (M - N)! (组合数).给出M和质数p,求C(M,0 ...
- Uva - 12230 Crossing Rivers (数学期望)
你住在村庄A,每天需要过很多条河到另一个村庄B上班,B在A的右边,所有的河都在A,B之间,幸运的是每条船上都有自由移动的自动船, 因此只要到达河左岸然后等船过来,在右岸下船,上船之后船的速度不变.现在 ...
随机推荐
- eclipse 中安装spring tool suite 插件100%成功率
自己曾在学习spring时,在eclipse EE中安装springsourceTool Suite插件浪费了很多时间,不管是离线,在线还是在eclipse marketplace中安装,尝试了许多方 ...
- java cpu使用率高异常排查
1.top命令对cpu进行排序shift+p 2.pwdx pid查找业务进程路径 3.top -Hp pid查看相关负载线程pid 4.printf “0x%x\n” 线程pid // 将线 ...
- oracle 的启动与连接
1. Oracle的启动 oracle的服务如下图所示: 启动oracle有两个重要的服务(如上图标识处): l OracleOraDb11g_home1TNSListener:监听服务,主要用于客户 ...
- IOS 进程描述
● 什么是进程 ● 进程是指在系统中正在运行的一个应用程序 ● 每个进程之间是独立的,每个进程均运行在其专用且受保护的内存空间内 ● 通过“活动监视器”可以查看Mac系统中所开启的进程
- UVA 215 Spreadsheet Calculator (模拟)
模拟题.每个单元格有表达式就dfs,如果有环那么就不能解析,可能会重复访问到不能解析的单元格,丢set里或者数组判下重复. 这种题首先框架要对,变量名不要取的太乱,细节比较多,知道的库函数越多越容易写 ...
- 自建ssr(谷歌云免费试用一年)
近期我一个朋友的VPN到期了,他也不想再去续费,同时发现谷歌云第一年申请时是免费的,所以他就自己搭建了一个自己专属的VPN 以下是他的搭建教程: 本教程难点在于申请免费试用资格 谷歌云+ssr搭建免 ...
- Java中的异常处理从概念到实例
1.概念 采用新的异常处理机制 在以往的程序开发过程中,经常采用返回值进行处理.例如,在编写一个方法,可以返回一个状态代码,调用者根据状态代码判定出错与否.若状态代码表示一个错误,则调用这进行相应的处 ...
- API调用微信getWXACodeUnlimit()获取小程序码
微信文档地址:https://developers.weixin.qq.com/miniprogram/dev/api/open-api/qr-code/getWXACodeUnlimit.html? ...
- 使用Vue CLI 3快速创建项目
首先 vue create ant-design-vue-pro 执行命令会显示两个选项,1默认,2自定义 我么选择自定义 选择好自定义的插件回车就等待下安装成功然后进入项目文件夹 cd ant-de ...
- Sum All Odd Fibonacci Numbers-freecodecamp算法题目
Sum All Odd Fibonacci Numbers 1.要求 给一个正整数num,返回小于或等于num的斐波纳契奇数之和. 斐波纳契数列中的前几个数字是 1.1.2.3.5 和 8,随后的每一 ...