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的最大公约数. 其计算原理依赖于下面的定理: 两个整数的最大公约数等 ...
随机推荐
- ASP.NET MVC5+EF6+EasyUI 后台管理系统(90)-EF 扩展操作
上一篇讲了EF直接执行SQL与存储过程的用 法 这次我们来看 EntityFramework-Plus(免费开源) 库的用法相比其他扩展库,这个更加新并且用法更加简单 这是一个对Entity Fram ...
- Python之Flask笔记
在这里先说一下最开始所经历的一些错误app=Flask(_name_),当初拼写的时候怎么都报错后来发现此处是两个'_' 配置文件 app.config.from_object(__name__) 在 ...
- python-re模块-54
import re # findall # search # match ret = re.findall('[a-z]+', 'eva egon yuan') # 返回所有满足匹配条件的结果,放在列 ...
- Median String CodeForces - 1144E
You are given two strings ss and tt, both consisting of exactly kk lowercase Latin letters, ss is le ...
- 文本文档中各字母出现次数汇总(java)
package 字母频率统计; import java.io.*; public class Inputfile { public static void main(String args[]) { ...
- Java工具类——UUIDUtils
借用一下百度百科的解释,来看一下UUID是什么. UUID含义是通用唯一识别码 (Universally Unique Identifier),这 是一个软件建构的标准,也是被开源软件基金会 (Ope ...
- apply和call方法
真伪数组转换 /* apply和call方法的作用: 专门用于修改方法内部的this 格式: call(对象, 参数1, 参数2, ...); apply(对象, [数组]); */ function ...
- HTTPS的SSL证书配置
SSL证书 TOMCAT7.0部署_百度经验https://jingyan.baidu.com/article/7082dc1c65066be40a89bda8.html SSL证书安装指引 - 青春 ...
- Memcache之安装篇
本篇文章会介绍memcache在Windows和Linux下的具体安装过程,详细的记录其中的流程内容,帮助小伙伴们快速的搭建起memcache服务,废话少说,直接上!!! Windows: Memca ...
- JMeter学习non-gui模式运行
-h, --help print usage information and exit #打印帮助信息 -v, --version print the version information and ...