占坑

做法是拆掉所有式子,拆完式子看一下,如果A=0,发现边被分为了终点走向n的边和不走向n的边。所以边就有了新的边权,并且可以相加。然后通过网络流建模的套路建模使得满足时间的限制,然后由于有负边,所以跑spfa,这里60分。然后还有两个点是一条链,送10分。

先放代码,还没测,可能会爆零。交上去的爆零了因为没写freopenQAQ


//@winlere
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<queue>
#define ERP(t,a) for(register int t=head[a];t;t=e[t].nx) using namespace std; typedef long long ll;
inline int qr(){
register int ret=0,f=0;
register char c=getchar();
while(c<48||c>57)f|=c==45,c=getchar();
while(c>=48&&c<=57) ret=ret*10+c-48,c=getchar();
return f?-ret:ret;
}
namespace sol1{ const int maxn=3e5+5;
struct E{
int fr,to,st,ed;
E(){to=fr=st=ed=0;}
E(const int&a,const int&b,const int&c,const int&d){
fr=a;to=b;st=c;ed=d;
}
}data[maxn];
ll w[maxn];
int arc[maxn];
int cnt;
int nodecnt;
typedef pair < ll , int > P;
//priority_queue< P , vector<P>,greater <P> > q;
queue<P> q;
bool in[maxn<<2];
vector < int > fr[maxn],to[maxn];
vector < P > e[maxn<<2];
inline bool cmp(const int&a,const int&b){
return data[a].ed>data[b].ed;
}
int n,m,A,B,C;
inline bool cmp2(const int&a,const int&b){
return data[a].st>data[b].st;
}
ll d[maxn<<2];
inline ll spfa(){
for(register int t=1;t<maxn<<2;++t) d[t]=2e18;
d[0]=0;in[0]=1;
q.push(make_pair(0,0));
while(!q.empty()){
P cur=q.front();
q.pop();in[cur.second]=0;
for(register int t=0,edd=e[cur.second].size();t<edd;++t){
//cout<<d[e[cur.second][t].second]<<' '<<d[cur.second]+e[cur.second][t].first<<endl;
if(d[e[cur.second][t].second]>d[cur.second]+e[cur.second][t].first){
d[e[cur.second][t].second]=d[cur.second]+e[cur.second][t].first;
if(!in[e[cur.second][t].second])
q.push(make_pair(d[e[cur.second][t].second],e[cur.second][t].second)),in[e[cur.second][t].second]=1;
}
}
}
return d[m+1];
} inline void add(const int&fr,const int&to,const ll&w){
//cout<<"fr="<<fr<<' '<<"to="<<to<<" w="<<w<<endl;
e[fr].push_back(make_pair(w,to));
} inline int init(const int&a,const int&b,const int&c,const int&d1,const int&e1){
n=a;m=b;A=c;B=d1;C=e1;
nodecnt=n;
for(register int t=1,x,y,p,q;t<=m;++t){
x=qr();y=qr();p=qr();q=qr();
//cout<<x<<' '<<y<<' '<<p<<' '<<q<<endl;
data[t]=E(x,y,p,q);
w[t]=C+1ll*B*p+1ll*A*p*p;
if(y!=n) w[t]=w[t]+1ll*A*q*q-1ll*B*q;
if(y==n) w[t]=w[t]+0ll+q;
fr[x].push_back(t);to[y].push_back(t);
if(x==1) add(0,t,w[t]);
if(y==n) add(t,m+1,0);
}
for(register int t=1;t<=n;++t){
//if(fr[t].empty()||to[t].empty())continue;
sort(to[t].begin(),to[t].end(),cmp);
sort(fr[t].begin(),fr[t].end(),cmp2);
int k=0;/* cout<<t<<' '<<fr[t].size()<<' '<<to[t].size()<<endl;
cout<<"fr=";
for(auto f:fr[t])
cout<<f<<" ";
putchar('\n');
cout<<"to=";
for(auto f:to[t])
cout<<f<<" ";
putchar('\n'); */
for(register int i=0,edd=to[t].size(),ed2=fr[t].size();i<edd;++i){
if(i<edd-1)add(to[t][i+1],to[t][i],0);
while(k<ed2&&data[fr[t][k]].st>=data[to[t][i]].ed) add(to[t][i],fr[t][k],w[fr[t][k]]),++k;
}
}
cout<<spfa()<<endl;
return 0;
} } int main(){
freopen("route.in","r",stdin);
freopen("route.out","w",stdout); int a=qr(),b=qr(),c=qr(),d=qr(),e=qr();
if(a<=100&&b==a-1&&c!=0){
ll A=c,B=d,C=e;
ll ans=1ll*a*C;
ll t1=0,t2=0,t3=0;
for(register int t=1;t<=b;++t){
qr();qr();t1=qr();t2=qr();
ans+=B*(t1-t3)+A*(t1-t3)*(t1-t3);
t3=t2;
}
cout<<ans+t3<<endl;
return 0;
}
return sol1::init(a,b,c,d,e);
return 0;
}

【题解】[NOI2019Route](70分)的更多相关文章

  1. 洛谷P4559 [JSOI2018]列队 【70分二分 + 主席树】

    题目链接 洛谷P4559 题解 只会做\(70\)分的\(O(nlog^2n)\) 如果本来就在区间内的人是不用动的,区间右边的人往区间最右的那些空位跑,区间左边的人往区间最左的那些空位跑 找到这些空 ...

  2. 「PKUSC2018」星际穿越 (70分做法)

    5371: [Pkusc2018]星际穿越 Time Limit: 10 Sec  Memory Limit: 512 MBSubmit: 27  Solved: 11[Submit][Status] ...

  3. 洛谷P1979 华容道(70分 暴力)

    P1979 华容道 题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少 ...

  4. 洛谷P1081 开车旅行70分

    https://www.luogu.org/problem/show?pid=1081 太遗憾了明明写出来了,却把最小值初始值弄小了,从第二个点开始就不可能对了.70分! #include<io ...

  5. 华容道 noip2013 70分搜索

    题目描述 [问题描述] 小 B 最近迷上了华容道,可是他总是要花很长的时间才能完成一次.于是,他想到用编程来完成华容道:给定一种局面, 华容道是否根本就无法完成,如果能完成, 最少需要多少时间. 小 ...

  6. ccf 201712-4 行车路线(70分)

    ccf 201712-4 行车路线 解题思路: 首先Dijkstra是基于贪心算法的,即每一次作出的选择都具有贪心选择性.此题由于有“如果连续走小道,小明的疲劳值会快速增加,连续走s公里小明会增加s2 ...

  7. Cogs 1264. [NOIP2012] 开车旅行(70分 暴力)

    1264. [NOIP2012] 开车旅行 ★★☆   输入文件:drive.in   输出文件:drive.out   简单对比时间限制:2 s   内存限制:128 MB [题目描述] 小A 和小 ...

  8. 【NOI2016】优秀的拆分 题解(95分)

    题目大意: 求一个字符串中形如AABB的子串个数. 思路: 用哈希做到O(1)判断字符串是否相同,O($n^2$)预处理,ans[i]为开头位置为i的形如AA的子串个数.再用O($n^2$)枚举出AA ...

  9. ACM: 限时训练题解-Runtime Error-二分查找

    Runtime Error   Bahosain was trying to solve this simple problem, but he got a Runtime Error on one ...

随机推荐

  1. js获取当前日期及获取当前日期的前一天日期函数

    function getcurrentdate(){ //获取系统时间var LSTR_ndate=new Date();var LSTR_Year=LSTR_ndate.getFullYear(); ...

  2. Javascript用正则表达式replace替换父串中所有符合条件的子串

    这样用,只会替换匹配到的第一个子串 str = 'I hava a pen ,I hava an apple,apple pen, pen apple' str = str.replace('appl ...

  3. @bzoj - 4378@ [POI2015] Logistyka

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 维护一个长度为 n 的序列,一开始都是 0,支持以下两种操作: ...

  4. bzoj 4386: [POI2015]Wycieczki

    bzoj 4386: [POI2015]Wycieczki 这题什么素质,爆long long就算了,连int128都爆……最后还是用long double卡过的……而且可能是我本身自带大常数吧,T了 ...

  5. 解决ubuntu的Idea启动No JDK found. Please validate either IDEA_JDK, JDK_HOME or JAVA_HOME environment variable points to valid JDK installation.

    直接在idea安装目录下运行idea.sh可以正常启动,但是使用ubuntu的dash搜索出来的idea报错,No JDK found. Please validate either IDEA_JDK ...

  6. 带你进入 Activiti 工作流的世界

    Activiti 是一个针对企业用户.开发人员 .系统管理员的轻量级工作流业务管理平台,其核心是使用 java 开发的快速 . 稳定的 BPMN2.0 流程引擎 .它可以与 spring 完美集成. ...

  7. 【a503】圆排列问题

    Time Limit: 1 second Memory Limit: 32 MB [问题描述] 给定n个大小不等的圆c1,c2,...., cn,现要将这n个圆排列进一个矩形框中,且要求各圆与矩形框的 ...

  8. CSS定位方式有哪些?position属性的值有哪些?他们之间的区别是什么?

    在CSS中关于定位的内容是:position:relative | absolute | static | fixed • static 自动定位,自动定位就是元素在页 面普通文档流中由HTML自动定 ...

  9. CSS中常用的简写模式

    一.font属性简写 font-style:字体样式 normal 默认值.浏览器显示一个标准的字体样式. italic 浏览器会显示一个斜体的字体样式. oblique 浏览器会显示一个倾斜的字体样 ...

  10. Flex AIR自定义Mobile的弹出框组件

    做Flex Mobile开发的人应该知道,Flex为手机应用并没有提供弹出框组件,需要自定义. 通过查找文档.资料,我做出一个效果还算不错的弹出框组件,可以适用于手机设备上,不多讲,直接贴源码,相信对 ...