C - Otoshidama

传送门:https://abc085.contest.atcoder.jp/tasks/abc085_c

有面值为10000、5000、1000(YEN)的纸币。试用N张纸币,组成金额为Y(YEN)的钱。

依次考虑:

1.只用1KYEN的纸币;

2.用1KYEN和5KYEN的纸币;

3.用1KYEN、5KYEN和10KYEN的纸币。

参考程序如下:

#include <stdio.h>

int min(int a, int b)
{
return a < b? a: b;
} int main(void)
{
int n, y;
scanf("%d%d", &n, &y);
//1k-yen only.
int yen_1k = y / ;
int yen_5k = ;
int yen_10k = ;
int cnt = yen_1k + yen_5k + yen_10k;
if (cnt == n) printf("%d %d %d\n", yen_10k, yen_5k, yen_1k);
else if (cnt < n) printf("-1 -1 -1\n");
//1k-yen and 5k-yen.
else {
int dif = cnt - n;
int y1k_2_y5k = min(dif / , yen_1k / );
yen_5k += y1k_2_y5k;
yen_1k -= y1k_2_y5k * ;
cnt = yen_1k + yen_5k + yen_10k;
if (cnt == n) printf("%d %d %d\n", yen_10k, yen_5k, yen_1k);
//1k-yen, 5k-yen and 10k-yen.
else {
dif = cnt - n;
int y5k_2_y10k = min(dif, yen_5k / );
yen_10k += y5k_2_y10k;
yen_5k -= y5k_2_y10k * ;
cnt = yen_1k + yen_5k + yen_10k;
if (cnt == n) printf("%d %d %d\n", yen_10k, yen_5k, yen_1k);
else printf("-1 -1 -1\n");
}
}
return ;
}

当然,这个问题也可以构造一个三元一次方程,brute force求解。

D - Katana Thrower

传送门:https://abc085.contest.atcoder.jp/tasks/abc085_d

N把武士刀,对于每一把武士刀,有以下两种攻击方法:

①常规:攻击造成a点damage,可连续多次使用;

②终结:攻击造成b点damage,使用一次后丢弃。

对于每一把武士刀,有a≤b

为造成至少H点的damage,求最小攻击次数。

设置一个优先队列(用std::priority_queue实现),对于每一把武士刀,将有序对<a,1><b,0>置入优先队列。于是,每次取出顶端的元素,作为武器使用。

参考程序如下:

#include <bits/stdc++.h>
using namespace std; priority_queue<pair<int, bool> > q; int main(void)
{
int n, h;
scanf("%d%d", &n, &h);
for (int i = ; i < n; i++) {
int a, b;
scanf("%d%d", &a, &b);
q.push(make_pair(a, ));
q.push(make_pair(b, ));
}
int ans = ;
while (h > ) {
int attack = q.top().first;
bool multi_attack = q.top().second;
q.pop();
if (multi_attack) {
int cnt = h / attack;
if (h % attack) cnt++;
h -= attack * cnt;
ans += cnt;
}
else {
h -= attack;
ans++;
}
}
printf("%d\n", ans);
return ;
}

AtCoder ABC 085C/D的更多相关文章

  1. ATCODER ABC 099

    ATCODER ABC 099 记录一下自己第一场AK的比赛吧...虽然还是被各种踩... 只能说ABC确实是比较容易. A 题目大意 给你一个数(1~1999),让你判断它是不是大于999. Sol ...

  2. Atcoder ABC 141

    Atcoder ABC 141 A - Weather Prediction SB题啊,不讲. #include<iostream> #include<cstdio> #inc ...

  3. Atcoder ABC 139E

    Atcoder ABC 139E 题意: n支球队大循环赛,每支队伍一天只能打一场,求最少几天能打完. 解法: 考虑抽象图论模型,既然一天只能打一场,那么就把每一支球队和它需要交手的球队连边. 求出拓 ...

  4. Atcoder ABC 139D

    Atcoder ABC 139D 解法: 等差数列求和公式,记得开 $ long long $ CODE: #include<iostream> #include<cstdio> ...

  5. Atcoder ABC 139C

    Atcoder ABC 139C 题意: 有 $ n $ 个正方形,选择一个起始位置,使得从这个位置向右的小于等于这个正方形的高度的数量最多. 解法: 简单递推. CODE: #include< ...

  6. Atcoder ABC 139B

    Atcoder ABC 139B 题意: 一开始有1个插口,你的插排有 $ a $ 个插口,你需要 $ b $ 个插口,问你最少需要多少个插排. 解法: 暴力模拟. CODE: #include< ...

  7. Atcoder ABC 139A

    Atcoder ABC 139A 题意: 给你两个字符串,记录对应位置字符相同的个数 $ (n=3) $ 解法: 暴力枚举. CODE: #include<iostream> #inclu ...

  8. atcoder abc 244

    atcoder abc 244 D - swap hats 给定两个 R,G,B 的排列 进行刚好 \(10^{18}\) 次操作,每一次选择两个交换 问最后能否相同 刚好 \(10^{18}\) 次 ...

  9. AtCoder ABC 250 总结

    AtCoder ABC 250 总结 总体 连续若干次一样的结果:30min 切前 4 题,剩下卡在 T5 这几次卡在 T5 都是一次比一次接近, 什么 dp 前缀和打挂,精度被卡,能水过的题连水法都 ...

随机推荐

  1. param size: The requested size, in points.

    param size: The requested size, in points. 字幕宽度的自适应 . fontScale c++ - OpenCV find the text Scale fro ...

  2. 0x0118消息就是WM_SYSTIMER

    http://social.msdn.microsoft.com/Forums/vstudio/en-US/c0f9bac9-d211-4b8b-ba99-f5a0ed0d2e0a/what-is-w ...

  3. LeetCode241——Different Ways to Add Parentheses

    Given a string of numbers and operators, return all possible results from computing all the differen ...

  4. mst

    https://www.zybuluo.com/ysner/note/1245941 题面 给一个\(n\)点完全图,点权均小于\(2^m\).定义边权等于两端点点权的与和(即\(a_i\&b ...

  5. bzoj3240 [Noi2013]矩阵游戏——费马小定理+推式子

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=3240 n 和 m 太过巨大,不难想到应该用费马小定理什么的来缩小范围: 总之就是推式子啦,看 ...

  6. openstack 虚拟机导出

  7. 使用psutil模块获取电脑运行信息

    psutil是python的一个用于获取cpu信息的模块,非常好使,以下附上官方的一些example: CPU-> Examples >>> import psutil > ...

  8. RabbitMQ~消息的产生和管理(15672)

    上一讲说了rabbitmq在windows环境的部署,而今天主要说一下消息在产生后,如何去查看消息,事实上,rabbitmq为我们提供了功能强大的管理插件,我们只要开启这个插件即可,它也是一个网站,端 ...

  9. [转]自适应网页设计(Responsive Web Design)

    本文转自:http://www.ruanyifeng.com/blog/2012/05/responsive_web_design.html 作者: 阮一峰 日期: 2012年5月 1日 随着3G的普 ...

  10. Jquery课堂上课了,第一节Jquery选择器$

    Jquery是优秀的Javascrīpt框架,$是jquery库的申明,它很不稳定(我就常遇上),换一种稳定的写法jQuery.noConflict();                   jQue ...