UVA - 10375 Choose and divide[唯一分解定理]
UVA - 10375 |
Time Limit: 1000MS | Memory Limit: 65536K | |
Total Submissions: 4053 | Accepted: 1318 |
Description
- m!
C(m,n) = --------
n!(m-n)!
Given four natural numbers p, q, r, and s, compute the the result of dividing C(p,q) by C(r,s).
Input
Output
Sample Input
- 10 5 14 9
- 93 45 84 59
- 145 95 143 92
- 995 487 996 488
- 2000 1000 1999 999
- 9998 4999 9996 4998
Sample Output
- 0.12587
- 505606.46055
- 1.28223
- 0.48996
- 2.00000
- 3.99960
Source
唯一分解定理
太诡异了,uva AC
poj一直TLE,连白书的标解都WA
- //
- // main.cpp
- // poj2613
- //
- // Created by Candy on 10/20/16.
- // Copyright ? 2016 Candy. All rights reserved.
- //
- #include <iostream>
- #include <cstdio>
- #include <cstring>
- #include <algorithm>
- #include <cmath>
- using namespace std;
- const int N=1e4+;
- int p,q,r,s;
- int prime[N],cnt=,e[N],vis[N];
- void era(int n){
- int m=sqrt(n)+;
- for(int i=;i<=m;i++) if(!vis[i])
- for(int j=i*i;j<=n;j+=i) vis[j]=;
- for(int i=;i<=n;i++) if(!vis[i]) prime[++cnt]=i;
- }
- inline void mul(int x,int d){//x^d
- for(int i=;i<=cnt&&x!=;i++)
- while(x%prime[i]==){
- x/=prime[i];
- e[i]+=d;
- }
- }
- void fac(int x,int d){//printf("%d %d\n",x,d);
- for(int i=;i<=x;i++) mul(i,d);
- }
- inline int fastPow(int a,int b){
- int ans=;
- for(;b;b>>=,a*=a)
- if(b&) ans*=a;
- return ans;
- }
- int main(int argc, const char * argv[]){
- era();//cout<<"p";
- while(scanf("%d%d%d%d",&p,&q,&r,&s)!=EOF){
- memset(e,,sizeof(e));
- fac(p,);
- fac(q,-);
- fac(p-q,-);
- fac(r,-);
- fac(s,);
- fac(r-s,);
- double ans=;
- for(int i=;i<=cnt;i++){
- if(e[i]>) ans*=(double)fastPow(prime[i],e[i]);
- else if(e[i]<) ans/=(double)fastPow(prime[i],-e[i]);
- // ans*=pow(prime[i],e[i]);
- }
- printf("%.5f\n",ans);
- }
- return ;
- }
UVA - 10375 Choose and divide[唯一分解定理]的更多相关文章
- 【暑假】[数学]UVa 10375 Choose and divide
UVa 10375 Choose and divide 题目: http://acm.hust.edu.cn/vjudge/problem/viewProblem.action?id=19601 思路 ...
- uva10375 Choose and Divide(唯一分解定理)
uva10375 Choose and Divide(唯一分解定理) 题意: 已知C(m,n)=m! / (n!*(m-n!)),输入整数p,q,r,s(p>=q,r>=s,p,q,r,s ...
- UVA 10375 Choose and divide【唯一分解定理】
题意:求C(p,q)/C(r,s),4个数均小于10000,答案不大于10^8 思路:根据答案的范围猜测,不需要使用高精度.根据唯一分解定理,每一个数都可以分解成若干素数相乘.先求出10000以内的所 ...
- UVA 10375 Choose and divide(大数的表示)
紫上给得比较奇怪,其实没有必要用唯一分解定理.我觉得这道题用唯一分解只是为了表示大数. 但是分解得到的幂,累乘的时候如果顺序很奇怪也可能溢出.其实直接边乘边除就好了.因为答案保证不会溢出, 设定一个精 ...
- UVa 10375 - Choose and divide(唯一分解定理)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 10375 Choose and divide
n! 分解素因子 快速幂 ei=[N/pi^1]+ [N/pi^2]+ …… + [N/pi^n] 其中[]为取整 ei 为数 N!中pi 因子的个数: #include <iostream& ...
- Uva 10375 选择与除法 唯一分解定理
题目链接:https://vjudge.net/contest/156903#problem/E 题意:已知 求:C(p,q)/C(r,s) 其中p,q,r,s都是10^4,硬算是肯定超数据类型的. ...
- UVA.10791 Minimum Sum LCM (唯一分解定理)
UVA.10791 Minimum Sum LCM (唯一分解定理) 题意分析 也是利用唯一分解定理,但是要注意,分解的时候要循环(sqrt(num+1))次,并要对最后的num结果进行判断. 代码总 ...
- Choose and divide(唯一分解定理)
首先说一下什么是唯一分解定理 唯一分解定理:任何一个大于1的自然数N,如果N不是质数,那么N可以分解成有限个素数的乘积:例:N=(p1^a1)*(p2^a2)*(p3^a3)......其中p1< ...
随机推荐
- java函数
函数的封装没有定规,只要遵循语法,函数如何封装按照需求来做 函数四要素:函数名,输入,加工,输出(返回). 一.函数调用 1.函数名(变量列表); 没有返回值. 2.数据类型 变量名=函数名(变量列表 ...
- SSH(Struts2+Spring+Hibernate)框架搭建流程<注解的方式创建Bean>
此篇讲的是MyEclipse9工具提供的支持搭建自加包有代码也是相同:用户登录与注册的例子,表字段只有name,password. SSH,xml方式搭建文章链接地址:http://www.cnblo ...
- 对hashmap,hashset,hashtable的理解
1.首先先理一下java的集合关系,Collection和Map接口是所有集合接口的根结点,其他集合都直接或者间接的实现了他们中的一个:collection下有:list(元素可重复)和set(不可重 ...
- MySQL中CURRENT_TIMESTAMP(转)
1. MySQL 获得当前时间戳函数:current_timestamp, current_timestamp() 代码如下 mysql> select current_timestamp ...
- 关于C#消息调度(作业日志)
在Windows定时作业中,其实有多种关于作业调度形式,比如Windows Services 和 Windows Form 都可以做到,各有各的好处.现在来介绍下使用插件的形式进行定时作业. 1.用q ...
- iOS之搜索框UISearchController的使用(iOS8.0以后替代UISearchBar+display)
在iOS 8.0以上版本中, 我们可以使用UISearchController来非常方便地在UITableView中添加搜索框. 而在之前版本中, 我们还是必须使用UISearchBar + UISe ...
- iOS之UICollectionView详解
UICollectionView是一种类似于UITableView但又比UITableView功能更强大.更灵活的视图,这是源于它将UICollectionView对cell的布局交给了UIColle ...
- 设置 TabBarItem 选中时的图片及文字颜色
TabBarController 是在 ios 开发过程中使用较为频繁的一个 Controller,但是在使用过程中经常会遇到一些问题,例如本文所要解决的,如何修改 TabBar 选中时文字及图片的颜 ...
- iOS 本地推送通知
1.什么是本地推送通知 不需要联网的情况下,应用程序经由系统发出的通知 2.本地推送的使用场景 定时提醒,如玩游戏.记账.闹钟.备忘录等 3.实现本地推送通知的步骤 创建本地推送通知的对象UILoca ...
- org.hibernate.HibernateException: No Hibernate Session bound to thread, and configuration does not allow creation of non-transactional one here
org.hibernate.HibernateException: No Hibernate Session bound to thread, and configuration does not a ...