AtCoder ABC 085C/D
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的更多相关文章
- ATCODER ABC 099
ATCODER ABC 099 记录一下自己第一场AK的比赛吧...虽然还是被各种踩... 只能说ABC确实是比较容易. A 题目大意 给你一个数(1~1999),让你判断它是不是大于999. Sol ...
- Atcoder ABC 141
Atcoder ABC 141 A - Weather Prediction SB题啊,不讲. #include<iostream> #include<cstdio> #inc ...
- Atcoder ABC 139E
Atcoder ABC 139E 题意: n支球队大循环赛,每支队伍一天只能打一场,求最少几天能打完. 解法: 考虑抽象图论模型,既然一天只能打一场,那么就把每一支球队和它需要交手的球队连边. 求出拓 ...
- Atcoder ABC 139D
Atcoder ABC 139D 解法: 等差数列求和公式,记得开 $ long long $ CODE: #include<iostream> #include<cstdio> ...
- Atcoder ABC 139C
Atcoder ABC 139C 题意: 有 $ n $ 个正方形,选择一个起始位置,使得从这个位置向右的小于等于这个正方形的高度的数量最多. 解法: 简单递推. CODE: #include< ...
- Atcoder ABC 139B
Atcoder ABC 139B 题意: 一开始有1个插口,你的插排有 $ a $ 个插口,你需要 $ b $ 个插口,问你最少需要多少个插排. 解法: 暴力模拟. CODE: #include< ...
- Atcoder ABC 139A
Atcoder ABC 139A 题意: 给你两个字符串,记录对应位置字符相同的个数 $ (n=3) $ 解法: 暴力枚举. CODE: #include<iostream> #inclu ...
- atcoder abc 244
atcoder abc 244 D - swap hats 给定两个 R,G,B 的排列 进行刚好 \(10^{18}\) 次操作,每一次选择两个交换 问最后能否相同 刚好 \(10^{18}\) 次 ...
- AtCoder ABC 250 总结
AtCoder ABC 250 总结 总体 连续若干次一样的结果:30min 切前 4 题,剩下卡在 T5 这几次卡在 T5 都是一次比一次接近, 什么 dp 前缀和打挂,精度被卡,能水过的题连水法都 ...
随机推荐
- jsp ajax 数据库Demo
转自:http://blog.csdn.net/rushkid02/article/details/7515058 下面介绍JSP前台表单内容通过Ajax异步提交到后台Servlet进行校验(校验方式 ...
- P2495 [SDOI2011]消耗战 虚树
这是我做的第一道虚树题啊,赶脚不错.其实虚树也没什么奇怪的,就是每棵树给你一些点,让你多次查询,但是我不想每次都O(n),所以我们每次针对给的点建一棵虚树,只包含这些点和lca,然后在这棵虚树上进行树 ...
- Java的安装过程
记录一下自己在Windowns下安装java的过程 安装网址:http://www.oracle.com/index.html 打开网址后要先登录,如果没有号就先注册,然后才能下载 step1:下载J ...
- Xampp mysql无法启动的解决方案
如果出现mysql 无法启动表明在安装xampp 前已经安装了mysql,造成mysql服务无法启动. 19:06:33 [mysql] MySQL Service detected with wr ...
- PHP入门开发
1.下载开发工具phpstorm 地址:http://www.jetbrains.com/phpstorm/download/download-thanks.html?platform=windows ...
- 5CSS之字体font-family
---------------------------------------------------------------------------------------------------- ...
- 345 Reverse Vowels of a String 反转字符串中的元音字母
编写一个函数,以字符串作为输入,反转该字符串中的元音字母.示例 1:给定 s = "hello", 返回 "holle".示例 2:给定 s = "l ...
- [ SCOI 2008 ] 着色方案
\(\\\) \(Description\) 给出\(K\)种颜料各自的个数\(C_i\),每一个颜料只够涂一个格子,求将颜料用完,涂一排格子,每个格子只能涂一次的条件下,相邻两个格子的颜色互不相同的 ...
- 关于编辑器对<input>标签报错提示“表单输入没有相关label”的问题
相信很多朋友在制作表单的时候,我们的编辑器会有下图的相关提示吧 我们发现虽然这样并不影响我们的正常使用,但是看着这样的报错提示总是很让人心烦,那么这到底是为什么呢? 其实,这是因为编辑器建议我们在使用 ...
- 怎么用css hack处理各浏览器兼容IE6,IE7,IE8,IE9/ FF
第一:什么事浏览器兼容性 浏览器兼容性问题又被称为网页兼容性或网站兼容性问题,指网页在各种浏览器上的显示效果可能不一致而产生浏览器和网页间的兼容问题.在网站的设计和制作中,做好浏览器兼容,才能够让网站 ...