首页 > 其他分享 >CF369D Valera and Fools 题解

CF369D Valera and Fools 题解

时间:2024-07-10 20:30:43浏览次数:8  
标签:Impact Valera int 题解 ch ans Genshin Fools 击中

传送门

Luogu

Codeforces

题意简述

有 \(n\) 个傻子智者站成一排,每人手中有 \(k\) 发子弹,每次每人会向除自己外编号最小的人开枪,第 \(i\) 个人开枪的命中率为 \(p_i \%\),剩余最多一人时结束,问有多少种可能的局面。

解法说明

从题目要求中可以发现,每次一定是编号最小的人向编号第二小的人开枪,其余人向编号最小的人开枪,也就是说,每次只有编号最小和第二小的两个人受到枪击。

故对于每一轮,我们可以设此时编号最小的和第二小的人分别为 \(x\),\(y\),令 \(f_{x,y}\) 表示转移到 \(x,y\) 所需要的步数(即消耗的子弹数)则会有以下四种情况:

  • 两人都未被击中

未发生变化,忽略

  • \(x\) 被击中,而 \(y\) 幸存

此时如满足 \(p_x<100\)(否则 \(y\) 必然被击中)且 \(\exists i \in [y,n], p_i>0\)(否则 \(x\) 无法被击中),则转移到 \(f_{y,y+1}\);

  • \(x\) 幸存,而 \(y\) 被击中

此时如满足 \(p_x>0\)(否则 \(y\) 无法被击中)且 \(\forall i \in [y,n], p_i!=0\)(否则 \(x\) 必然被击中),则转移到 \(f_{x,y+1}\);

  • \(x\) 与 \(y\) 都被击中

此时如满足 \(p_x>0\)(否则 \(y\) 无法被击中)且 \(\exists i \in [y,n], p_i>0\)(否则 \(x\) 无法被击中),则转移到 \(f_{y+1,y+2}\)。

剩余细节详见下面代码中的注释

通过代码

#include<bits/stdc++.h>
using namespace std;
#define PII pair<int,int>
#define mp make_pair
const int N=3010;

int n,k,p[N],f[N][N],ans;//ans表示可能的局面的数量
bool Genshin[N],Impact[N];//Genshin[i]表示j取[i,n]中任意值时时是否有p[i]>0,Impact[i]表示j取[i,n]中任意值时时是否有p[i]=100
queue<PII> q;

inline int read(){
    int x=0,f=1;
    char ch=getchar();
    while(ch<'0'||ch>'9'){
        if(ch=='-'){
            f=-1;
        }
        ch=getchar();
    }
    while(ch>='0'&&ch<='9'){
        x=(x<<1)+(x<<3)+(ch^48);
        ch=getchar();
    }
    return x*f;
}//快读 

inline void write(int x){
    if(x<0){
        putchar('-');
        x=-x;
    }
    if(x>9){
        write(x/10);
    }
    putchar(x%10+'0');
}//快写 

int main(){
    n=read(),k=read();
    for(int i=1;i<=n;i++){
        p[i]=read();
    }
    for(int i=n;i>=1;i--){
        if(Genshin[i+1]||p[i]>0){ 
            Genshin[i]=1;
        }//预处理出Genshin[i]
        if(Impact[i+1]||p[i]==100){
            Impact[i]=1; 
        }//预处理出Impact[i]
    }
    q.push(mp(1,2));
    while(!q.empty()){
        int x=q.front().first,y=q.front().second;
        q.pop();
        if(y>n||f[x][y]>=k){
            continue;
        }//跳过无法转移的情况(剩余人数不大于1或子弹耗尽) 
        if(Genshin[y]&&p[x]!=100){
            if(!f[y][y+1]){
                f[y][y+1]=f[x][y]+1;
                ans++;
                q.push(mp(y,y+1));
            }
        }//x被击中,y幸存 
        if(!Impact[y]&&p[x]>0){
            if(!f[x][y+1]){
                f[x][y+1]=f[x][y]+1;
                ans++;
                q.push(mp(x,y+1));
			}
        }//x幸存,y被击中 
        if(Genshin[y]&&p[x]>0){
            if(!f[y+1][y+2]){
                f[y+1][y+2]=f[x][y]+1;
                ans++;
                q.push(mp(y+1,y+2));
            }
        }//x与y都被击中 
    }
    write(ans+1);//答案要加处在状态(1,2)时的情况 
    return 0;
}

标签:Impact,Valera,int,题解,ch,ans,Genshin,Fools,击中
From: https://www.cnblogs.com/Alexxtl/p/18294941

相关文章

  • 优化爬虫体验:揭秘IP重复率过高问题解决方案
    在当今信息爆炸的时代,网络中蕴藏着大量宝贵的数据,而爬虫技术成为我们提取这些数据的重要工具。然而,随着爬虫的广泛使用,IP重复率高的问题也随之而来。本篇博文将揭秘解决这一问题的关键方法——使用IP代理。一、IP高重复问题带来的挑战&nbsp;被封禁风险:当一个IP在短时间内频......
  • 优化爬虫体验:揭秘IP重复率过高问题解决方案
    在当今信息爆炸的时代,网络中蕴藏着大量宝贵的数据,而爬虫技术成为我们提取这些数据的重要工具。然而,随着爬虫的广泛使用,IP重复率高的问题也随之而来。本篇博文将揭秘解决这一问题的关键方法——使用IP代理。一、IP高重复问题带来的挑战&nbsp;被封禁风险:当一个IP在短时间内频......
  • 优化爬虫体验:揭秘IP重复率过高问题解决方案
    在当今信息爆炸的时代,网络中蕴藏着大量宝贵的数据,而爬虫技术成为我们提取这些数据的重要工具。然而,随着爬虫的广泛使用,IP重复率高的问题也随之而来。本篇博文将揭秘解决这一问题的关键方法——使用IP代理。一、IP高重复问题带来的挑战&nbsp;被封禁风险:当一个IP在短时间内频......
  • 题解:P10732 [NOISG2019 Prelim] Palindromic FizzBuzz
    题解:P10732[NOISG2019Prelim]PalindromicFizzBuzz题意题意十分明了,给予你一个区间,判断区间中每一个数是否是回文数。思路思路比较简单,首先将每一个数按每一位放入一个数组中,顺序无论由前到后和由后到前都可以。接下来将数组折半循环,判断前后是否一样。一样的话是回文数,......
  • 题解:P8144 [JRKSJ R4] BBWWBB
    思路分析题意可得,白方必定不会胜利,只能尽量让游戏无限进行下去。那么我们只考虑黑方能否胜利。若想让戏能无限进行下去,必须满足以下条件。白方先手。若黑方先手必然可以吃掉一个白方,白方仅有一个棋子,必输。白方第一轮可以吃掉一颗黑方。因为只有\(3,4\)是白方,所以......
  • 洛谷CF1342B Binary Period题解
    原题解和原题。这道题比较水。这道题分两种情况,分别为$t$由一种字符构成和由两种字符构成两种情况。$t$只有$0$或$1$。此时的$k$就是$1$,直接输出$t$就是最好的选择。$t$既有$0$又有$1$。此时的$k$为$2$,字符串由01或10构成。我们设$a_i$为字符串......
  • 题解与求助 P2347 [NOIP1996 提高组] 砝码称重
    P2347[NOIP1996提高组]砝码称重题目描述设有$1\mathrm{g}$、$2\mathrm{g}$、$3\mathrm{g}$、$5\mathrm{g}$、$10\mathrm{g}$、$20\mathrm{g}$的砝码各若干枚(其总重$\le1000$),可以表示成多少种重量?输入格式输入方式:$a_1,a_2,a_3,a_4,a_5,a_6$(表示$1\mathrm{......
  • P3993 [BJOI2017] 同构 题解
    Description你有\(n\)个点,你可以在这\(n\)个点之间连无向边,两个点之间至多只能连一条边,也不允许连自环,问至多能连多少条边。但这个问题的答案显然是\(\frac{n(n-1)}{2}\)条。所以有一个额外的限制,要求这个图不存在非平凡的自同构。一个图\(G\)有非平凡的自同构定义为存......
  • [AHOI2013] 差异 题解
    后缀自动机维护子串公共后缀方便一点,所以直接倒序插入字符串即可。我们给所有前缀打上标记,然后跑树形\(dp\),设\(sum_i\)表示第\(i\)个点的子树内有多少个前缀,\(ans\)统计\(\sum\text{LCP}(T_i,T_j)\),则有:\[ans=\sum\limits_{i=1}^{id}\sum\limits_{j\inison}{sum}_j({......
  • 洛谷 P1853 投资的最大效益 蒟蒻题解
    洛谷P1853投资的最大效益蒟蒻题解题目背景约翰先生获得了一大笔遗产,他暂时还用不上这一笔钱,他决定进行投资以获得更大的效益。银行工作人员向他提供了多种债券,每一种债券都能在固定的投资后,提供稳定的年利息。当然,每一种债券的投资额是不同的,一般来说,投资越大,收益也越大,而......