设为首页 加入收藏

TOP

UVA 10090 - Marbles (数论)
2015-07-24 05:55:18 来源: 作者: 【 】 浏览:8
Tags:UVA 10090 Marbles 数论

UVA 10090 - Marbles

题目链接

题意:有两种盒子,一种代价c1,能装n1个珠子,一种代价c2,能装n2个珠子,问如何正好装n个珠子,并且使得代价最少。
思路:利用扩展欧几里得算法求出n1?x+n2?y=n的一个解(x′,y′)
就可以知道x,y的通解分别为
x=x′?n/gcd(n1,n2)+n2/gcd(n1,n2)?t
y=y′?n/gac(n1,n2)?n1/gcd(n1,n2)?t
由于x > 0 && y > 0,就可以求出t的范围。
那么t越小x越小,y越大,反之亦然。
之后利用贪心,看那种盒子比例比较优,就尽量让哪种盒子多即可。
代码:

#include 
   
     #include 
    
      #include 
     
       long long extend_gcd(long long a, long long b, long long &x, long long &y) { if (b == 0) {x = 1; y = 0; return a;} long long d = extend_gcd(b, a % b, y, x); y -= a / b * x; return d; } long long n, c1, c2, n1, n2; int main() { while (~scanf("%lld", &n) && n) { scanf("%lld%lld%lld%lld", &c1, &n1, &c2, &n2); long long x, y; long long d = extend_gcd(n1, n2, x, y); long long downk = ceil(1.0 * -n * x / n2); long long upk = floor(1.0 * n * y / n1); if (downk > upk || n % d) { printf("failed\n"); continue; } if (c1 * n2 < c2 * n1) { x = n * x / d + n2 / d * upk; y = n * y / d - n1 / d * upk; } else { x = n * x / d + n2 / d * downk; y = n * y / d - n1 / d * downk; } printf("%lld %lld\n", x, y); } return 0; }
     
    
   
】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇hdu1172猜数字 下一篇求二维数组中子数组和中最大的值..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容: