zoukankan      html  css  js  c++  java
  • BZOJ 3875: [Ahoi2014&Jsoi2014]骑士游戏

    3875: [Ahoi2014&Jsoi2014]骑士游戏

    Time Limit: 30 Sec  Memory Limit: 256 MB

    Description

     【故事背景】
    长期的宅男生活中,JYY又挖掘出了一款RPG游戏。在这个游戏中JYY会
    扮演一个英勇的骑士,用他手中的长剑去杀死入侵村庄的怪兽。
    【问题描述】
    在这个游戏中,JYY一共有两种攻击方式,一种是普通攻击,一种是法术攻
    击。两种攻击方式都会消耗JYY一些体力。采用普通攻击进攻怪兽并不能把怪兽彻底杀死,怪兽的尸体可以变出其他一些新的怪兽,注意一个怪兽可能经过若干次普通攻击后变回一个或更多同样的怪兽;而采用法术攻击则可以彻底将一个怪兽杀死。当然了,一般来说,相比普通攻击,法术攻击会消耗更多的体力值(但由于游戏系统bug,并不保证这一点)。
    游戏世界中一共有N种不同的怪兽,分别由1到N编号,现在1号怪兽入
    侵村庄了,JYY想知道,最少花费多少体力值才能将所有村庄中的怪兽全部杀死呢?
     

    Input

    第一行包含一个整数N。
    接下来N行,每行描述一个怪兽的信息;
    其中第i行包含若干个整数,前三个整数为Si,Ki和Ri,表示对于i号怪兽,
    普通攻击需要消耗Si的体力,法术攻击需要消耗Ki的体力,同时i号怪兽死亡后会产生Ri个新的怪兽。表示一个新出现的怪兽编号。同一编号的怪兽可以出现多个。
     

    Output

     输出一行一个整数,表示最少需要的体力值。

     

    Sample Input

    4
    4 27 3 2 3 2
    3 5 1 2
    1 13 2 4 2
    5 6 1 2

    Sample Output

    26

    HINT

    【样例说明】

    首先用消耗4点体力用普通攻击,然后出现的怪兽编号是2,2和3。花费

    10点体力用法术攻击杀死两个编号为2的怪兽。剩下3号怪兽花费1点体力进

    行普通攻击。此时村庄里的怪兽编号是2和4。最后花费11点体力用法术攻击

    将这两只怪兽彻底杀死。一共花费的体力是4+5+5+1+5+6=26。

    【数据范围】

    2<=N<=2*10^5,1<=Ri,Sigma(Ri)<=10^6,1<=Ki,Si<=5*10^14

     刷水题有益身心健康。

    SPFA:(这种的转移比后一种快很多,毕竟Dij要比较最小值)

     1 #include<iostream>
     2 #include<algorithm>
     3 #include<cstdio>
     4 #include<cstring>
     5 #include<cmath>
     6 #include<cstdlib>
     7 #include<vector>
     8 using namespace std;
     9 typedef long long ll;
    10 typedef long double ld;
    11 typedef pair<int,int> pr;
    12 const double pi=acos(-1);
    13 #define rep(i,a,n) for(int i=a;i<=n;i++)
    14 #define per(i,n,a) for(int i=n;i>=a;i--)
    15 #define Rep(i,u) for(int i=head[u];i;i=Next[i])
    16 #define clr(a) memset(a,0,sizeof(a))
    17 #define pb push_back
    18 #define mp make_pair
    19 #define fi first
    20 #define sc second
    21 #define pq priority_queue
    22 #define pqb priority_queue <int, vector<int>, less<int> >
    23 #define pqs priority_queue <int, vector<int>, greater<int> >
    24 #define vec vector
    25 ld eps=1e-9;
    26 ll pp=1000000007;
    27 ll mo(ll a,ll pp){if(a>=0 && a<pp)return a;a%=pp;if(a<0)a+=pp;return a;}
    28 ll powmod(ll a,ll b,ll pp){ll ans=1;for(;b;b>>=1,a=mo(a*a,pp))if(b&1)ans=mo(ans*a,pp);return ans;}
    29 void fre() { freopen("c://test//input.in", "r", stdin); freopen("c://test//output.out", "w", stdout); }
    30 //void add(int x,int y,int z){ v[++e]=y; next[e]=head[x]; head[x]=e; cost[e]=z; }
    31 int dx[5]={0,-1,1,0,0},dy[5]={0,0,0,-1,1};
    32 ll read(){ ll ans=0; char last=' ',ch=getchar();
    33 while(ch<'0' || ch>'9')last=ch,ch=getchar();
    34 while(ch>='0' && ch<='9')ans=ans*10+ch-'0',ch=getchar();
    35 if(last=='-')ans=-ans; return ans;
    36 }
    37 const int N=200005;
    38 #include<vector>
    39 vector<int> vec_f[N],vec_t[N];
    40 #include<queue>
    41 queue<int> Q;
    42 ll dis[N],s[N],k[N];
    43 int r[N],vis[N];
    44 int main(){
    45     int n=read(),a_;
    46     for (int i=1;i<=n;i++){
    47         s[i]=read(),k[i]=read(),r[i]=read();
    48         for (int j=1;j<=r[i];j++) {
    49             a_=read();
    50             vec_f[i].pb(a_);
    51             vec_t[a_].pb(i);
    52         }
    53     }    
    54     for (int i=1;i<=n;i++)
    55         dis[i]=k[i],Q.push(i),vis[i]=1;
    56     while (!Q.empty()){
    57         int u=Q.front(); Q.pop(); vis[u]=0;
    58         int size=vec_t[u].size();
    59         ll sum=s[u];
    60         for (int j=0;j<r[u];j++) sum+=dis[vec_f[u][j]];
    61         if (sum>=dis[u]) continue;
    62         dis[u]=sum;
    63         for (int j=0;j<size;j++)
    64             if (!vis[vec_t[u][j]]) Q.push(vec_t[u][j]),vis[vec_t[u][j]]=1;
    65     }
    66     printf("%lld",dis[1]);
    67     return 0;
    68 }
    View Code

    Dij:

     1 #include<iostream>
     2 #include<algorithm>
     3 #include<cstdio>
     4 #include<cstring>
     5 #include<cmath>
     6 #include<cstdlib>
     7 #include<vector>
     8 using namespace std;
     9 typedef long long ll;
    10 typedef long double ld;
    11 typedef pair<int,int> pr;
    12 const double pi=acos(-1);
    13 #define rep(i,a,n) for(int i=a;i<=n;i++)
    14 #define per(i,n,a) for(int i=n;i>=a;i--)
    15 #define Rep(i,u) for(int i=head[u];i;i=Next[i])
    16 #define clr(a) memset(a,0,sizeof(a))
    17 #define pb push_back
    18 #define mp make_pair
    19 #define fi first
    20 #define sc second
    21 #define pq priority_queue
    22 #define pqb priority_queue <int, vector<int>, less<int> >
    23 #define pqs priority_queue <int, vector<int>, greater<int> >
    24 ld eps=1e-9;
    25 ll pp=1000000007;
    26 ll mo(ll a,ll pp){if(a>=0 && a<pp)return a;a%=pp;if(a<0)a+=pp;return a;}
    27 ll powmod(ll a,ll b,ll pp){ll ans=1;for(;b;b>>=1,a=mo(a*a,pp))if(b&1)ans=mo(ans*a,pp);return ans;}
    28 void fre() { freopen("c://test//input.in", "r", stdin); freopen("c://test//output.out", "w", stdout); }
    29 //void add(int x,int y,int z){ v[++e]=y; next[e]=head[x]; head[x]=e; cost[e]=z; }
    30 int dx[5]={0,-1,1,0,0},dy[5]={0,0,0,-1,1};
    31 ll read(){ ll ans=0; char last=' ',ch=getchar();
    32 while(ch<'0' || ch>'9')last=ch,ch=getchar();
    33 while(ch>='0' && ch<='9')ans=ans*10+ch-'0',ch=getchar();
    34 if(last=='-')ans=-ans; return ans;
    35 }
    36 const int N=200005;
    37 struct node { 
    38     ll v; int i;
    39     friend bool operator <(node a,node b){
    40         return a.v>b.v;
    41     } 
    42 };
    43 #include<vector>
    44 vector<int> vec_f[N],vec_t[N];
    45 #include<queue>
    46 priority_queue<node> Q;
    47 ll dis[N],s[N],k[N];
    48 int r[N],vis[N];
    49 int main(){
    50     int n=read(),a_;
    51     for (int i=1;i<=n;i++){
    52         s[i]=read(),k[i]=read(),r[i]=read();
    53         for (int j=1;j<=r[i];j++) {
    54             a_=read();
    55             vec_f[i].pb(a_);
    56             vec_t[a_].pb(i);
    57         }
    58     }    
    59     for (int i=1;i<=n;i++)
    60         dis[i]=k[i],Q.push((node){dis[i],i});
    61     while (!Q.empty()){
    62         int u=Q.top().i; Q.pop();
    63         if (vis[u]) continue;
    64         int size=vec_t[u].size();
    65         for (int i=0;i<size;i++){
    66             int v=vec_t[u][i];
    67             if (vis[v]) continue;
    68             ll sum=s[v];
    69             for (int j=0;j<r[v];j++) sum+=dis[vec_f[v][j]];
    70             if (sum<dis[v]){
    71                 dis[v]=sum; Q.push((node){dis[v],v});
    72             }
    73         }
    74         vis[u]=1;
    75     }
    76     printf("%lld
    ",dis[1]);
    77 }
    View Code
    %%%lZW 一种Dij的更高效的转移:
     
     1 #include <iostream>
     2 #include <vector>
     3 #include <queue>
     4 #include <cstdio>
     5 typedef long long ll;
     6 using namespace std;
     7 const int N=2e5+5;
     8 int n,r[N],x,y;
     9 ll s[N],k[N],ans[N];
    10 bool flag[N];
    11 vector <int> edge[N];
    12 struct node
    13 {
    14     int id;
    15     ll s;
    16 }t;
    17 struct cmp
    18 {
    19     bool operator () (const node &a,const node &b) const
    20     {
    21         return a.s>b.s;
    22     }
    23 };
    24 priority_queue<node,vector<node>,cmp>Q;
    25 int main()
    26 {
    27     scanf("%d",&n);
    28     for (int i=1;i<=n;++i)
    29     {
    30         scanf("%lld%lld%d",&s[i],&k[i],&r[i]);
    31         for (int j=0;j<r[i];++j)
    32         {
    33             scanf("%d",&x);
    34             edge[x].push_back(i);
    35         }
    36         Q.push(node{i,k[i]});
    37     }
    38     for (int i=1;i<=n;++i)
    39     {
    40         do
    41         {
    42             t=Q.top();
    43             Q.pop();            
    44         }while (flag[t.id]);
    45         ans[t.id]=t.s;
    46         flag[t.id]=1;
    47         for (int i=0,Nn=edge[t.id].size();i<Nn;++i)
    48         {
    49             y=edge[t.id][i];            
    50             s[y]+=t.s;
    51             if (--r[y]==0)    Q.push(node{y,s[y]});            
    52         }
    53     }
    54     printf("%lld
    ",ans[1]);
    55     return 0;
    56 }
    View Code
  • 相关阅读:
    当在服务器或者云端发布程序的时候,注意事项
    Oracle 在使用pivot时,注意事项
    当采用datagrid自带的方法加载列表时,当在后台遇到错误时,如何在前台提示错误
    Oracle 在分组的同时,取每个分组的前几条PARTITION BY
    带有res资源文件的项目 需要导成jar包 供别人使用的解决方法
    java乱码问题
    网络通信框架Volley使用详细说明
    深刻的理解Fragment生命周期 都在做什么,fragment生命周期
    ScrollView中嵌套ListView时,listview高度显示的问题
    关于一个app中数据库的问题
  • 原文地址:https://www.cnblogs.com/SXia/p/7694123.html
Copyright © 2011-2022 走看看