BZOJ2330_糖果_KEY
看题目可知这是一道差分约束的题目。
根据每种关系建边如下:

对于每种情况建边,然后跑一边SPFA。(最长路)
因为可能会有自环或环的情况,都不可能存在。
跑SPFA时记录入队次数,超过N弹出。
SPFA的dist起始值为1,ans=∑dist[i]
对于每个点做一遍SPFA会超时,所以将所有点放入队列中,所有点一起跑SPFA。
code:
/**************************************************************
Problem: 2330
User: yekehe
Language: C++
Result: Accepted
Time:1280 ms
Memory:43792 kb
****************************************************************/
#include <cstdio>
#include <cstdlib>
#include <cstring>
using namespace std;
int read()
{
char c;while(c=getchar(),(c<''||c>'')&&c!='-');
int x=,y=;c=='-'?y=-:x=c-'';
while(c=getchar(),c>=''&&c<='')x=x*+c-'';
return x*y;
}
struct list{
int head[],nxt[],To[],W[],cnt;
list(){
memset(head,-,sizeof head);
memset(nxt,-,sizeof nxt);
cnt=;
}
void add(int x,int y,int c)
{
To[cnt]=y;
W[cnt]=c;
nxt[cnt]=head[x];
head[x]=cnt;
cnt++;
}
}P;
int N,K;
int dist[],l[],flag[];
int into[],SF=;
void SPFA()
{
int h=,t=;
memset(into,,sizeof into);
for(int i=;i<=N;i++)l[++t]=i,into[i]++;//入队++
while(h<t){
int front=l[++h];
flag[front]=;
for(int i=P.head[front];i!=-;i=P.nxt[i]){
if(dist[P.To[i]]<P.W[i]+dist[front]){//求最长路
dist[P.To[i]]=P.W[i]+dist[front];
if(!flag[P.To[i]]){
l[++t]=P.To[i],flag[P.To[i]]=;
into[P.To[i]]++;
if(into[P.To[i]]>N){SF=-;return ;}//判环
}
}
}
}
return ;
}
int main()
{
N=read();K=read();
register int i;
for(i=;i<=K;i++){
int o=read(),x=read(),y=read();
switch(o){
case :P.add(x,y,),P.add(y,x,);break;
case :P.add(x,y,);break;
case :P.add(y,x,);break;
case :P.add(y,x,);break;
case :P.add(x,y,);break;
}
}
for(i=;i<=N;i++)dist[i]=;
SPFA();
if(SF<)return puts("-1"),;//有环
long long ans=;
for(i=;i<=N;i++)ans+=(long long)dist[i];
printf("%lld",ans);
return ;
}
BZOJ2330_糖果_KEY的更多相关文章
- 原生js可爱糖果数字时间特效
效果展示:http://hovertree.com/texiao/js/35/ 数字采用漂亮的糖果皮肤设计 效果图: 代码如下: <!DOCTYPE html> <html> ...
- UOJ #58 【WC2013】 糖果公园
题目链接:糖果公园 听说这是一道树上莫队的入门题,于是我就去写了--顺便复习了一下莫队的各种姿势. 首先,我们要在树上使用莫队,那么就需要像序列一样给树分块.这个分块的过程就是王室联邦这道题(vfle ...
- [LeetCode] Candy 分糖果问题
There are N children standing in a line. Each child is assigned a rating value. You are giving candi ...
- UOJ58 【WC2013】糖果公园
本文版权归ljh2000和博客园共有,欢迎转载,但须保留此声明,并给出原文链接,谢谢合作. 本文作者:ljh2000 作者博客:http://www.cnblogs.com/ljh2000-jump/ ...
- bzoj2330: [SCOI2011]糖果
2330: [SCOI2011]糖果 Time Limit: 10 Sec Memory Limit: 128 MB Description 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友 ...
- 糖果 bzoj 2330
糖果(1s 128MB)candy [题目描述] 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要求,比如小明 ...
- BZOJ 2330: [SCOI2011]糖果 [差分约束系统] 【学习笔记】
2330: [SCOI2011]糖果 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 5395 Solved: 1750[Submit][Status ...
- Vijos P1196吃糖果游戏[组合游戏]
描述 Matrix67和Shadow正在做一个小游戏. 桌子上放着两堆糖果,Matrix67和Shadow轮流对这些糖果进行操作.在每一次操作中,操作者需要吃掉其中一堆糖果,并且把另一堆糖果分成两堆( ...
- BZOJ 4548 小奇的糖果
Description 有 \(N\) 个彩色糖果在平面上.小奇想在平面上取一条水平的线段,并拾起它上方或下方的所有糖果.求出最多能够拾起多少糖果,使得获得的糖果并不包含所有的颜色. Input 包含 ...
随机推荐
- SAP S/4HANA生产订单创建时使用的工厂数据是从什么地方带出来的
大家如果使用我github上的这段代码创建S/4HANA的生产订单时,一定会发现,我在代码里并没有硬编码来指定生产订单的ID,然而运行时会发现我在系统里配置的这个2800被自动使用了,这是怎么做到的呢 ...
- ListView实现分页加载(一)制作Demo
一.什么是分页加载 在下面的文章中,我们来讲解LitView分页加载的实现.什么是分页加载呢?我们先看几张效果图吧,如下: ...
- Struts2注解开发
Hibernate和spring框架的开发前边总结了,这次看一下流行的MVC流程框架Struts2的注解开发吧.Struts2主要解决了从JSP到Action上的流程管理,如何进行Uri和action ...
- UVa 1220 - Party at Hali-Bula(树形DP)
链接: https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- 「uoj#188. 【UR #13】Sanrd」
题目 不是很能看懂题意,其实就是求\([l,r]\)区间内所有数的次大质因子的和 这可真是看起来有点鬼畜啊 这显然不是一个积性函数啊,不要考虑什么特殊的函数了 我们考虑Min_25筛的过程 设\(S( ...
- Codeforces Round #527 (Div. 3) D1. Great Vova Wall (Version 1) 【思维】
传送门:http://codeforces.com/contest/1092/problem/D1 D1. Great Vova Wall (Version 1) time limit per tes ...
- shiro密码的比对,密码的MD5加密,MD5盐值加密,多个Relme
有具体问题的可以参考之前的关于shiro的博文,关于shiro的博文均是一次工程的内容 密码的比对 通过AuthenticatingRealm的CredentialsMatcher方法 密码的加密 ...
- Yii2 配置发送邮件
'components' => [ 'mailer' => [ 'class' => 'yii\swiftmailer\Mailer', 'viewPath' => '@com ...
- halcon 分水领域法详解(转载)
寻思自己写了的,但是这个大佬写的太好了,感谢Y忍冬草_ http://blog.csdn.net/y363703390 https://blog.csdn.net/y363703390/article ...
- Spring data JPA先排序再分页。
//工具类,增删改查等等package com.yunqing.service.impl; import java.util.Map; import org.springframework.beans ...