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 前缀和打挂,精度被卡,能水过的题连水法都 ...
随机推荐
- charts柱状图,定时刷新
option: var dataoptionone = { title : { text: '数据存储情况', subtext: '数据表', x:'center' }, tooltip: { sho ...
- RxJava使用介绍
主讲人:阳石柏 RxJava基本概念 背压概念介绍 RxJava 2.0版本介绍及更新 一.RxJava基本概念 RxJava 在 GitHub 主页上的自我介绍是 “a library for co ...
- allonsy
时间限制 1s 空间限制 512MB 2.1 题目描述 "Allons-y!" 时间还算足够,好好看看题吧. 有一种说法,时间线是扭曲的,会相互交织.(一般在科幻片里比较流行?) ...
- codevs2557张程易(背包dp)
2557 张程易,编程易 时间限制: 2 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 张程易是一名神奇的魔法少女,在oier之中有着 ...
- [Swift通天遁地]二、表格表单-(17)制作在表单左侧添加单选和复选组件的表单行
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
- Windows(7/8/10)搭建kibana 6.x版本(elasticsearch的可视化服务)
在搭建kibana之前,我们先了解下什么是kibana Kibana 是一款开源的数据分析和可视化平台,它是 Elastic Stack 成员之一,设计用于和 Elasticsearch 协作.您可以 ...
- join()和fromkeys()的用法与注意事项
join()和fromkeys()的用法与注意事项 1.join()的用法与注意事项: join()可以使用集合,列表,字符串的子元素,拼接,下面介绍用法: str.join(data) 2.from ...
- layout 自适应详解
@{ ViewBag.Title = "人员查找"; ViewBag.LeftWidth = "200px"; ViewBag.MiddleW ...
- [python] ThreadPoolExecutor线程池
初识 Python中已经有了threading模块,为什么还需要线程池呢,线程池又是什么东西呢?在介绍线程同步的信号量机制的时候,举得例子是爬虫的例子,需要控制同时爬取的线程数,例子中创建了20个线程 ...
- UNIX环境高级编程--7
进程环境main函数: C程序总是从main函数开始执行.main函数原型是: int main(int argc, char *argv[]); 当内核执行C程序时(使用一个exe ...