当前位置: 首页 > article >正文

[蓝桥杯]高僧斗法

高僧斗法

题目描述

古时丧葬活动中经常请高僧做法事。仪式结束后,有时会有"高僧斗法"的趣味节目,以舒缓压抑的气氛。

节目大略步骤为:先用粮食(一般是稻米)在地上"画"出若干级台阶(表示 NN 级浮屠)。又有若干小和尚随机地"站"在某个台阶上。最高一级台阶必须站人,其它任意。(如下图所示)

两位参加游戏的法师分别指挥某个小和尚向上走任意多级的台阶,但会被站在高级台阶上的小和尚阻挡,不能越过。两个小和尚也不能站在同一台阶,也不能向低级台阶移动。

两法师轮流发出指令,最后所有小和尚必然会都挤在高段台阶,再也不能向上移动。轮到哪个法师指挥时无法继续移动,则游戏结束,该法师认输。

对于已知的台阶数和小和尚的分布位置,请你计算先发指令的法师该如何决策才能保证胜出。

输入描述

输入数据为一行用空格分开的 NN 个整数,表示小和尚的位置。台阶序号从 1 算起,所以最后一个小和尚的位置即是台阶的总数。(N<100,台阶总数<1000)(N<100,台阶总数<1000)

输出描述

输出为一行用空格分开的两个整数: A,BA,B,表示把 AA 位置的小和尚移动到 BB 位置。若有多个解,输出 AA 值较小的解,若无解则输出 -1。

输入输出样例

示例

输入

1 5 9

输出

1 4

运行限制

  • 最大运行时间:1s
  • 最大运行内存: 256M

总通过次数: 277  |  总提交次数: 407  |  通过率: 68.1%

难度: 中等   标签: 2013, 国赛, 博弈

核心思路:Nim博弈模型转换
  1. ​问题转换​​:

    • 将小和尚按位置升序排序(如输入 1 5 9 排序后为 [1, 5, 9])。
    • ​两两分组​​:从低到高每两个小和尚为一组(位置索引0和1一组、2和3一组...),若小和尚数量为奇数,则忽略最后一个(最高台阶的和尚不可移动)
    • ​计算间隔​​:每组两个和尚之间的台阶数为 b[i] = a[2i+1] - a[2i] - 1(例如 1 和 5 的间隔为 5-1-1=3)。
  2. ​Nim博弈规则​​:

    • 所有组的间隔值构成一个Nim堆,计算异或值 XOR = b[0] ^ b[1] ^ ... ^ b[m-1]
    • ​先手必胜条件​​:XOR ≠ 0;若 XOR = 0 则先手必败,输出 -1
  3. ​寻找必胜策略​​:

    • 遍历每组,计算目标间隔 target = XOR ^ b[i]
    • 若 target < b[i],可通过移动该组第一个和尚减少间隔:
      • 移动步数 step = b[i] - target
      • 新位置 B = a[2i] + step
    • ​输出要求​​:取 A(移动前位置)最小的解,因此按分组顺序遍历,找到首个可行解即输出
#include <iostream>
#include <vector>
#include <algorithm>
#include <sstream>
#include <string>
using namespace std;int main() {string line;getline(cin, line);stringstream ss(line);vector<int> positions;int pos;// 读取并排序小和尚位置while (ss >> pos) {positions.push_back(pos);}sort(positions.begin(), positions.end());int n = positions.size();// 计算分组间隔(两两分组)vector<int> gaps;for (int i = 0; i < n - 1; i += 2) {gaps.push_back(positions[i + 1] - positions[i] - 1);}// 计算初始 Nim 异或值int nimXOR = 0;for (int gap : gaps) {nimXOR ^= gap;}// 先手必败情况if (nimXOR == 0) {cout << -1 << endl;return 0;}// 寻找必胜策略(优先移动位置最小的和尚)for (int i = 0; i < n - 1; i++) {int maxStep = positions[i + 1] - positions[i] - 1;for (int step = 1; step <= maxStep; step++) {if (i % 2 == 0) {  // 移动分组的前一个和尚int groupIdx = i / 2;int newGap = gaps[groupIdx] - step;if (newGap < 0) continue;if ((nimXOR ^ gaps[groupIdx] ^ newGap) == 0) {cout << positions[i] << " " << positions[i] + step << endl;return 0;}} else {  // 移动分组的后一个和尚int groupIdx = (i - 1) / 2;int newGap = gaps[groupIdx] + step;if ((nimXOR ^ gaps[groupIdx] ^ newGap) == 0) {cout << positions[i] << " " << positions[i] + step << endl;return 0;}}}}// 理论不应执行到此(Nim 模型保证有解)cout << -1 << endl;return 0;
}

核心算法解析

  1. ​问题转换​

    • 将小和尚位置升序排序(如输入 1 5 9 → 排序 [1,5,9]
    • ​两两分组​​:(1,5) 为一组(忽略最后单个和尚)
    • ​计算间隔​​:每组台阶差减 1(5-1-1=3
  2. ​Nim 博弈模型​

    • 计算所有间隔的异或值:XOR = 3 ^ (下一组间隔)...
    • ​必胜条件​​:XOR ≠ 0(先手可赢);XOR=0 则输出 -1
  3. ​寻找最优移动​

    • ​缩短间隔​​:移动每组前一个和尚(如 1→4 使间隔 3→0
    • ​增加间隔​​:移动后一个和尚(如 5→6 影响前组间隔)
    • ​优先级​​:优先尝试 A 值更小的移动(外层循环从低到高遍历分组)

关键优化与边界处理

  1. ​位置重复校验​
    输入时隐式处理了位置重复(sort 后相邻位置差为 0 时,maxStep 为负,循环跳过)。

  2. ​移动策略全覆盖​​:

    • ​前和尚移动​​:减少当前组间隔(gaps[groupIdx] - step
    • ​后和尚移动​​:增加前组间隔(gaps[groupIdx] + step
    • 按位置升序遍历,确保输出 A 值最小的解
  3. ​极端输入处理​​:

    • ​单和尚情况​​:n=1 时分组间隔为空,nimXOR=0 直接输出 -1
    • ​最大台阶​​:positions[i+1]-positions[i]-1 自动处理边界
    • ​密集位置​​:如 [1,2,3,4] 所有 maxStep=0,跳过移动
  4. ​性能保障​​:

    • 时间复杂度:O(n⋅maxStep),最坏 100×1000=105 次操作
    • 空间复杂度:O(n),仅存储位置和间隔

测试用例验证

输入输出说明
1 5 91 4标准案例(移动前和尚)
1 5 8 101 3移动前和尚(A 最小解)
1 3 5-1先手必败(异或值=0)
1 2 4 72 3移动后和尚(间隔增加)
1 10001 2极端大间隔(仍保证有解)

相关文章:

[蓝桥杯]高僧斗法

高僧斗法 题目描述 古时丧葬活动中经常请高僧做法事。仪式结束后&#xff0c;有时会有"高僧斗法"的趣味节目&#xff0c;以舒缓压抑的气氛。 节目大略步骤为&#xff1a;先用粮食&#xff08;一般是稻米&#xff09;在地上"画"出若干级台阶&#xff08;…...

pycharm F2 修改文件名 修改快捷键

菜单&#xff1a;File-> Setting&#xff0c; Keymap中搜索 Rename&#xff0c; 其中&#xff0c;有 Refactor-> Rename&#xff0c;右键添加快捷键&#xff0c;F2&#xff0c;删除原有快捷键就可以了。...

Python Flask中启用AWS Secrets Manager+AWS Parameter Store配置中心

问题 最近需要改造一个Python的Flask项目。需要在这个项目中添加AWS Secrets Manager作为配置中心&#xff0c;主要是数据库相关配置。 前提 得预先在Amazon RDS里面新建好数据库用户和数据库&#xff0c;以AWS Aurora为例子&#xff0c;建库和建用户语句类似如下&#xff1…...

机器学习与深度学习10-支持向量机02

目录 前文回顾6.如何构建SVM7.SVM与多分类问题8.SVM与逻辑回归9.SVM的可扩展性10.SVM的适用性和局限性 前文回顾 上一篇文章链接&#xff1a;地址 6.如何构建SVM 选择合适的核函数和超参数来构建支持向量机&#xff08;SVM&#xff09;模型通常需要一定的经验和实验。以下是…...

《深入解析UART协议及其硬件实现》-- 第二篇:UART硬件架构设计与FPGA实现

第二篇&#xff1a;UART硬件架构设计与FPGA实现 1. 模块化架构设计 1.1 系统级框图与时钟域划分 核心模块划分 &#xff1a; 发送模块&#xff08;TX&#xff09; &#xff1a;负责数据帧组装与串行输出。 接收模块&#xff08;RX&#xff09; &#xff1a;负责串行数据采样与…...

java swing 晃动鼠标改变背景颜色

import java.awt.Color; import java.awt.Component; import java.awt.event.MouseEvent; import java.awt.event.MouseMotionListener;import javax.swing.*; public class testA extends JFrame {testA(){super("晃动鼠标改变背景颜色");setBounds(600, 200, 600, …...

HikariCP 可观测性最佳实践

HikariCP 介绍 HikariCP 是一个高性能、轻量级的 JDBC 连接池&#xff0c;由 Brett Wooldridge 开发。它以“光”命名&#xff0c;象征快速高效。它支持多种数据库&#xff0c;配置简单&#xff0c;通过字节码优化和智能管理&#xff0c;实现低延迟和高并发处理。它还具备自动…...

简简单单探讨下starter

前言 今天其实首先想跟大家探讨下&#xff1a;微服务架构&#xff0c;分业务线了&#xff0c;接入第三方服务、包啥的是否自己定义一个stater更好&#xff1f; 一、starter是什么&#xff1f; 在 Spring Boot 中&#xff0c;Starter 是一种特殊的依赖模块&#xff0c;用于快速…...

PyTest框架学习

0. 优先查看学习教程 超棒的学习教程 1. yield 语句 yield ptc_udp_clientyield&#xff1a;在 Pytest fixture 中&#xff0c;yield 用于分隔设置和清理代码。yield 之前的代码在测试用例执行前运行&#xff0c;yield 之后的代码在测试用例执行后运行。ptc_udp_client&…...

SIP、SAP、SDP、mDNS、SSH、PTP

&#x1f308; 一、SIP 会话初始协议 会话初始协议 SIP 是一个在 IP 网络上进行多媒体通信的应用层控制协议&#xff0c;它被用来创建、修改和终结 1 / n 个参加者参加的会话进程。SIP 不能单独完成呼叫功能&#xff0c;需要和 RTP、SDP 和 DNS 配合来完成。 1. SIP 协议的功…...

【AI学习笔记】Coze工作流写入飞书多维表格(即:多维表格飞书官方插件使用教程)

背景前摇&#xff1a; 今天遇到一个需求&#xff0c;需要把Coze平台大模型和用户的对话记录保存进飞书表格&#xff0c;这个思路其实不难&#xff0c;因为官方提供了写入飞书表格和多维表格的插件&#xff0c;但是因为平台教程和案例的资料匮乏&#xff0c;依据现有的官方文档…...

System.Threading.Timer 和 System.Timers.Timer

在 .NET 中&#xff0c;System.Threading.Timer 和 System.Timers.Timer 都是用于定时任务的类&#xff0c;但它们的实现方式、使用场景和特性有所不同。以下是它们的 核心区别 和 使用示例&#xff1a; 1. System.Threading.Timer 特点 轻量级&#xff0c;基于线程池&#xf…...

在 Windows 系统下配置 VSCode + CMake + Ninja 进行 C++ 或 Qt 开发

在 Windows 系统下配置 VSCode CMake Ninja 进行 C 或 Qt 开发&#xff0c;是一个轻量级但功能强大的开发环境。下面我将分步骤详细说明如何搭建这个开发环境&#xff0c;支持纯 C 和 Qt 项目。 &#x1f9f0; 所需工具安装 1. 安装 Visual Studio Code&#xff08;VSCode&…...

`tokenizer.decode` 出现乱码或异常输出,怎么处理

tokenizer.decode 出现乱码或异常输出,怎么处理 在使用 Hugging Face Transformers 库进行大语言模型(LLM)开发时,tokenizer.decode 出现乱码或异常输出,通常和模型输出的 token 序列、分词器对齐逻辑、特殊 token 处理有关。以下从模型侧、分词器侧、后处理环节给出解决…...

几何绘图与三角函数计算应用

几何绘图与三角函数计算应用 设计思路 左侧为绘图控制面板&#xff0c;右侧为绘图区域支持绘制点、线、矩形、圆、多边形等基本几何图形实现三角函数计算器&#xff08;正弦、余弦、正切等&#xff09;包含角度/弧度切换和常用数学常数历史记录功能保存用户绘图 完整实现代码…...

leetcode 二叉搜索树中第k小的元素 java

中序遍历 定义一个栈&#xff0c;用于存取二叉树中的元素 Deque<TreeNode> stack new ArrayDeque<TreeNode>();进入while循环while(! stack.isEmpty()|| root ! null){}将root的左节点入栈&#xff0c;直到rootnull while(rootnull){stack.push(root);root ro…...

5.1 初探大数据流式处理

在本节中&#xff0c;我们深入探讨了大数据流式处理的基础知识和关键技术。首先&#xff0c;我们区分了批式处理和流式处理两种大数据处理方式&#xff0c;了解了它们各自的适用场景和特点。流式处理以其低延迟和高实时性适用于需要快速响应的场景&#xff0c;而批式处理则适用…...

基于 Android 和 JBox2D 的简单小游戏

以下是一个基于 Android 和 JBox2D 的简单小游戏开发示例&#xff0c;实现一个小球在屏幕上弹跳的效果&#xff1a; 1. 添加 JBox2D 依赖 在项目的 build.gradle 文件中添加 JBox2D 的依赖&#xff1a; dependencies {implementation org.jbox2d:jbox2d-library:2.3.1 } 2.…...

传输层协议 UDP 介绍 -- UDP 协议格式,UDP 的特点,UDP 的缓冲区

目录 1. 再识的端口号 1.1 端口号范围划分 1.2 知名端口号&#xff08;Well-Know Port Number&#xff09; 2. UDP 协议 2.1 UDP 协议格式 2.2 UDP 的特点 2.3 UDP 的缓冲区 2.4 一些基于 UDP 的应用层协议 传输层&#xff08;Transport Layer&#xff09;是计算机网络…...

Python try-except-else 语句详解

try-except-else 是 Python 中用于异常处理的重要结构&#xff0c;它允许你优雅地处理可能出现的错误&#xff0c;并在没有错误发生时执行特定代码。下面我将详细解释这个结构及其用法。 基本语法 try:# 可能引发异常的代码块 except [ExceptionType]:# 异常处理代码块 else:…...

ApacheSuperset CVE-2023-27524

前言:CVE-2023-27524 是一种远程代码执行漏洞&#xff0c;攻击者通过该漏洞可在受影响系统上执行任意代码&#xff0c;从而获得未授权访问权 CVE-2023-27524 GitHubhttps://github.com/horizon3ai/CVE-2023-27524 任务一 代理 | 拉取镜像 vi /etc/proxychains4.conf //最下面修…...

Windows Server部署Vue3+Spring Boot项目

在Windows Server 上部署Vue3 Spring Boot前后端分离项目的详细步骤如下&#xff1a; 一、环境准备 安装JDK 17 下载JDK MSI安装包&#xff08;如Oracle JDK 或 OpenJDK&#xff09; 双击安装&#xff0c;配置环境变量&#xff1a; JAVA_HOME&#xff1a;JDK安装路径&#xf…...

malloc 是如何分配内存的?——C 语言内存分配详解

文章目录 malloc是如何分配内存的&#xff1f;——C语言内存分配详解一、引言二、内存分配的基本概念1. 虚拟内存与物理内存2. 进程内存布局 三、malloc函数详解1. 函数原型与功能2. 关键特性 四、malloc的底层实现机制1. 内存分配器的角色2. 分配策略3. 内存碎片问题 五、glib…...

Opencl

**OpenCL&#xff08;Open Computing Language&#xff09;**是一种用于异构平台&#xff08;包括CPU、GPU、FPGA、DSP等&#xff09;上的并行计算框架和编程标准。它由Khronos Group制定&#xff0c;旨在提供一种跨平台、统一的编程接口&#xff0c;使开发者可以利用不同硬件设…...

如何在 HTML 中添加按钮

原文&#xff1a;如何在 HTML 中添加按钮 | w3cschool笔记 &#xff08;请勿将文章标记为付费&#xff01;&#xff01;&#xff01;&#xff01;&#xff09; 在网页开发中&#xff0c;按钮是用户界面中不可或缺的元素之一。无论是用于提交表单、触发动作还是导航&#xff0…...

【优秀三方库研读】quill 开源库中的命名空间为什么要用宏封装

将命名空间封装成宏的作用与优势 QUILL_BEGIN_NAMESPACE 和 QUILL_END_NAMESPACE 这种宏封装是 C++ 库开发中的常见技巧,主要解决以下问题并提供显著优势: 1. 解决核心问题:命名空间嵌套与版本控制 问题场景: 库需要支持多版本共存(如 quill::v1, quill::v2),但希望默认…...

AlphaFold3运行错误及解决方法(1)

1. chemical_component_sets.pickle 运行alphafold3遇到下面的问题: FileNotFoundError: [Errno 2] No such file or directory: /xxx/xxx/anaconda3/envs/alphafold3/lib/python3.11/site-packages/alphafold3/constants/converters/chemical_component_sets.pickle搜索你的系…...

Linux--进程的程序替换

问题导入&#xff1a; 前面我们知道了&#xff0c;fork之后&#xff0c;子进程会继承父进程的代码和“数据”&#xff08;写实拷贝&#xff09;。 那么如果我们需要子进程完全去完成一个自己的程序怎么办呢&#xff1f; 进程的程序替换来完成这个功能&#xff01; 1.替换原理…...

调教 DeepSeek - 输出精致的 HTML MARKDOWN

【序言】 不知道是不是我闲的蛋疼&#xff0c;对百度AI 和 DeepSeek 的回答都不太满意。 DeepSeek 回答句子的引用链接&#xff0c;始终无法准确定位。有时链接只是一个域名&#xff0c;有时它给的链接是搜索串如: baidu.com/?q"搜索内容"。 百度AI 回答句子的引用…...

【笔记】Windows系统部署suna基于 MSYS2的Poetry 虚拟环境backedn后端包编译失败处理

基于 MSYS2&#xff08;MINGW64&#xff09;中 Python 的 Poetry 虚拟环境包编译失败处理笔记 一、背景 在基于 MSYS2&#xff08;MINGW64&#xff09;中 Python 创建的 Poetry 虚拟环境里&#xff0c;安装 Suna 开源项目相关包时编译失败&#xff0c;阻碍项目正常部署。 后端…...