样例解释
有意义的转换方式共4种:
1->4,消耗能量 1.5
1->2->1->4,消耗能量 4.5
1->3->4,消耗能量 4.5
1->2->3->4,消耗能量 4.5
显然最多只能完成其中的3种转换方式(选第一种方式,后三种方式仍选两个),即最多可以转换3份样本。
如果将 E=14.9 改为 E=15,则可以完成以上全部方式,答案变为 4。
数据规模
占总分不小于 10% 的数据满足 N <= 6,M<=15。
占总分不小于 20% 的数据满足 N <= 100,M<=300,E<=100且E和所有的ei均为整数(可以直接作为整型数字读入)。
所有数据满足 2 <= N <= 5000,1 <= M <= 200000,1<=E<=107,1<=ei<=E,E和所有的ei为实数。
正解:k短路算法(单源最短路+a*算法)
解题报告:这是一个k短路的裸体,拿来练练手,比如,在一个图中,源点是s,汇点是t,k短路的求法是先把所有的边反向,求出所有点到汇点t的最短路,然后从源点开始,用a*算法找路。
1 #include <iostream> 2 #include <iomanip> 3 #include <cstdlib> 4 #include <cstdio> 5 #include <cstring> 6 #include <cmath> 7 #include <string> 8 #include <algorithm> 9 #include <queue> 10 #define RG register 11 #define File(a) freopen(a".in","r",stdin),freopen(a".out","w",stdout) 12 const int N = 10000; 13 const int M = 300000; 14 const int inf = 2147483641; 15 16 using namespace std; 17 18 int nn[M][2],head[N],n,m,nm[M][2],he[N],ans; 19 double w[M],dis[N],gg; 20 bool vis[N]; 21 struct date{ 22 int xh; 23 double s; 24 bool operator < (const date a) const{ 25 return a.s<s; 26 } 27 }; 28 priority_queue<date>d; 29 30 int gi(){ 31 char ch=getchar();int x=0; 32 while(ch<‘0‘ || ch>‘9‘) ch=getchar(); 33 while(ch>=‘0‘ && ch<=‘9‘) x=x*10+ch-‘0‘,ch=getchar(); 34 return x; 35 } 36 37 void dijkstra2(){ 38 date k;RG int i; 39 d.push((date){1,dis[1]}); 40 while(!d.empty()){ 41 k=d.top();d.pop(); 42 if (k.xh==n) 43 if (k.s>gg) return; 44 else ans++,gg-=k.s; 45 for (i=head[k.xh]; i; i=nn[i][0]) 46 d.push((date){nn[i][1],k.s-dis[k.xh]+dis[nn[i][1]]+w[i]}); 47 } 48 return; 49 } 50 51 priority_queue<date>h; 52 53 void dijkstra1(){ 54 date a;RG int i; 55 h.push((date){n,0}),dis[n]=0; 56 while(!h.empty()){ 57 a=h.top();h.pop(); 58 if (vis[a.xh]) continue; 59 vis[a.xh]=1; 60 for (i=he[a.xh]; i; i=nm[i][0]) if (dis[nm[i][1]]>dis[a.xh]+w[i]){ 61 dis[nm[i][1]]=dis[a.xh]+w[i]; 62 h.push((date){nm[i][1],dis[nm[i][1]]}); 63 } 64 } 65 return; 66 } 67 68 int main(){ 69 File("1975"); 70 RG int i,l,r; 71 n=gi(),m=gi();scanf("%lf",&gg); 72 for (i=1; i<=m; i++){ 73 l=gi(),r=gi();scanf("%lf",&w[i]); 74 nn[i][1]=r,nn[i][0]=head[l],head[l]=i; 75 nm[i][1]=l,nm[i][0]=he[r],he[r]=i; 76 } 77 for (i=1; i<=n; i++) dis[i]=inf; 78 dijkstra1(); 79 dijkstra2(); 80 printf("%d",ans); 81 return 0; 82 }