codechef EBAIT Election Bait【欧几里得算法】
题目分析:
欧几里得算法来处理一类分数问题,分数问题的形式如下
$\frac{a}{b} < \frac{p}{q} < \frac{c}{d}$
当a=0时,答案等于$\frac{1}{\lfloor \frac{d}{c} \rfloor + 1}$
当a>=b时,可以考虑前后同减去一个数化为真分数,再加上
当c>d时,因为不满足一二,所以可以直接令答案等于$\frac{1}{1}$
否则分子分母取倒,再倒回来
代码:
#include<bits/stdc++.h>
using namespace std; const int maxn = ; int n,C1,C2;
int a[maxn]; pair<int,int> p1,p2; void comp(pair<int,int> alpha,pair<int,int> beta){
if(1ll*alpha.first*beta.second >= 1ll*alpha.second*beta.first)
p1 = beta;
} pair<int,int> euchild(pair<int,int> alpha,pair<int,int> beta){
if(alpha.first == ) return make_pair(,beta.second/beta.first+);
if(alpha.first >= alpha.second){
int lw = alpha.first/alpha.second,hh = beta.second;
pair<int,int> jh = euchild(make_pair(alpha.first%alpha.second,alpha.second),make_pair(beta.first-lw*hh,hh));
jh.first += jh.second*lw;
return jh;
}
if(beta.first > beta.second) return make_pair(,);
swap(beta.first,beta.second);swap(alpha.first,alpha.second);
pair<int,int> jh = euchild(beta,alpha);
swap(jh.first,jh.second);
return jh;
} void work(){
if(n&){puts("-1");return;}
p1 = make_pair(,);
int a1 = ,a2 = ;
for(int i=;i<n;i++){
if(i&) a1 += a[i];
else a2 += a[i];
comp(p1,make_pair(a1,a2));
}
a2 += a[n]; p2 = make_pair(a2,a1); swap(p1.first,p1.second);
if(1ll*p1.first*p2.second > 1ll*p2.first*p1.second){puts("-1");return;}
pair<int,int> ans = euchild(p1,p2);
if(ans.first <= C1 && ans.second <= C2){
printf("%d %d\n",ans.first,ans.second);
}else puts("-1");
} int main(){
int Tmp; scanf("%d",&Tmp);
while(Tmp--){
scanf("%d%d%d",&n,&C1,&C2);
for(int i=;i<=n;i++) scanf("%d",&a[i]);
work();
}
return ;
}
codechef EBAIT Election Bait【欧几里得算法】的更多相关文章
- 扩展欧几里得算法(extgcd)
相信大家对欧几里得算法,即辗转相除法不陌生吧. 代码如下: int gcd(int a, int b){ return !b ? gcd(b, a % b) : a; } 而扩展欧几里得算法,顾名思义 ...
- 欧几里得算法:从证明等式gcd(m, n) = gcd(n, m mod n)对每一对正整数m, n都成立说开去
写诗或者写程序的时候,我们经常要跟欧几里得算法打交道.然而有没要考虑到为什么欧几里得算法是有效且高效的,一些偏激(好吧,请允许我用这个带有浓重个人情感色彩的词汇)的计算机科学家认为,除非程序的正确性在 ...
- noip知识点总结之--欧几里得算法和扩展欧几里得算法
一.欧几里得算法 名字非常高大上的不一定难,比如欧几里得算法...其实就是求两个正整数a, b的最大公约数(即gcd),亦称辗转相除法 需要先知道一个定理: gcd(a, b) = gcd(b, a ...
- 欧几里得算法与扩展欧几里得算法_C++
先感谢参考文献:http://www.cnblogs.com/frog112111/archive/2012/08/19/2646012.html 注:以下讨论的数均为整数 一.欧几里得算法(重点是证 ...
- 最小公约数(欧几里得算法&&stein算法)
求最小公约数,最easy想到的是欧几里得算法,这个算法也是比較easy理解的,效率也是非常不错的. 也叫做辗转相除法. 对随意两个数a.b(a>b).d=gcd(a.b),假设b不为零.那么gc ...
- vijos1009:扩展欧几里得算法
1009:数论 扩展欧几里得算法 其实自己对扩展欧几里得算法一直很不熟悉...应该是因为之前不太理解的缘故吧这次再次思考,回看了某位大神的推导以及某位大神的模板应该算是有所领悟了 首先根据题意:L1= ...
- ****ural 1141. RSA Attack(RSA加密,扩展欧几里得算法)
1141. RSA Attack Time limit: 1.0 secondMemory limit: 64 MB The RSA problem is the following: given a ...
- 欧几里得算法求最大公约数(gcd)
关于欧几里得算法求最大公约数算法, 代码如下: int gcd( int a , int b ) { if( b == 0 ) return a ; else gcd( b , a % b ) ; } ...
- Python 最大公约数的欧几里得算法及Stein算法
greatest common divisor(最大公约数) 1.欧几里得算法 欧几里德算法又称辗转相除法,用于计算两个正整数a,b的最大公约数. 其计算原理依赖于下面的定理: 两个整数的最大公约数等 ...
随机推荐
- JavaScript对象访问器属性
对象访问器就是setter和getter,他们的作用就是 提供另外一种方法来获取或者设置对象的属性值, 并且在获取和设置的时候,可以用一定的其他操作. 看下面代码: <script> va ...
- CodeForces Round #550 Div.3
http://codeforces.com/contest/1144 A. Diverse Strings A string is called diverse if it contains cons ...
- JSLinux
JSLinuxhttps://bellard.org/jslinux/vm.html?url=https://bellard.org/jslinux/win2k.cfg&mem=192& ...
- Laravel 获取 Route Parameters (路由参数) 的 5 种方法
Laravel 获取路由参数的方式有很多,并且有个小坑,汇总如下. 假设我们设置了一个路由参数: 现在我们访问 http://test.dev/1/2 在 TestController ...
- vue页面传参和接参
https://blog.csdn.net/zhouzuoluo/article/details/81259298(copy) js** this.$router.push({ name: 'Flow ...
- vs2012密钥
Microsoft Visual Studio Ultimate 2012 旗舰版 有效注册密钥:YKCW6-BPFPF-BT8C9-7DCTH-QXGWC:KCW6-BPFPF-BT8C9-7DCT ...
- cookie,localStorage和sessionStorage区别
三者的异同 特性 Cookie localStorage sessionStorage 数据的生命期 一般由服务器生成,可设置失效时间.如果在浏览器端生成Cookie,默认是关闭浏览器后失效 除非被清 ...
- 进程有一个全局变量i,还有有两个线程。i++在两个线程里边分别执行100次,能得到的最大值和最小值分别是多少?
转自https://blog.csdn.net/biubiu741/article/details/77990592 i++不是原子操作,也就是说,它不是单独一条指令,而是3条指令: 1.从内存中把i ...
- python之路--MySQL权限管理 数据备份还原
一 权限管理 mysql最高管理者是root用户, 这个一般掌握在公司DBA手里, 当你想去对数据库进行一些操作的时候,需要DBA授权给你. 1. 对新用户增删改 1. 创建用户 # 要先use my ...
- 每日一小时linux(1)--sysRq
参考https://www.ibm.com/developerworks/cn/linux/l-cn-sysrq/index.html SysRq 是什么 你是否遇到服务器不能通过 SSH 登录,也不 ...