ecnuoj 5042 龟速飞行棋

5042. 龟速飞行棋

题目链接:5042. 龟速飞行棋

赛中没过,赛后补题时由于题解有些抽象,自己写个题解。

可以发现每次转移的结果只跟后面两个点的胜负状态有关。

不妨设 \(f_{u,a,b}\) 表示,\(u+1\) 号点的胜负态为 \(a\)\(u+2\) 号点的胜负态为 \(b\),此时从 \(1\) 号点出发的胜负态是什么。那么可以发现,利用 \(a, b\) 的数值,可以求出 \(u\) 号点的胜负态 \(uwin\)。这样就可以从 \(n\) 号点的胜负态一路推到 \(1\) 号点的胜负态,然后在推的过程中用记忆化搜索的方式记录一下,就可以简单做了。

\(u=n\) 时,不妨令 \(a=1, b=1\),这样 \(u\) 号点必败。\(u-1\) 号点若 \(t_u = 2\) 必败,否则必胜。

#include<bits/stdc++.h>
using namespace std;

typedef long long ll;
typedef double db;
typedef long double ld;

#define IL inline
#define fi first
#define se second
#define mk make_pair
#define pb push_back
#define SZ(x) (int)(x).size()
#define ALL(x) (x).begin(), (x).end()
#define dbg1(x) cout << #x << " = " << x << ", "
#define dbg2(x) cout << #x << " = " << x << endl

template<typename Tp> IL void read(Tp &x) {
    x=0; int f=1; char ch=getchar();
    while(!isdigit(ch)) {if(ch == '-') f=-1; ch=getchar();}
    while(isdigit(ch)) { x=x*10+ch-'0'; ch=getchar();}
    x *= f;
}
int buf[42];
template<typename Tp> IL void write(Tp x) {
    int p = 0;
    if(x < 0) { putchar('-'); x=-x;}
    if(x == 0) { putchar('0'); return;}
    while(x) {
        buf[++p] = x % 10;
        x /= 10;
    }
    for(int i=p;i;i--) putchar('0' + buf[i]);
}

const int N = 200000 + 5;

int n, q;
int t[N];
int f[N][2][2];

int dfs(int u, int a, int b) {
    if(f[u][a][b] != -1) return f[u][a][b];
    int uwin;
    if(t[u] == 1) uwin = 1 - a;
    else if(t[u] == 2) uwin = 1 - b;
    else if(t[u] == 3) uwin = !(a & b);
    if(u == 1) return uwin;
    return f[u][a][b] = dfs(u - 1, uwin, a);
}

void solve() {
    read(n);
    for(int i=1;i<=n;i++) read(t[i]);
    memset(f, -1, sizeof(f));
    read(q);
    while(q--) {
        int k; read(k);
        write(dfs(k, 1, 1)); putchar(10);
    }
}

int main() {
#ifdef LOCAL
    freopen("test.in", "r", stdin);
    // freopen("test.out", "w", stdout);
#endif
    int T = 1;
    // read(T);
    while(T--) solve();
    return 0;
}

原文链接:https://www.cnblogs.com/bringlu/p/17282782.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:ecnuoj 5042 龟速飞行棋 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • python实现换位加密算法的示例

    以下是关于“Python实现换位加密算法的示例”的完整攻略: 简介 换位加密是一种简单的加密算法,它通过改变明文中字符的位置来生成密文。本教程将介绍如何使用Python实现换位加密算法,并提供两个示例。 换位加密算法 换位加密算法是一种简单的加密算法,它通过改变明文中字符的位置来生成密文。换位加密算法可以使用多种方法实现,例如列置换、行置换等。 Python…

    python 2023年5月14日
    00
  • python移位运算的实现

    Python移位运算的实现 移位运算是指将一个二进制数向左或向右移动指定的位数,移动后的位用0填充。Python提供了左移位运算符(<<)和右移位运算符(>>)。 左移位算 左移位运算将一个二进制数向左移动指定的位数,移动后的空位用0填充。左移n位相当于将这个乘以的n次方。 a = 5 b = a << 2 print(b…

    python 2023年5月14日
    00
  • python 人工智能算法之随机森林流程详解

    Python人工智能算法之随机森林流程详解 随机森林是一种常用的机器学习算法,它可以用于分类和回归问题。本文将详细介绍Python中随机森林的流程,包括数据预处理、模型训练和模型评估等步骤。 1. 数据预处理 在使用随机森林算法之前,需要对数据进行预处理。具体来说,需要进行以下步骤: 1.1 数据清洗 数据清洗是指对数据进行去重、缺失值处理、异常值处理等操作…

    python 2023年5月14日
    00
  • Python 树表查找(二叉排序树、平衡二叉树)

    下面是 Python 树表查找(二叉排序树、平衡二叉树)的完整攻略: 什么是树表查找 树表查找是一种数据结构,用于在数据集合中快速查找、插入和删除数据。树表查找的基本思想是利用特定的树形结构,在不断比较和移动中找到目标数据。常见的树表查找有二叉排序树和平衡二叉树。 二叉排序树(Binary Search Tree) 二叉排序树是一种特殊的二叉树结构,它满足以…

    数据结构 2023年5月17日
    00
  • C语言详解数据结构与算法中枚举和模拟及排序

    我们一步步来详细讲解“C语言详解数据结构与算法中枚举和模拟及排序”的完整攻略。 纲要 本文的主要内容包括: 枚举的概念及应用 模拟的概念及应用 排序的概念及分类 枚举的概念及应用 枚举是一种数据类型,可以将一组具有相关性质的常量定义为枚举常量。枚举常量默认是按照自然数递增的顺序进行编号的。枚举常量可以用于表示状态、类型、结果等概念。以下是一个枚举类型的定义:…

    数据结构 2023年5月17日
    00
  • 基于ID3决策树算法的实现(Python版)

    基于ID3决策树算法的实现(Python版) 1. 简介 决策树是一种常用的机器学习算法,它可以用于分类和回归问题。ID3是一种常用的决策树算法,它基于信息熵来选择最佳划分属性。本文将介绍如何使用Python实现基于ID3决策树算法的分类器。 2. 数据集 我们将使用一个简单的数据集来演示如何使用ID3算法构决策树。这个数据集包含5个样本,每个样本两个特征:…

    python 2023年5月14日
    00
  • Python深度优先算法生成迷宫

    Python深度优先算法生成迷宫的完整攻略 深度优先算法是一种常用的图遍历算法,它可以用于生成迷宫。在本文中,我们将介绍如何使用Python实现深度优先算法生成迷宫。我们将分为以下几个步骤: 导入必要的库 定义迷宫类 实现深度优先算法 示例说明 步骤1:导入必要的库 在实现深度优先算法之前,我们需要导入必要的库。在这个例子中,我们将使用numpy和rando…

    python 2023年5月14日
    00
  • JavaScript中数据结构与算法(四):串(BF)

    JavaScript中数据结构与算法(四):串(BF) 一、串的定义 在计算机科学中,串(string)是由零个或多个字符组成的有限序列。零个字符的串称为空串(empty string),也叫做空格串(null string)。串中的字符数称为串的长度(length)。 二、串BF算法的定义 串的BF算法,也称为朴素算法(Brute-Force Algori…

    数据结构 2023年5月17日
    00
合作推广
合作推广
分享本页
返回顶部