题意:

使(a/b-c/d)最小,然后让你求c/d.

我们能说最小the error |A/B - C/D|

然后C,D的范围是 0 < C < D < B。

其实就是:求接近(A/B)分数的最大分数

思路:

因为是神队友搞得exgcd专题,所以往这方面想想。

我们先把那个减式通分得:(AD-BC)/BD;求这个最小

若A,B有最大公约数不是1,则化简就是答案。

若最大公约数为1,那么(分子)AD-BC=1,即求AX-BY=1或 -AX+BY=1。

那么把X,Y算出来,比较一下分母就好了。后面自己推咯,很简单的。

#include <stdio.h>
#include <string.h>
#include <math.h>
#include <algorithm>
#include <iostream>
using namespace std;
#define LL __int64
#define mod 9973
#define N 100010 LL exgcd(LL a,LL b,LL &x,LL &y)
{
if(b==0)
{
x=1;
y=0;
return a;
}
LL ans=exgcd(b,a%b,x,y);
LL temp=x;
x=y;
y=temp-a/b*y;
return ans;
} int main()
{
int T;
scanf("%d",&T);
while(T--)
{
LL a,b,x,y;
scanf("%I64d/%I64d",&a,&b);
LL d=exgcd(a,b,x,y);
if(d!=1)
{
printf("%I64d/%I64d\n",a/d,b/d);
continue;
}
if(a==1)
{
printf("1/%I64d\n",b-1);
continue;
}
LL d1=(x+b)%b;
LL c1=(-y+a)%a;
LL d2=(-x+b)%b;
LL c2=(y+a)%a;
if(d2>d1)
{
printf("%I64d/%I64d\n",c2,d2);
}
else
{
printf("%I64d/%I64d\n",c1,d1);
} }
}

hdoj4180的更多相关文章

随机推荐

  1. Koala - 使用

    几天项目又加紧,样式想写又太慢! 下载考拉:http://pc6.dun.123ch.cn/download/koala%E7%BC%96%E8%AF%91%E5%B7%A5%E5%85%B7_30@ ...

  2. weex 项目开发(五)自定义 过滤函数 和 混合 及 自定义 Header 组件

    1.自定义  过滤函数 src / filters / index.js /** * 自定义 过滤函数 */ export function host (url) { if (!url) return ...

  3. Oracle 物理和逻辑备库健康监測的一个根据

    以以下keyword眼为例: 1 物理备库健康检查根据: Tue Apr 22 16:44:51 CST 2014Media Recovery Log /data/CMS/arch_log/1_583 ...

  4. sql select(A.B)拼接

    需要做的工作:把DBtable里边的某两个字段,(当然可以更多)或者不同表,道理类似,用某个符号拼接起来. 比如(Table.A).(Tables.B) oracle里边可以这样写,sql没试: se ...

  5. Linux 用户和文件权限管理

    Linux —— 用户权限管理 权限: 为什么需要权限管理?    1.计算机资源有限,我们需要合理的分配计算机资源.    2.Linux是一个多用户系统,对于每一个用户来说,个人隐私的保护是十分重 ...

  6. js对象的属性问题

    ES6之前js的对象的属性只能是字符串, <html> <head> <script type="text/javascript"> var a ...

  7. mysql下distinct和group by区别对比

    在数据表中记录了用户验证时使用的书目,现在想取出所有书目,用DISTINCT和group by都取到了我想要的结果,但我发现返回结果排列不同,distinct会按数据存放顺序一条条显示,而group ...

  8. LeetCode题解(19)--Remove Nth Node From End of List

    https://leetcode.com/problems/remove-nth-node-from-end-of-list/ 原题: Given a linked list, remove the  ...

  9. Kills all phantomjs instances, disregard of their origin python关闭进程

    Python/Linux quit() does not terminate PhantomJS process · Issue #767 · SeleniumHQ/selenium https:// ...

  10. node-orm2

    最近应老大要求,对orm2进行再一步封装,所以记录下封装和使用心得(文中数据库:mysql). 数据库连接 var orm = require("orm"); orm.connec ...