提交记录 11141


用户 题目 状态 得分 用时 内存 语言 代码长度
Imakf noi19a. 【NOI2019】回家路线 Accepted 100 64.579 ms 81288 KB C++ 2.58 KB
提交时间 评测时间
2019-10-29 16:21:58 2020-08-01 02:38:56
#include<cstdio>
#include<cstring>
#include<ctime>
#include<cstdlib>
#include<vector>
#include<deque>
#include<iostream>
#include<algorithm>

#define rg register
#define il inline
#define MX (200000 + 5)
#define db double
#define INF (1LL << 50)
#define ll long long

ll min(ll a ,ll b){return a < b ? a : b;}

int n ,m ,A ,B ,C;
il int read(){
	rg char k = getchar();
	int x = 0;
	while(k < '0' || k > '9')	k = getchar();
	while(k >= '0' && k <= '9'){
		x = x * 10 + k - '0';
		k = getchar();
	}
	return x;
}
struct edge{
	int x ,y ,p ,q;
	long long val;
}e[MX];
struct operation{
	int pos ,tim ,id ,belong;
	bool operator <(const operation &B)const{return tim == B.tim ? id > B.id : tim < B.tim;}
}op[MX * 2];

std::deque<int> que[MX >> 1];
ll dp[MX * 2];
db slope(int j1 ,int j2){
	if(op[j1].tim - op[j2].tim == 0)	return INF;
	return (dp[j1] - dp[j2] * 1.0) / (op[j1].tim - op[j2].tim);
}

void stop(){
	for(rg int i = 1 ; i <= 100 ;)
		++i;
}

int main(){
	//freopen("route7.in" ,"r" ,stdin);
	n = read(); m = read();
	A = read(); B = read(); C = read();
	for(rg int i = 1 ,x ,y ,p ,q ; i <= m ; ++i){
		x = read(); y = read();
		p = read(); q = read();
		e[i] = (edge){x ,y ,p ,q ,0};
		op[i * 2 - 1] = (operation){x ,p ,1 ,i};
		op[i * 2] = (operation){y ,q ,2 ,i};
	}
	ll ans = INF;
	std::sort(op + 1 ,op + 1 + m + m);
	e[0] = (edge){0 ,1 ,0 ,0};
	op[0] = (operation){1 ,0 ,2 ,0};
	que[1].push_back(0);
	for(int i = 1 ,now ,type ; i <= m * 2 ; ++i){
		now = op[i].pos ,type = op[i].id;
		if(now == 617) stop();
		if(type == 1){
			while(que[now].size() > 1){
				int j1 = que[now].front() ,j2 = que[now].at(1);
				ll t = 1LL * A * (2 * op[i].tim - op[j1].tim - op[j2].tim) + B;
				if(slope(j1 ,j2) <= t)	que[now].pop_front();
				else break;
			}
			
			if(!que[now].empty()){
				int j = que[now].front();
				e[op[i].belong].val = dp[j] + 
					1LL * A * (op[i].tim - op[j].tim) * (op[i].tim - op[j].tim) 
					+ 1LL * B * (op[i].tim - op[j].tim) + C;
			}
			else{e[op[i].belong].val = INF; continue;}
		}
		
		else{
			dp[i] = e[op[i].belong].val;
			while(que[now].size() > 1){
				int j1 = que[now].back() ,j2 = que[now].at(que[now].size() - 2);
				if(slope(j1 ,i) < slope(j2 ,j1))	que[now].pop_back();
				else break;
			}
			
			if(now == n){
			 	ans = min(ans ,dp[i] + op[i].tim);
				//std::cerr << "One reaches End. From " << e[op[i].belong].x << ". Answer is " << dp[i] + op[i].tim << " \n";
			 	continue;
			}
			 
			if(dp[i] < INF)	{
				//std::cerr << "Reached " << now << ". Answer is " << dp[i] << ". Time is " << op[i].tim << " \n";
				que[now].push_back(i);
			}
		}
		
	}
	printf("%lld\n" ,ans);
	return 0;
}

CompilationN/AN/ACompile OKScore: N/A

Testcase #113.834 ms65 MB + 680 KBAcceptedScore: 5

Testcase #213.823 ms65 MB + 680 KBAcceptedScore: 5

Testcase #313.83 ms65 MB + 680 KBAcceptedScore: 5

Testcase #413.822 ms65 MB + 680 KBAcceptedScore: 5

Testcase #514.56 ms65 MB + 956 KBAcceptedScore: 5

Testcase #614.601 ms65 MB + 952 KBAcceptedScore: 5

Testcase #714.591 ms65 MB + 952 KBAcceptedScore: 5

Testcase #814.589 ms65 MB + 952 KBAcceptedScore: 5

Testcase #914.576 ms65 MB + 952 KBAcceptedScore: 5

Testcase #1014.561 ms65 MB + 952 KBAcceptedScore: 5

Testcase #1114.57 ms65 MB + 956 KBAcceptedScore: 5

Testcase #1214.6 ms65 MB + 952 KBAcceptedScore: 5

Testcase #1314.581 ms65 MB + 952 KBAcceptedScore: 5

Testcase #1414.602 ms65 MB + 952 KBAcceptedScore: 5

Testcase #1561.42 ms79 MB + 392 KBAcceptedScore: 5

Testcase #1660.86 ms79 MB + 392 KBAcceptedScore: 5

Testcase #1759.679 ms79 MB + 388 KBAcceptedScore: 5

Testcase #1857.834 ms79 MB + 392 KBAcceptedScore: 5

Testcase #1964.579 ms79 MB + 392 KBAcceptedScore: 5

Testcase #2058.797 ms79 MB + 392 KBAcceptedScore: 5


Judge Duck Online | 评测鸭在线
Server Time: 2024-12-05 10:33:42 | Loaded in 1 ms | Server Status
个人娱乐项目,仅供学习交流使用 | 捐赠