码迷,mamicode.com
首页 > 其他好文 > 详细

POJ 2142 The Balance(exgcd)

时间:2019-09-12 23:16:48      阅读:88      评论:0      收藏:0      [点我收藏+]

标签:void   ios   lin   题目   problem   none   balance   closed   ret   

嗯...

 

题目链接:http://poj.org/problem?id=2142

 

AC代码:

技术图片
 1 #include<cstdio>
 2 #include<iostream>
 3 
 4 using namespace std;
 5 
 6 inline int _abs(int x){
 7     if(x < 0) return -x;
 8     return x;
 9 }
10 
11 inline void exgcd(int a, int b, int &g, int &x, int &y){
12     if(!b) { g = a; x = 1; y = 0;}
13     else { exgcd(b, a % b, g, y, x); y -= x * (a / b);}
14 }
15 
16 inline void work(int a, int b, int c, int &g, int &x, int &y){
17     exgcd(a, b, g, x, y);
18     x *= c / g;
19     int t = b / g;
20     x = (x % t + t) % t;
21     y = _abs((a * x - c) / b);
22 }
23 
24 int main(){
25     int a, b, c, x1, g, y1, x2, y2;
26     while(~scanf("%d%d%d", &a, &b, &c)){
27         if(!a && !b && !c) break;
28         work(a, b, c, g, x1, y1);
29         work(b, a, c, g, x2, y2);
30         if(x1 + y1 < x2 + y2) printf("%d %d\n", x1, y1);
31         else printf("%d %d\n", y2, x2);
32     }
33     return 0;
34 }
AC代码

 

POJ 2142 The Balance(exgcd)

标签:void   ios   lin   题目   problem   none   balance   closed   ret   

原文地址:https://www.cnblogs.com/New-ljx/p/11515354.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!