100pts被hack求调
查看原帖
100pts被hack求调
846661
ARIS1_0楼主2024/12/17 21:16

树状数组实现单点修改+区间查询最小值,因为不能处理 0 边界所以所有 l,rl,r 全部 +2+2

#include<bits/stdc++.h>
#define ll long long
using namespace std;
mt19937 myrand(time(0));
inline ll read(){
	ll x=0,w=1;
	char ch=0;
	while(ch<'0'||ch>'9'){
		if(ch=='-')w=-1;
		ch=getchar();
	}
	while(ch>='0'&&ch<='9'){
		x=(x<<3)+(x<<1)+(ch^48);
		ch=getchar();
	}
	return x*w;
}
void write(ll x){
	if(x<0){
		putchar('-');
		x=-x;
	}
	static int sta[35];
	int top=0;
	do{
		sta[top++]=x%10,x/=10;
	}while(x);
	while(top)putchar(sta[--top]+'0');
}
int lowbit(int x){return x&(-x);}
ll n,L,R,c[100005],dp[100005],v[100005];
struct node{
	ll st,ed,S;
	bool operator <(const node &x){
		return ed<x.ed;
	}
}a[10005];
void update(ll x,ll k){
	v[x]=k;
	for(int i=x;i<=R;i+=lowbit(i)){
		c[i]=v[i];
		for(int j=1;j<lowbit(i);j*=2)c[i]=min(c[i],c[i-j]);
	}
}
ll Qmin(int l,int r){
	ll ret=LLONG_MAX;
	while(r>=l){
		ret=min(ret,v[r]);
		r--;
		for(;r-lowbit(r)>=l;r-=lowbit(r))ret=min(ret,c[r]);
	}
	return ret;
}

int main(){
	n=read();L=read()+2;R=read()+2;
	for(int i=1;i<=n;i++){
		a[i].st=read()+2;
		a[i].ed=read()+2;
		a[i].S=read();
	}
	sort(a+1,a+n+1);
	memset(dp,0x3f,sizeof(dp));
	for(int i=L;i<=100000;i++){
		update(i,dp[i]);
	}
	dp[L]=0;
	for(int i=1;i<=n;i++){
		dp[a[i].ed]=min(dp[a[i].ed],Qmin(a[i].st-1,a[i].ed-1)+a[i].S);
		update(a[i].ed,dp[a[i].ed]);
		if(a[i].ed>=R){
			if(dp[a[i].ed]>=0x3f3f3f3f3f3f3f3f)puts("-1");
			else write(dp[a[i].ed]);
			return 0;
		}
	}
	return 0;
}
2024/12/17 21:16
加载中...