codeforces A. Nuts 解题报告
题目链接:http://codeforces.com/problemset/problem/402/A
题目意思:几经辛苦,终于体明题目噶意思了 = =,完全是考验一个人是否清醒的最简便方法- -!
给出4个数,分别为k,a,b和v。k:1个box最大可以分成的section;a:需要放置的nut的个数;b:divisor的数量 v:每个section的容量。有两个约束条件:(1)每个box的section数不能超过k个; (2)放置的nut的数量不能超过v个(即不能超过section的最大容量)。注意:x个divisor可以得到x + 1个section,每个section的容量为v个。
我的做法有点麻烦。以 b 与 k - 1的关系得到两个部分: b >= k-1 和 b < k
先讨论 b >= k-1 的情况。它表示可以利用divisor来划分出更多的section,最少为 k 个,box相应的最少为1个。b / (k-1) 表示有k个section的box数,从i = 1 ~ b/(k-1) 来扫描,每个box可以装的最多nut数为k * v,当然这个过程中有可能把所有的nut装完,也有可能k个section的box数用光都不能装满。对于后者的情况,求出未消耗完的divisor数(b -= b/(k-1)*(k-1))可以划分出的section数(b+1),然后加入去接下来用到的box(有b+1个section),能装(b+1)*v个nut,假设还没装得完,那么接下来用到的box,容量都为v。依次相加直到 >= a为止。
至于 b < k-1 这种情况比较简单。它表示装得最多nut的box 数最大的section 都比 k 小。那么它能划分出的section数最大为 b+1,能装的nut数最多为 (b+1)*v,接下来如果未装满所有nut,就需要用到容量为v的box数。
#include <iostream>
#include <cstdio>
#include <cstdlib>
using namespace std; int main()
{
int k, a, b, v, i;
while (scanf("%d%d%d%d", &k, &a, &b, &v) != EOF)
{
int sum = ;
int cnt = ;
if (b >= k-) // 情况一
{
int flag = ;
for (i = ; i <= b/(k-); i++) // 有k个section的box数
{
sum += k * v; // 每个box的容量
cnt++; // box数递增
if (sum >= a) // 不需要用完所有含k个section的box
{
flag = ;
break;
}
}
if (!flag) // 用完k个section的所有box都不能装满
{
b -= b/(k-) * (k-); // divisor有剩
sum += (b+) * v; // 紧随着的box的section数为b+1,容量相应乘v
cnt++;
while (sum < a) // 用完这个特殊的box都不能装完所有的nut
{
sum += v; // 后面要用到的box容量都为v
cnt++;
}
}
}
else // 情况二
{
sum += (b + ) * v; // 第一个box的section为b+1
cnt++;
while (sum < a) // 这个box装不完所有的nut
{
sum += v;
cnt++;
}
}
printf("%d\n", cnt);
}
}
codeforces A. Nuts 解题报告的更多相关文章
- codeforces 31C Schedule 解题报告
题目链接:http://codeforces.com/problemset/problem/31/C 题目意思:给出 n 个 lessons 你,每个lesson 有对应的 起始和结束时间.问通过删除 ...
- Timus 2068. Game of Nuts 解题报告
1.题目描述: 2068. Game of Nuts Time limit: 1.0 secondMemory limit: 64 MB The war for Westeros is still i ...
- codeforces 499B.Lecture 解题报告
题目链接:http://codeforces.com/problemset/problem/499/B 题目意思:给出两种语言下 m 个单词表(word1, word2)的一一对应,以及 profes ...
- codeforces 495C. Treasure 解题报告
题目链接:http://codeforces.com/problemset/problem/495/C 题目意思:给出一串只有三种字符( ')','(' 和 '#')组成的字符串,每个位置的这个字符 ...
- codeforces 490B.Queue 解题报告
题目链接:http://codeforces.com/problemset/problem/490/B 题目意思:给出每个人 i 站在他前面的人的编号 ai 和后面的人的编号 bi.注意,排在第一个位 ...
- CodeForces 166E -Tetrahedron解题报告
这是本人写的第一次博客,学了半年的基础C语言,初学算法,若有错误还请指正. 题目链接:http://codeforces.com/contest/166/problem/E E. Tetrahedro ...
- codeforces 489A.SwapSort 解题报告
题目链接:http://codeforces.com/problemset/problem/489/A 题目意思:给出一个 n 个无序的序列,问能通过两两交换,需要多少次使得整个序列最终呈现非递减形式 ...
- codeforces 485A.Factory 解题报告
题目链接:http://codeforces.com/problemset/problem/485/A 题目意思:给出 a 和 m,a 表示第一日的details,要求该日结束时要多生产 a mod ...
- codeforces 483A. Counterexample 解题报告
题目链接:http://codeforces.com/problemset/problem/483/A 题目意思:给出一个区间 [l, r],要从中找出a, b, c,需要满足 a, b 互质,b, ...
随机推荐
- SilverLight:基础控件使用(5)-TreeView控件-基本使用
ylbtech-SilverLight-Basic-Control:基础控件使用(5)-TreeView控件-基本使用 前台编辑 后台逐个添加 后台绑定数据源 1.A,返回顶部TreeView控件(树 ...
- 【Todo】Java学习路线(方向指导)
在网上搜了下Java学习路线(关键词:学习,因为众所周知,实践出牛人,在平时工作不怎么深入的情况下,才强调学习的方向的重要性 ^_^) 发现下面知乎这个回答写的真好.mark如下: https://w ...
- iOS集成百度地图方法步骤
前言:app中的导航功能越来越流行,现在我自己做的项目中也有此需求,做过了后记录下笔记. 由于源代码保密所以这里仅仅提供demo,下面是效果图 一:iOS地图SDK 1.打开 百度地图api链接 i ...
- 面试之SQL(1)--选出选课数量>=2的学号
ID Course 1 AA 1 BB 2 AA 2 BB 2 CC 3 AA 3 BB 3 CC 3 DD 4 AA NULL NULL 选出选课数量>=2的学号 select di ...
- 【CODEFORCES】 B. Dreamoon and Sets
B. Dreamoon and Sets time limit per test 1 second memory limit per test 256 megabytes input standard ...
- shell脚本分析mysql慢查询日志(slow log)
使用percona公司的pt-query-digest分析慢查询日志.分析.统计的结果的比較清晰 #!/bin/sh slowlog_path=/root/slow_query_log everysl ...
- 【浅墨Unity3D Shader编程】之三 光之城堡篇:子着色器、通道与标签的写法 & 纹理混合
本系列文章由@浅墨_毛星云 出品,转载请注明出处. 文章链接:http://hpw123.net/a/C__/kongzhitaichengxu/2014/1117/120.html 作者:毛星云 ...
- 虚拟网卡TUN/TAP 驱动程序设计原理
昨天韦哥写了<Linux下Tun/Tap设备通信原理>一文,只提到了两个使用Tun的用户进程之间的通信路径,并没有说明Tun虚拟网卡驱动是如何实现的,而正好看到了这里的一篇讲解这方面的文章 ...
- 获取当前外网IP地址
<script src="http://pv.sohu.com/cityjson?ie=utf-8"></script><script>cons ...
- js实现网页端复制功能
实现网页端复制功能: <div id="copyInput" style="display:none;"> <form> <inp ...