题目大意:

就是将两种砝码左右摆放,能够在物品放置在天平上时保持平衡

很容易得到 ax + by = t的模线性方程

按题目要求,希望首先满足 |x| + |y| 最小 , 如果有多种情况,再满足所有砝码质量最小,也就是a|x| + b|y|最小

x = x0 + b/g * k

y = y0 - a/g * k

这里可以通过画一个2维坐标图进行观察 x , y 对于k的直线,我假定 b > a ,初始如果 a>b就交换两者数据,记得最后答案交换回来

因为a,b为砝码重量都大于0

所以x是递增直线,y是递减直线

因为假设b > a了,所以x的上升趋势必然大于y的下降趋势

所以只有在x = 0的左右两个点是满足最小的情况的 , 用xx[2] , yy[2]记录这两个点,然后进行比较即可

/*

当然不交换a , b 也可以, 那就得在 a > b 的条件下多保存两组数据,此时是在y = 0 的左右两个点

*/

 #include <cstdio>
#include <cstring>
#include <iostream>
using namespace std; int ex_gcd(int a , int &x , int b , int &y)
{
if(b == ){
x = , y = ;
return a;
}
int ans = ex_gcd(b , x , a%b , y);
int t = x;
x = y , y = t - a/b*y;
return ans;
} void my_swap(int &a , int &b)
{
int t = a;
a = b , b = t;
} int my_abs(int a)
{
return a>=?a:-a;
} int main()
{
// freopen("a.in" , "r" , stdin);
int a , b , w;
while(scanf("%d%d%d" , &a , &b , &w) , a){
int x , y;
bool flag = false;
if(b < a){
my_swap(a , b);
flag = true;
} int g = ex_gcd(a , x , b , y);
int k = w/g;
x = k*x , y = k*y;
a /= g , b /= g;
int xx[] , yy[];
if(x >= ){
xx[] = x - x/b*b;
xx[] = xx[] - b;
yy[] = y + x/b*a;
yy[] = yy[] + a;
}else{
xx[] = x - x/b*b+b;
xx[] = xx[] - b;
yy[] = y + x/b*a - a;
yy[] = yy[] + a;
}
int ansx , ansy;
if(my_abs(xx[]) + my_abs(yy[]) == my_abs(xx[]) + my_abs(yy[])){
if(my_abs(xx[])*a + my_abs(yy[])*b < my_abs(xx[])*a + my_abs(yy[])*b)
ansx = my_abs(xx[]) , ansy = my_abs(yy[]);
else
ansx = my_abs(xx[]) , ansy = my_abs(yy[]);
}
else{
if(my_abs(xx[]) + my_abs(yy[]) < my_abs(xx[]) + my_abs(yy[]))
ansx = my_abs(xx[]) , ansy = my_abs(yy[]);
else
ansx = my_abs(xx[]) , ansy = my_abs(yy[]);
}
if(flag)
my_swap(ansx , ansy);
printf("%d %d\n" , ansx , ansy);
}
return ;
}

最新文章

  1. ExtJS关于组件Component生命周期
  2. 字符集和字符编码(Charset &amp; Encoding)
  3. AngularJs单元测试
  4. Android API 21 Toolbar Padding
  5. &#39;Invalid parameter not satisfying: body&#39;
  6. u-boot和linux的机器码
  7. Varnish缓存服务详解及应用实现
  8. live-server 介绍&amp;安装
  9. DingDing的CorpSecretID和SSOSecret不是一个东西
  10. interface{} 泛型编程
  11. centos7使用lldb调试netcore应用转储dump文件
  12. CyclicBarrier源码解读
  13. c# 规范用户输入控件
  14. C#获取文件MD5值方法
  15. WebApi安全性 使用TOKEN+签名验证 (秘钥是GUID的,私有的,不是雙方的,并不在网络连接上传输)
  16. Android 对BaseAdapter做优化处理
  17. mysql性能优化(一)
  18. go-restful 实现一个web server
  19. 【第十周】psp
  20. string ids=aduuids.Aggregate(&quot;&quot;, (m, n) =&gt; m + n+&quot;,&quot;).TrimEnd(&#39;,&#39;);

热门文章

  1. P3207 [HNOI2010]物品调度
  2. 【计蒜客习题】 取石子游戏(gcd)
  3. [算法] 常见排序算法总结(C语言版)
  4. VC++常见错误原因解析--error LNK2019: 无法解析的外部符号 &quot;public: void __thiscall
  5. 联想 Z5 Pro(L78031)免解锁BL 免rec 保留数据 ROOT Magisk Xposed 救砖ZUI 10.0.355
  6. Sublime——基本操作
  7. 浏览器 chrome 360等 加载本地json 或者xml 文件
  8. LockDemo 锁对象
  9. HDU_2544_最短路
  10. 梦想Android版CAD控件2018.10.12更新