hdoj4180
题意:
使(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的更多相关文章
随机推荐
- html中跳转方法(含设定时间)
脚本方式 如: <script language="JavaScript" type="text/JavaScript"> <!-- wind ...
- 常见ODBC及OLEDB连接串的写法
书 名:性能测试进阶指南——LoadRunner11实战 作 者:陈霁 关于数据库连接串的写法
- Android自己定义圆角ImageView
我们常常看到一些app中能够显示圆角图片.比方qq的联系人图标等等,实现圆角图片一种办法是直接使用圆角图片资源,当然假设没有圆角图片资源.我们也能够自己通过程序实现的,以下介绍一个自己定义圆角Imag ...
- 安装Sublime配合quick-cocos2d-x开发
下载地址 Sublime下载地址 安装 Package Control 在Sublime中,按Ctrl+~打开控制台,输入: Sublime Text2 import urllib2,os; pf=' ...
- 算法和流程控制 --《高性能JavaScript》
总结: 1.for, while, do-while循环性能相当,并没有一种循环类型明显快于或满于其他类型. 2.避免使用for-in循环,除非要遍历一个属性数量未知的对象. 3.改善循环性能的最佳形 ...
- attribute constructor&destructor
attribute constructor&destructor 在看openwrt里libnl-tiny这个库的时候,遇到了C里面的构造函数这个概念. static void __init ...
- Facebook内部高效工作指南
文章来源: TopDigital http://news.ittime.com.cn/usershow/main?userid=2826 [IT时代网.IT时代周刊编者按]每一个人工作中都会遇到力不从 ...
- 我遇到的错误curl: (7) Failed to connect to 127.0.0.1 port 1086: Connection refused
今天我用curl命令,无论如何都是出现: curl: (7) Failed to connect to 127.0.0.1 port 1086: Connection refused 找了很久,不知道 ...
- vue2-editor富文本基础使用方法
vue2-editor的入门使用准备工作: 使用 npm install vue2-editor --save 安装到项目中去: 使用 在需要的单文件内引入 import { VueEditor } ...
- MongoDB3.6.3 windows安装配置、启动
1.官网下载MongoDB的安装包 2.安装中一直Next即可安装成功,不过需要注意的是: 可以自定义安装,选择安装路径 值得注意的还有,安装中因为下载compass十分缓慢.把下面默认选中的勾去掉 ...