Codeforces Round #433 (Div. 2)【A、B、C、D题】
题目链接:Codeforces Round #433 (Div. 2)
题意:已知分子与分母的和,求分子小于分母的 最大的最简分数。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int gcd(int a,int b){return b?gcd(b,a%b):a;}
int n;
int main() {
int a, b;
scanf("%d", &n);
for(int i = n/; i >= ; --i)
if(gcd(i, n-i)==) {a = i, b = n-i; break;}
printf("%d %d\n", a, b);
retur
15ms
codeforces 854 B. Maxim Buys an Apartment【水】
题意:有标号1~n的n个公寓顺序排列在一条线,已知有k个公寓不为空 但不知道是哪k个,定义一个 空的 并且旁边至少有一个 非空的公寓 为好公寓,问最少和最多有几个 好公寓。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
using namespace std;
int n, k;
int main() {
int a, b;
scanf("%d %d", &n, &k);
if(k >= n/+) {a = (n!=k); b = n-k;}
else {a = (k!=); b = k*;}
printf("%d %d\n", a, b);
return ;
}
15ms
codeforces 853 A. Planning【贪心+优先队列】
题意:n个航班,原本顺序出发,现在已知前k分钟没有航班能出发,每个航班均只能延迟出发时间,已知每个航班延迟一分钟需要的花费,现在要你安排出发顺序,使得总花费最小。
题解:用优先队列维护延迟时间最大值,贪心的对每个位置取队列中的最大值。
#include <iostream>
#include <cstdio>
#include <cstring>
#include <queue>
#include <algorithm>
using namespace std;
typedef long long ll;
const int N = 3e5+;
int n, k;
int c[N], a[N];
priority_queue<pair<int, int> > q;
ll ans, t;
int main() {
ans = t = ;
while(!q.empty()) q.pop();
int i, j, x;
scanf("%d %d", &n, &k);
for(i = ; i <= k+n; ++i) {
if(i <= n) {
scanf("%d", &x); t += x;
q.push(make_pair(x, i));
}
if(i > k) {
a[q.top().second] = i;
t -= q.top().first; q.pop();
}
ans += t;
}
printf("%lld\n", ans);
for(i = ; i < n; ++i)
printf("%d ", a[i]);
printf("%d\n", a[n]);
return ;
}
187ms
未完待补。。。
codeforces 853 B. Jury Meeting【贪心】
题意:有n+1个城市,0号为首都,1~n每个城市有一个人,现在要安排每个人去首都,并且所有人一起待上至少k天并且返回自己的城市(航班飞行时长为一天),给出m个航班信息(每个航班都是在 0号城市 与其他城市之间往返),求满足安排的最少花费。
题解:将航班按时间排序后,贪心算所有人在第i天前出发的最小花费和第i天后返回的最小花费,最后前缀后缀扫一下。
//因为各种细节问题WA。。QAQ
#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#define CLR(a,b) memset((a),(b),sizeof((a)))
using namespace std;
typedef long long ll;
const int N = 1e5+;
const int M = 1e6+;
const ll inf = 2e11+;
int n, m, k;
struct node {
int d, f, t, c;
bool operator < (const node &r)const {
return d < r.d;
}
}e[N];
ll a[M], b[M];
int d[N];
int main() {
int i, j, day = , u;
ll ans = inf;
CLR(a, ); CLR(b, ); CLR(d, );
scanf("%d %d %d", &n, &m, &k);
for(i = ; i <= m; ++i) {
scanf("%d%d%d%d", &e[i].d, &e[i].f, &e[i].t, &e[i].c);
day = max(day, e[i].d);
}
int num = n, tt = ;
ll mi = ;
sort(e+, e++m);
for(i = ; i <= m; ++i) {
tt = e[i].d;
if(u=e[i].f) {
if(!d[u]) {
d[u] = e[i].c; num--;
if(!num) {
for(j = ; j <= n ; ++j)a[tt] += d[j];
mi = a[tt];
}
}
else if(d[u] > e[i].c){
if(!num) {mi -= (d[u] - e[i].c); a[tt]=mi;}
d[u] = e[i].c;
}
}
}
if(num) {puts("-1"); return ;}
CLR(d, ); num = n;
for(i = m; i >= ; --i) {
tt = e[i].d;
if(u=e[i].t) {
if(!d[u]) {
d[u] = e[i].c; num--;
if(!num) {
for(j = ; j <= n ; ++j)b[tt] += d[j];
mi = b[tt];
}
}
else if(d[u] > e[i].c){
if(!num) {mi -= (d[u] - e[i].c); b[tt]=mi;}
d[u] = e[i].c;
}
}
}
if(num) {puts("-1"); return ;} for(i = ; i <= day; ++i) {
if(!a[i]) a[i] = a[i-];
else if(a[i-]) a[i] = min(a[i], a[i-]);
}
for(i = day; i >= ; --i) {
if(!b[i]) b[i] = b[i+];
else if(b[i+]) b[i] = min(b[i], b[i+]);
} //for(i = 1; i <= day; ++i) printf("%d ",a[i]);puts("");
//for(i = day; i >= 1; --i) printf("%d ",b[i]);puts(""); for(i = ; i <= day; ++i)
if(a[i] && i++k <= day && b[i++k])
ans = min(ans, a[i]+b[i++k]);
if(ans<inf) printf("%lld\n", ans);
else puts("-1");
return ;
}
93ms
Codeforces Round #433 (Div. 2)【A、B、C、D题】的更多相关文章
- Codeforces Round #367 (Div. 2) A. Beru-taxi (水题)
Beru-taxi 题目链接: http://codeforces.com/contest/706/problem/A Description Vasiliy lives at point (a, b ...
- Codeforces Round #575 (Div. 3) 昨天的div3 补题
Codeforces Round #575 (Div. 3) 这个div3打的太差了,心态都崩了. B. Odd Sum Segments B 题我就想了很久,这个题目我是找的奇数的个数,因为奇数想分 ...
- Codeforces Round #334 (Div. 2) A. Uncowed Forces 水题
A. Uncowed Forces Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/604/pro ...
- Codeforces Round #433 (Div. 2, based on Olympiad of Metropolises)
A. Fraction 题目链接:http://codeforces.com/contest/854/problem/A 题目意思:给出一个数n,求两个数a+b=n,且a/b不可约分,如果存在多组满足 ...
- Codeforces Round #433 Div. 1
A:显然从大到小排序后贪心放在第一个能放的位置即可.并查集维护. #include<iostream> #include<cstdio> #include<cmath&g ...
- codeforces 853b//Jury Meeting// Codeforces Round #433 (Div. 1)
题意:几个人要去一个城市k天,现给出各航班的日期和花费,让这n个人能相会k天的最小花费? 用数组arr1[i]记录在第i天人到齐的最小花费.arr2[i]记录第i天之后才有人开始走的最小花费.然后取a ...
- Codeforces Round #433 (Div. 2, based on Olympiad of Metropolises) D. Jury Meeting(双指针模拟)
D. Jury Meeting time limit per test 1 second memory limit per test 512 megabytes input standard inpu ...
- Codeforces Round #433 (Div. 2, based on Olympiad of Metropolises) D
Country of Metropolia is holding Olympiad of Metrpolises soon. It mean that all jury members of the ...
- Codeforces Round #433 (Div. 2, based on Olympiad of Metropolises) C
Helen works in Metropolis airport. She is responsible for creating a departure schedule. There are n ...
随机推荐
- leetcode_173【二叉搜索树迭代器】
实现一个二叉搜索树迭代器.你将使用二叉搜索树的根节点初始化迭代器. 调用 next() 将返回二叉搜索树中的下一个最小的数. 示例: BSTIterator iterator = new BSTIte ...
- 问题集录04--json和jsonp讲解
JSON和JSONP JSON(Javascript Object Notation)是一种轻量级的数据交换格式,用于在浏览器和服务器之间交换信息. JSONP(JSON With Padding ...
- Bitbucket 关联 VS
1.双击已经建立好的仓库 - 克隆仓库-目标路径选择一个空的文件夹,点击克隆 2.把已经建立好的项目拷贝的到刚刚那个空目录里面 3.在VS里面打开新路径下面的项目,点击提交即可; 我安装了Bitbuc ...
- 深入理解 JSON
我们先来看一个JS中常见的JS对象序列化成JSON字符串的问题,请问,以下JS对象通过JSON.stringify后的字符串是怎样的?先不要急着复制粘贴到控制台,先自己打开一个代码编辑器或者纸,写写看 ...
- [javaEE] 三层架构案例-用户模块(二)
使用junit测试框架,测试查找用户和添加用户功能 com.tsh.test.xmlUserDaoTest package com.tsh.test; import org.junit.Test; i ...
- 十一、cent OS下搭建SVN服务器
安装SVN命令:yum install subversion 查看安装位置:rpm -ql subversion,我们看到它在/usr/bin目录下生成了svn的二进制文件 查看svn版本:/usr/ ...
- mysql,简单介绍一下索引
汉字很多,人力有时尽,人不可能记住所有的字,为了解决这个问题,于是有了字典.数据库里的数据很多,为了方便检索,于是有了索引. 索引,是一种数据结构,在这种数据结构中实现了高级的查找算法,索引可以帮助我 ...
- C 堆内存管理
在Win32 程序中每个进程都占有4GB的虚拟地址空间,这4G的地址空间内部又被分为代码段,全局变量段堆段和栈段,栈内存由函数使用,用来存储函数内部的局部变量,而堆是由程序员自己申请与释放的,系统在管 ...
- flask 继承模版的基本使用1
- ImportError: No module named bs4错误解决方法
前言:毕业论文打算用Python做爬虫爬一些数据,最近开始入门Python: 在学习的时候遇到一个问题,按照看的文章安装了Python,也配置了相应的环境(使用window系统),使用pycharm编 ...