codeforces round #257 div2 C、D
本来应该认真做这场的。思路都是正确的。
C题,是先该横切完或竖切完,无法满足刀数要求。再考虑横切+竖切(竖切+横切),
由于横切+竖切(或竖切+横切)会对分割的东西产生交叉份数。从而最小的部分不会尽可能的大。
代码例如以下。尽管比較长、比較乱,但全然能够压缩到几行,由于差点儿是4小块反复的代码,自己也懒得压缩
注意一点,比方要推断最小块的时候,比方9行要分成2份,最小的剩下那份不是9取模2,而应该是4
m/(k+1)<=m-m/(k+1)*k
#include<bits/stdc++.h>
using namespace std;
typedef long long LL;
const int MAX = 1e6+10;
const LL MOD = 1e9+7;
LL f[1000];
int main() {
LL n,m,k;
//freopen("in.txt", "r", stdin);
while(scanf("%I64d %I64d %I64d",&n,&m, &k)==3) {
if(k > (n+m-2)) { printf("-1\n"); continue;}
LL k1 = k;
LL ans = 0, ans2 = 0;
if(1){
if(k<=(m-1)){
if(m%(k+1)==0)
ans = m/(k+1)*n;
else if(m/(k+1)<=m-m/(k+1)*k) {
ans = m/(k+1)*n;
}
else ans = (m/(k+1)-1)*n;
}
else {
k -= (m-1);
if(n%(k+1)==0)
ans = n/(k+1);
else if(m/(k+1)<=m-m/(k+1)*k) {
ans = n/(k+1);
}
else ans = (n/(k+1)-1);
}
}
//printf("%I64d~\n", ans);
swap(n, m);
if(2){
k = k1;
if(k<=(m-1)){
if(m%(k+1)==0) {
ans2 = m/(k+1)*n;
}
else if(m/(k+1)<=m-m/(k+1)*k) {
ans2 = m/(k+1)*n;
}
else ans2 = (m/(k+1)-1)*n;
}
else {
k -= (m-1);
if(n%(k+1)==0)
ans2 = n/(k+1);
else if(m/(k+1)<=m-m/(k+1)*k) {
ans2 = n/(k+1);
}
else ans2 = (n/(k+1)-1);
}
} printf("%I64d\n", max(ans, ans2));
}
}
D题
一看题目时就非常欣喜,挺有意思的图论。
一開始的思路是错的,每次进行松弛操作时推断当前边是否标记过。从而进行减减操作。这样考虑忘了后面可能进行了一些更新,从而覆盖了前面的标记
正确思路:
在每次优先队列出点的时候,推断从起点到这个点的最短路有多少是跟K条(train route)是反复的就可以
自己须要注意的地方:
1、如何记录最短路的数目
2、当k==Count[u]时候的处理
3、小细节,第一个节点u,tt与Count[u]都是等于0的
代码还是挺快的~
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>
#include <vector>
#include <cmath>
#include <queue>
#include <stack>
#include <map>
#include <set> using namespace std; #define clr(x) memset(x,0,sizeof(x))
#define fp1 freopen("in.txt","r",stdin)
#define fp2 freopen("out.txt","w",stdout)
#define pb push_back #define INF 0x3c3c3c3c
typedef long long LL; const int maxn = 4*1e5;
bool vis[maxn];
struct Edge {int from,to,dist,cnt;};
struct Node
{
int d,u;
bool operator <(const Node &a) const {
return a.d<d; //从小到大排序。 }
}; int n,m,k; //点数和边数,用n表示,e不能和m冲突
vector<Edge> edges;//边列表
vector<int> G[maxn];//每一个结点出发的边编号(从0開始编号)
vector<int> qw[maxn];
int Count[maxn];
bool done[maxn];//是否已永久编号
int d[maxn];//s到各个点的距离
int p[maxn];//最短路中的上一条边
void init()
{
for(int i=0;i<n;i++) G[i].clear();//清空邻接表
edges.clear();
} void addedge(int from,int to,int dist)
//假设是无向。每条无向边需调用两次addedge
{
edges.push_back((Edge){from,to,dist});
int temp=edges.size();
G[from].push_back(temp-1);
} void dijk(int s)
{ clr(Count);
priority_queue<Node> q;
for(int i=0;i<n;i++) d[i]=INF;
d[s]=0;
memset(done,0,sizeof(done));
q.push((Node){0,s});
while(!q.empty()) {
Node x=q.top();
q.pop();
int u=x.u;
if(done[u]) continue;
done[u]=true;
for(int i=0;i<G[u].size();i++) {
Edge &e=edges[G[u][i]];
if(d[e.to]>d[u]+e.dist) {
d[e.to]=d[u]+e.dist;
p[e.to]=G[u][i];
q.push((Node){d[e.to],e.to});
Count[e.to] = 1;
}
else if(d[e.to]==d[u]+e.dist){
Count[e.to] ++;
}
} int tt = 0;
for(int i = 0;i < qw[u].size();i++){
if(qw[u][i] > d[u]) {
//printf("%d %d %d~\n", u, qw[u][i], d[u]);
int temp = k -1;
k = temp;
}
else if(qw[u][i] == d[u]) tt++;
}
//printf("%d %d %d!\n", u, tt, Count[u]);
if(tt == 0) continue;
else if(tt < Count[u]) { k -= tt; }
else if(tt == Count[u]) k -= (tt-1);
}
} int main()
{
//fp1;
while(scanf("%d %d %d", &n, &m, &k) == 3){
int k1 = k;
init();
int u, v, w;
for(int i = 1;i <= m;i++){
scanf("%d %d %d", &u, &v, &w);
u--; v--;
addedge(u, v, w);
addedge(v, u, w);
}
for(int i = m+1;i <= m+k;i++){
scanf("%d %d", &u, &v);
u--;
addedge(0, u, v);
addedge(u, 0, v);
qw[u].pb(v);
}
dijk(0);
printf("%d\n", k1 - k);
}
return 0;
}
codeforces round #257 div2 C、D的更多相关文章
- Codeforces Round #257 (Div. 1)A~C(DIV.2-C~E)题解
今天老师(orz sansirowaltz)让我们做了很久之前的一场Codeforces Round #257 (Div. 1),这里给出A~C的题解,对应DIV2的C~E. A.Jzzhu and ...
- Codeforces Round #539 div2
Codeforces Round #539 div2 abstract I 离散化三连 sort(pos.begin(), pos.end()); pos.erase(unique(pos.begin ...
- 【前行】◇第3站◇ Codeforces Round #512 Div2
[第3站]Codeforces Round #512 Div2 第三题莫名卡半天……一堆细节没处理,改一个发现还有一个……然后就炸了,罚了一啪啦时间 Rating又掉了……但是没什么,比上一次好多了: ...
- Codeforces Round#320 Div2 解题报告
Codeforces Round#320 Div2 先做个标题党,骗骗访问量,结束后再来写咯. codeforces 579A Raising Bacteria codeforces 579B Fin ...
- Codeforces Round #564(div2)
Codeforces Round #564(div2) 本来以为是送分场,结果成了送命场. 菜是原罪 A SB题,上来读不懂题就交WA了一发,代码就不粘了 B 简单构造 很明显,\(n*n\)的矩阵可 ...
- Codeforces Round #361 div2
ProblemA(Codeforces Round 689A): 题意: 给一个手势, 问这个手势是否是唯一. 思路: 暴力, 模拟将这个手势上下左右移动一次看是否还在键盘上即可. 代码: #incl ...
- Codeforces Round #626 Div2 D,E
比赛链接: Codeforces Round #626 (Div. 2, based on Moscow Open Olympiad in Informatics) D.Present 题意: 给定大 ...
- Codeforces Round #257 (Div. 1)449A - Jzzhu and Chocolate(贪婪、数学)
主题链接:http://codeforces.com/problemset/problem/449/A ------------------------------------------------ ...
- CodeForces Round 192 Div2
This is the first time I took part in Codeforces Competition.The only felt is that my IQ was contemp ...
随机推荐
- 批量增加Linux系统账号、重置账号密码、FTP账号批量测试
批量增加Linux系统账号.重置账号密码是用Linux Shell脚本来做的:批量FTP账号测试是用Python脚本来做的.这些脚本都是读取一个用户名和密码文件,然后基于该用户名密码文件进行自动批量测 ...
- 使用Cobbler批量部署Linux和Windows:CentOS/Ubuntu批量安装(二)
通过前面服务端的部署,已经配置好了 Cobbler Server 端,接下来开始进行 CentOS/Ubuntu 的批量安装,在进行 CentOS/Ubuntu 批量安装时,也需要通过Cobbler来 ...
- 理解 Memory barrier(内存屏障)【转】
转自:http://name5566.com/4535.html 参考文献列表:http://en.wikipedia.org/wiki/Memory_barrierhttp://en.wikiped ...
- springcloud Zuul中路由配置细节
上篇文章我们介绍了API网关的基本构建方式以及请求过滤,小伙伴们对Zuul的作用应该已经有了一个基本的认识,但是对于路由的配置我们只是做了一个简单的介绍,本文我们就来看看路由配置的其他一些细节. 首先 ...
- re模块逐步进阶
Windows 10家庭中文版,Python 3.6.4, 正则表达式,自己一直的水平是 知道,但不熟悉,简单的也能写,复杂的就需要看资料了,距离灵活运用还是差那么一些的. 于是,今天(180831) ...
- python基础-装饰器,生成器和迭代器
学习内容 1.装饰器 2.生成器 3.迭代器 4.软件目录结构规范 一:装饰器(decorator) 1.装饰器定义:本质就是函数,用来装饰其他函数,即为其他函数添加附加功能. 2.装饰器原则:1)不 ...
- 补充NTP知识的初中高
前言 网上流传阿里穆工对NTP知识梳理的初级和中级版本.我从时钟服务器厂商在实践中的经验对穆工的文档进行再次整理和补充,希望对使用此设备的客户和对此有兴趣的同学给出一些指引. 个人认为对知识的了解应该 ...
- 《MySQL技术内幕 InnoDB存储引擎 》学习笔记
第1章 MySQL体系结构和存储引擎 1.3 MySQL存储引擎 数据库和文件系统最大的区别在于:数据库是支持事务的 InnoDB存储引擎: MySQL5.5.8之后默认的存储引擎,主要面向OLTP ...
- mysql多表查询,group by并将结果导出来csv文件
SQL手动操作得少,遇到一个CASE,就记录一个CASE吧. 今天遇到的是统计一个发布结果. 这个发布表中,有两个字段是外键,并且要求按其中一个外键,作group by操作, 最后,导出来excel能 ...
- Android Studio从2.3升级到3.1注意事项
原文:https://blog.csdn.net/lithiumyoung/article/details/80111111 Android Studio从2.3升级到3.1注意事项 项目根目录下的b ...