poj 3411 && 1724

题目:http://poj.org/problem?id=3411

题意:n 个城市,m 条路,每条路都有两种情况的费用,一种是 在 b 城市付费 r,一种是提前在 c 城市付费 p 元,问从 1 到 n 最小的花费

思路:邻接表 + dfs

View Code
 1 #include <stdio.h>
 2 #include <iostream>
 3 #include <string.h>
 4 #include <algorithm>
 5 #define N 20
 6 #define inf 100000000
 7 #define _clr(a,val) (memset(a,val,sizeof(a)))
 8 
 9 using namespace std;
10 
11 int vis[N];
12 int head[N];
13 struct node
14 {
15     int a,b,c,p,r;
16     int next;
17 }point[N];
18 int n,m;
19 int minn;
20 void dfs(int x,int sum)
21 {
22     if(sum > minn || vis[x] > n) return;  // 当一个节点被访问n次时,就没必要再访问了
23     if(x == n)
24     {
25         if(sum < minn) minn = sum;
26         return ;
27     }
28     int t = head[x];
29     while(t != -1)
30     {
31         vis[point[t].b] ++;
32         if(vis[point[t].c] > 0) dfs(point[t].b,sum + point[t].p);
33         else dfs(point[t].b , point[t].r + sum);
34         vis[point[t].b] --;
35         t = point[t].next;
36     }
37 }
38 int main()
39 {
40     int i;
41     //freopen("data.txt","r",stdin);
42     while(scanf("%d%d",&n,&m) != EOF)
43     {
44         _clr(vis,0);
45         _clr(head,-1);
46         for(i = 0; i < m; i++)
47         {
48             scanf("%d%d%d%d%d",&point[i].a,&point[i].b,&point[i].c,&point[i].p,&point[i].r);
49             point[i].next = head[point[i].a];
50             head[point[i].a] = i;
51         }
52         minn = inf;
53         vis[1] = 1;
54         dfs(1,0);
55         if(minn == inf) printf("impossible\n");
56         else printf("%d\n",minn);
57     }
58     return 0;
59 }

题目:http://poj.org/problem?id=1724

题意:n个城市 m 条路,每条路有两个参数,一个是长度,一个是费用,给出Bob拥有的钱,问从1 到 n在 可以付的起费的情况下的做短路长度

思路:用优先队列保存加进来的点(在不超过 Bob最多钱的情况下),然后bfs当找到n时就输出并退出

View Code
 1 #include <stdio.h>
 2 #include <iostream>
 3 #include <string.h>
 4 #include <queue>
 5 #include <algorithm>
 6 #define N 10010
 7 #define inf 100000000
 8 #define _clr(a,val) (memset(a,val,sizeof(a)))
 9 
10 using namespace std;
11 
12 struct node
13 {
14     int point;
15     int len;
16     int cost;
17     friend bool operator < (node a,node b)  // 定义顺序
18     {
19         return a.len > b.len;
20     }
21 };
22 struct tnode
23 {
24     int f,t,l,c;
25     int next;
26 }eage[N];
27 int s,d,r;
28 int head[N];
29 void bfs()
30 {
31     node tem;
32     int flag = 0;
33     tem.point = 1, tem.len = tem.cost = 0;
34     priority_queue<node>qu;
35     qu.push(tem);
36     while(!qu.empty())
37     {
38         //cout<<"999\n";
39         node temp = qu.top();
40         qu.pop();
41         if(temp.point == d)
42         {
43             printf("%d\n",temp.len);  
44             flag = 1;
45             break;  //找到了就输出并退出
46         }
47         int i = head[temp.point];
48         while(i != -1)
49         {
50             node ttem;
51             ttem.point = eage[i].t, ttem.len = temp.len + eage[i].l, ttem.cost = temp.cost + eage[i].c;
52             if(ttem.cost <= s)
53             {
54                 qu.push(ttem);
55             }
56             i = eage[i].next;
57         }
58     }
59     if(!flag) printf("-1\n");
60     return ;
61 }
62 int main()
63 {
64     int i;
65     //freopen("data.txt","r",stdin);
66     while(scanf("%d%d%d",&s,&d,&r) != EOF)
67     {
68         _clr(head,-1);
69         for(i = 0; i < r; i++)
70         {
71             scanf("%d%d%d%d",&eage[i].f,&eage[i].t,&eage[i].l,&eage[i].c);
72             eage[i].next = head[eage[i].f], head[eage[i].f] = i;
73         }
74         bfs();
75     }
76     return 0;
77 }
posted @ 2012-08-07 18:36  AC_Girl  阅读(158)  评论(0编辑  收藏  举报