通关最小花费

链接: https://www.nowcoder.com/acm/contest/67/E
来源:牛客网

题目描述

    马云:“哈哈,女生的钱最好赚了!”

    叠纸:“马云说得对!”

    腾讯:“哇!真的耶!求代理!”

    小P眼一眯,嘴角一挑,似乎发现了商机。不就是抽卡过关看CG么,我也能做啊!于是乎,一个月后,一款《恋与程序员》诞生了。

    游戏里设置了n个事件,m个关卡,k张卡片。每一个事件都有一张独一无二的CG,但是每个关卡,都需要拥有特定的卡片才能通关。从一个事件,触发另一个事件,需要通过一个特定的关卡。我们给事件编号为1~n,对应的CG编号与事件的编号一致。卡片编号为1~k。一开始,玩家会触发事件1,并拿到1号CG,但是从此之后,玩家如果想触发别的事件,便要通过闯关来达到。

    现在,小Q想要c号CG(触发c号事件获得),但是小Q却又不想花太多的钱。于是小Q查了攻略,以事件为点,关卡为边,作了一张图,并且小Q知道每个关卡都需要什么卡片以及卡片的售价。请你计算一下,小Q拿到c号CG,至少要花多少钱。

    注意,过关并不需要消耗卡片,同一张卡片可以通关多次。

输入描述:

数据有多组,处理到文件结束。
每组数据第一行有四个整数n,m,k,c,代表事件数量、关卡数量、卡片数量以及小Q想要的CG的编号。
接下来m行,每行三个整数u,v,e,代表从u号事件可以通过闯关触发v号事件,并且需要e号卡片。
接下来k行,每行两个整数a,b,代表a号卡片的售价是b。

输出描述:

每组数据输出一行,一个整数,代表小Q拿到c号CG的最小花费。

  
  
示例1

输入

6 7 5 6
2 3 2
4 3 3
1 2 1
1 5 4
4 6 5
1 4 2
5 6 3
1 100
3 422
2 210
5 107
4 38

输出

317

备注:

对于100%的数据,
1 <= n,m,k <= 100;
1 <= u,v <= n;
1 <= a,c,e <= k;
1 <= b <= 1000。
   
   
#include<bits/stdc++.h>
using namespace std;
int use[101],w[101][101],cost[101],n,m,k,t,ans=INT_MAX;
//use[]标记是否有X号卡片,w[][]i与j可连接,ans 最小花费,cost[]x号卡片的价格;
  void dfs( int o, int sum)
{
     if (o==t)  ///找到了
     {
         ans=min(ans,sum);
         return ;
     }
     for ( int i=1;i<=n;i++) ///遍历与当前o点连接的点
         if (~w[o][i])  ///有通道 可连接
         {
             if (!use[w[o][i]]) ///没有所需要的通关卡片
             {
                 use[w[o][i]]=1;
                 dfs(i,sum+cost[w[o][i]]); ///当前花费(买通关卡片);
                 use[w[o][i]]=0; ///取消标记
             }
             else
                 dfs(i,sum); ///遍历下一个点
         }
}
int main () {
     while (~ scanf ( "%d%d%d%d" ,&n,&m,&k,&t)) {
         memset (w,-1, sizeof w);ans=INT_MAX;
         for ( int i=1,u,v,z;i<=m;i++) {
             scanf ( "%d%d%d" ,&u,&v,&z);
             w[u][v]=z;
         }
         for ( int i=1,x,y;i<=k;i++) {
             scanf ( "%d%d" ,&x,&y);
             cost[x]=y; ///x卡片的价格y
         }
         dfs(1,0);
         printf ( "%d\n" ,ans);
     }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值