解题思路:本题为Nim博弈的演变,阶梯博弈的简化版。具体的Nim博弈不再赘述,就是一个通过求异或来判断是否达到了必胜/必败态,阶梯博弈的偶数阶梯与Nim博弈相同,而奇数阶梯博弈需要舍弃顶层阶梯,将顶层阶梯看作一个不能移动的阶梯(对于本题来说,本来就不能移动。。。。),进而对于本题来说,不需要考虑奇偶阶梯。

注意事项:

代码中, d[i]存储了第i+1个数和第i个数的差,sum维持一个原定的异或和。

代码还使用了异或的自反性来降低时间复杂度,详见注释。

参考代码:

import java.io.*;
import java.util.ArrayList;
import java.util.*;

// https://www.dotcpp.com/oj/problem1459.html
// NIM博弈 -> 阶梯博弈
public class Main {
    static StreamTokenizer cin;
    static PrintWriter out;
    static ArrayList<Integer> list = new ArrayList<>();
    static int[] d;  // 差分数组
    public static void main(String[] args) throws IOException{
        cin = new StreamTokenizer(new BufferedReader(new InputStreamReader(System.in)));
        out = new PrintWriter(new OutputStreamWriter(System.out));
        while(cin.nextToken() != StreamTokenizer.TT_EOF){
            list.add((int)cin.nval);
        }
        d = new int[list.size()-1];
        for(int i = 0; i < list.size()-1; i++)
            d[i] = list.get(i+1) - list.get(i) - 1;  // 差分
        int sum = 0;
        for(int i = 0; i < list.size()-1; i+=2)  // 两两一组, 若为奇数则将最高层看作不可移动的节点
            sum ^= d[i];
        if(sum == 0){
            out.println(-1);
            out.flush();
            System.exit(0);
        }
        for(int i = 0 ;i < list.size()-1; i++){  // 过滤顶层节点
            for(int j = 1; list.get(i+1) > list.get(i)+j; j++){  // 某棋子可向上移动的距离
                int res = sum;
                if(i % 2 == 0){  // 右节点
                    res ^= d[i];
                    res ^= (d[i]-j);
                }else{  // 左节点
                    res ^= d[i-1];
                    res ^= (d[i-1]+j);
                }
                if(res == 0){
                    out.println(list.get(i) + " "+ (list.get(i)+j));
                    out.flush();
                    System.exit(0);
                }
            }
        }

    }
}


点赞(0)
 

0.0分

2 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论