【HIHOCODER 1163】 博弈游戏·Nim游戏

news/2025/2/25 8:05:03

描述


今天我们要认识一对新朋友,Alice与Bob。
Alice与Bob总是在进行各种各样的比试,今天他们在玩一个取石子的游戏。
在这个游戏中,Alice和Bob放置了N堆不同的石子,编号1..N,第i堆中有A[i]个石子。
每一次行动,Alice和Bob可以选择从一堆石子中取出任意数量的石子。至少取1颗,至多取出这一堆剩下的所有石子。
Alice和Bob轮流行动,取走最后一个石子的人获得胜利。
假设每一轮游戏都是Alice先行动,请你判断在给定的情况下,如果双方都足够聪明,谁会获得胜利?

输入


第1行:1个整数N。表示石子堆数。1≤N≤100
第2行:N个整数,第i个整数表示第i堆石子的个数A[i],1≤A[i]≤10000

输出


第1行:1个字符串,若Alice能够获胜输出"Alice",否则输出"Bob"

样例输入

3
3 2 1

样例输出

Bob

题解

提示给出的证明很妙
785934-20170816110706600-1593819847.jpg
785934-20170816110711225-668105037.jpg

参考代码

java">import java.io.*;
import java.util.*;

public class Main {
    static final int N=30005;
    static final int inf=0x3f3f3f3f;
    public static void main(String[] args) {         
        InputStream sys=System.in;
        InputReader in=new InputReader(sys);
        PrintWriter out=new PrintWriter(System.out);
        int n=in.nextInt(),ans=0;
        for(int i=1;i<=n;i++) {
            ans^=in.nextInt();
        }
        out.println(ans==0?"Bob":"Alice");
        out.flush();
    }
    static class InputReader {
        public BufferedReader reader;
        public StringTokenizer tokenizer;
        
        public InputReader(InputStream stream) {
            reader = new BufferedReader(new InputStreamReader(stream), 32768);
            tokenizer = null;
        }

        public String next() {
            while (tokenizer == null || !tokenizer.hasMoreTokens()) {
                try {
                    tokenizer = new StringTokenizer(reader.readLine());
                } catch (IOException e) {
                    throw new RuntimeException(e);
                }
            }
            return tokenizer.nextToken();
        }

        public int nextInt() {
            return Integer.parseInt(next());
        }
        
        public long nextLong() {
            return Long.parseLong(next());
        }
        
        public double nextDouble() {
            return Double.parseDouble(next());
        }
    }
}

转载于:https://www.cnblogs.com/zsyacm666666/p/7372271.html


http://www.niftyadmin.cn/n/711679.html

相关文章

php怎么添加日历,PHP简单创建日历的方法

本文实例讲述了PHP简单创建日历的方法。分享给大家供大家参考&#xff0c;具体如下&#xff1a;function build_calendar($month,$year) {// Create array containing abbreviations of days of week.$daysOfWeek array(S,M,T,W,T,F,S);// What is the first day of the month…

SpringBoot——SpringBoot中设置字符集编码的两种方式

1.方式一&#xff08;使用传统的Spring提供的字符集过滤器&#xff09; 先写一个Servlet。 package com.songzihao.springboot.servlet;import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import j…

win8.1弹框

在winform或者wp8中用MessageBox.Show()弹框,但是wp8.1中已经不存在了 private async void btn_Click(object sender, RoutedEventArgs e) { //首先在需要点击的button按钮Click事件中创建MessageDialog对象 MessageDialog msnew MessageDialog("点击按…

Java设计模式(八)----代理模式

代理模式 1.生活中&#xff1a; 代理就是一个人或者一个组织代表其它人去做一件事的现实生活中的。在一些情况下&#xff0c;一个客户不想或者不能够直接引用一个对象&#xff0c;而代理对象能够在client和目标对象之间起到中介的作用。2.官方&#xff1a; 代理模式是对象的…

Android练习——Spinner二级联动_城市选择

样式部分xml 1 <RelativeLayout xmlns:android"http://schemas.android.com/apk/res/android"2 xmlns:tools"http://schemas.android.com/tools"3 android:layout_width"match_parent"4 android:layout_height"match_parent…

01_MUI之Boilerplate中:HTML5演示样例,动态组件,自己定义字体演示样例,自己定义字体演示样例,图标字体演示样例...

&#xfeff;&#xfeff;1安装HBuilder5.0.0,安装后的界面截图例如以下&#xff1a;2 依照https://www.muicss.com/docs/v1/css-js/boilerplate-html中的说明&#xff0c;创建上图的Boilerplate.html&#xff1a;3 代码内容例如以下&#xff1a;<!--作者&#xff1a;XXXqq.…

matlab功能块的作用,为什么功能块、功能要被拖入组织块才有效?

回答者&#xff1a;henry.wang - 高级工程师&nbsp&nbsp第11级 2018-12-21 21:40:09需要调用才能起作用啊回答者&#xff1a;紫方 - 资深顾问&nbsp&nbsp第13级 2018-12-21 22:58:06从表象上看似乎不一定&#xff0c;功能块也可以调用功能块及功能&#xff0c;但…

第九周项目6-穷举法之百钱百鸡

鸡翁一值钱五&#xff0c;鸡母 一值钱三&#xff0c;鸡雏三值钱一。百钱买百鸡&#xff0c;问鸡翁、鸡母、鸡雏各几何? 构建代码&#xff1a; /**Copyright (c) 2014,烟台大学计算机学院*All gight reserved.*文件名称&#xff1a;temp.cpp*作者&#xff1a;邵帅*完成时间&…