Codeforces Round #523 (Div. 2) Solution
A. Coins
Water.
#include <bits/stdc++.h>
using namespace std;
int n, s; int main()
{
while (scanf("%d%d", &n, &s) != EOF)
{
int res = ;
for (int i = n; i >= ; --i) while (s >= i)
{
++res;
s -= i;
}
printf("%d\n", res);
}
return ;
}
B. Views Matter
Solved.
题意:
有n个栈,不受重力影响,在保持俯视图以及侧视图不变的情况下,最多可以移掉多少个方块
思路:
考虑原来那一列有的话那么这一列至少有一个,然后贪心往高了放
#include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
int n, m;
ll a[N], sum; int main()
{
while (scanf("%d%d", &n, &m) != EOF)
{
sum = ;
for (int i = ; i <= n; ++i) scanf("%lld", a + i), sum += a[i];
sort(a + , a + + n);
ll res = , high = ;
for (int i = ; i <= n; ++i) if (a[i] > high)
++high;
printf("%lld\n", sum - n - a[n] + high);
}
return ;
}
C. Multiplicity
Upsolved.
题意:
定义一个序列为好的序列即$b_1, b_2, ...., b_k 中i \in [1, k] 使得 b_i % i == 0$
求有多少个好的子序列
思路:
考虑$Dp$
$令dp[i][j] 表示第i个数,长度为j的序列有多少种方式$
$dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j] (arr[j] % j == 0)$
否则 $dp[i][j] = dp[i - 1][j]$
然后不能暴力递推,只需要更新$arr[j] % j == 0 的j即可$
#include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 1000100
const ll MOD = (ll)1e9 + ;
int n; ll a[N], dp[N]; int main()
{
while (scanf("%d", &n) != EOF)
{
for (int i = ; i <= n; ++i) scanf("%lld", a + i);
memset(dp, , sizeof dp);
dp[] = ;
for (int i = ; i <= n; ++i)
{
vector <int> cur;
for (int j = ; j * j <= a[i]; ++j)
{
if (a[i] % j == )
{
cur.push_back(j);
if (j != a[i] / j)
cur.push_back(a[i] / j);
}
}
sort(cur.begin(), cur.end());
reverse(cur.begin(), cur.end());
for (auto it : cur)
dp[it] = (dp[it] + dp[it - ]) % MOD;
}
ll res = ;
for (int i = ; i <= ; ++i) res = (res + dp[i]) % MOD;
printf("%lld\n", res);
}
return ;
}
D. TV Shows
Upsolved.
题意:
有n个电视节目,每个节目播放的时间是$[l, r],租用一台电视机的费用为x + y \cdot time$
一台电视机同时只能看一个电视节目,求看完所有电视节目最少花费
思路:
贪心。
因为租用电视机的初始费用是相同的,那么我们将电视节目将左端点排序后
每次选择已经租用的电视机中上次放映时间离自己最近的,还要比较租用新电视机的费用,
如果是刚开始或者没有一台电视机闲着,则需要租用新的电视机
#include <bits/stdc++.h>
using namespace std; #define ll long long
#define N 100010
struct node
{
ll l, r;
void scan() { scanf("%lld%lld", &l, &r); }
bool operator < (const node &r) const
{
return l < r.l || (l == r.l && this->r < r.r);
}
}arr[N];
int n; ll x, y;
const ll MOD = (ll)1e9 + ;
multiset <ll> se; int main()
{
while (scanf("%d%lld%lld", &n, &x, &y) != EOF)
{
for (int i = ; i <= n; ++i) arr[i].scan();
sort(arr + , arr + + n);
ll res = ;
for (int i = ; i <= n; ++i)
{
if (se.lower_bound(arr[i].l) == se.begin())
res = (res + x + y * (arr[i].r - arr[i].l) % MOD) % MOD;
else
{
int pos = *(--se.lower_bound(arr[i].l));
if (x < y * (arr[i].l - pos))
res = (res + x + y * (arr[i].r - arr[i].l) % MOD) % MOD;
else
{
se.erase(--se.lower_bound(arr[i].l));
res = (res + y * (arr[i].r - pos) % MOD) % MOD;
}
}
se.insert(arr[i].r);
}
printf("%lld\n", res);
}
return ;
}
E. Politics
Unsolved.
F. Lost Root
Unsolved.
Codeforces Round #523 (Div. 2) Solution的更多相关文章
- Codeforces Round #523 (Div. 2)
Codeforces Round #523 (Div. 2) 题目一览表 来源 考察知识点 完成时间 A Coins cf 贪心(签到题) 2018.11.23 B Views Matter cf 思 ...
- Codeforces Round #466 (Div. 2) Solution
从这里开始 题目列表 小结 Problem A Points on the line Problem B Our Tanya is Crying Out Loud Problem C Phone Nu ...
- 老年OIer的Python实践记—— Codeforces Round #555 (Div. 3) solution
对没错下面的代码全部是python 3(除了E的那个multiset) 题目链接:https://codeforces.com/contest/1157 A. Reachable Numbers 按位 ...
- Codeforces Round #545 (Div. 1) Solution
人生第一场Div. 1 结果因为想D想太久不晓得Floyd判环法.C不会拆点.E想了个奇奇怪怪的set+堆+一堆乱七八糟的标记的贼难写的做法滚粗了qwq靠手速上分qwqqq A. Skyscraper ...
- Codeforces Round 500 (Div 2) Solution
从这里开始 题目地址 瞎扯 Problem A Piles With Stones Problem B And Problem C Photo of The Sky Problem D Chemica ...
- Codeforces Round #523 (Div. 2) E. Politics(最小费+思维建图)
https://codeforces.com/contest/1061/problem/E 题意 有n个点(<=500),标记第i个点的代价a[i],然后分别在这n个点建两棵树,对于每颗树的每个 ...
- Codeforces Round #523 (Div. 2) F. Katya and Segments Sets (交互题+思维)
https://codeforces.com/contest/1061/problem/F 题意 假设存在一颗完全k叉树(n<=1e5),允许你进行最多(n*60)次询问,然后输出这棵树的根,每 ...
- Codeforces Round #607 (Div. 1) Solution
从这里开始 比赛目录 我又不太会 div 1 A? 我菜爆了... Problem A Cut and Paste 暴力模拟一下. Code #include <bits/stdc++.h> ...
- Codeforces Round #578 (Div. 2) Solution
Problem A Hotelier 直接模拟即可~~ 复杂度是$O(10 \times n)$ # include<bits/stdc++.h> using namespace std; ...
随机推荐
- python语言简介、解释器、字符编码介绍
一.为什么要选择python作为学习语言: 各个语言的对比: C和python.java.C#等 C语言:代码编译得到机器码,机器码在处理器上直接执行,每一条指令控制cpu工作 其他语言:代码编译得到 ...
- solr删除数据的4种方便快捷的方式
1.在solr客户端,访问你的索引库(我认为最方便的方法) 1)documents type 选择 XML 2)documents 输入下面语句 <delete><query> ...
- WinForm软件开机自动启动详细方法
现在正在制作一个物资公司的管理软件,把自己掌握的学到的一点点细细的讲给喜欢C#的同仁们,互相交流. 想要给你制作的应用程序做一个开机启动,很方便,你可以让用户选择,在你的工具栏中的某个下拉菜单里添加一 ...
- IE8及以下的数组处理与其它浏览器的不同
在解决search-box的bug时,由于IE8-的数组处理与其它浏览器的不同,而导致报错. 示例:arr=[1,3,3,]; 当数组的最后是一个逗号时: IE9+默认 arr=[1,3,3];也就是 ...
- SPF难以解决邮件伪造的现状以及方案
邮件伪造的现状 仿冒域名 私搭邮服仿冒域名: 例如某公司企业的域名是example.com,那么攻击者可以搭建一个邮服,也把自己的域名配置为example.com,然后发邮件给真实的企业员工xxx@e ...
- DES加密解密 Java中运用
DES全称Data Encryption Standard,是一种使用密匙加密的块算法.现在认为是一种不安全的加密算法,因为现在已经有用穷举法攻破DES密码的报道了.尽管如此,该加密算法还是运用非常普 ...
- 查看Oracle的redo日志切换频率
1.Oracle log 每次切换会记录到告警日志中 设想写个方案来查看log切换频率来判断Oracle log是否应该更改大小. 2.sql a.查看redo日志信息 select * from v ...
- Fiddler关闭自动更新
1,fiddler 启动时老弹出要更新,但不想更新,可以这样设置 Tools-Optons->General 把第一个√去掉
- Jenkins中maven的作用--构建项目(三)
本文主要根据Jenkins上的日志来继续说明构建项目的过程,上文我们已经讲到构建一个测试环境或单独终端的过程,详情可以了解上篇文章 一.背景介绍 首先看下SVN代码的仓库的结构: 代码仓库里有一个文件 ...
- MVC视图布局页常用代码
1.在视图 Views 中新建文件夹 Shared 2.在 Shared 中新建布局页-母版页 _Layout.cshtml @{ Layout = null; } <!DOCTYPE h ...