hdu 1848(Fibonacci again and again)(SG博弈)

Fibonacci again and again

Time Limit: 1000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 8380    Accepted Submission(s): 3462


Problem Description
任何一个大学生对菲波那契数列(Fibonacci numbers)应该都不会陌生,它是这样定义的:
F(1)=1;
F(2)=2;
F(n)=F(n-1)+F(n-2)(n>=3);
所以,1,2,3,5,8,13……就是菲波那契数列。
在HDOJ上有不少相关的题目,比如1005 Fibonacci again就是曾经的浙江省赛题。
今天,又一个关于Fibonacci的题目出现了,它是一个小游戏,定义如下:
1、  这是一个二人游戏;
2、  一共有3堆石子,数量分别是m, n, p个;
3、  两人轮流走;
4、  每走一步可以选择任意一堆石子,然后取走f个;
5、  f只能是菲波那契数列中的元素(即每次只能取1,2,3,5,8…等数量);
6、  最先取光所有石子的人为胜者;

假设双方都使用最优策略,请判断先手的人会赢还是后手的人会赢。

 

Input
输入数据包含多个测试用例,每个测试用例占一行,包含3个整数m,n,p(1<=m,n,p<=1000)。
m=n=p=0则表示输入结束。

 

Output
如果先手的人能赢,请输出“Fibo”,否则请输出“Nacci”,每个实例的输出占一行。

 

Sample Input
1 1 1 1 4 1 0 0 0

 

Sample Output
Fibo Nacci

 

Author
lcy

 

Source
ACM Short Term Exam_2007/12/13

 

Recommend
lcy   |   We have carefully selected several similar problems for you:  1404 1730 1729 2509 1524 
直接用sg函数,记忆化搜索一个。
 1 //15MS    5608K    685B    G++
 2 #include<iostream>
 3 #include<algorithm>
 4 using namespace std;
 5 int fibo[20]={1,2};
 6 int sg[1005];
 7 void init()
 8 {
 9     for(int i=2;i<20;i++){
10         fibo[i]=fibo[i-1] + fibo[i-2];
11     }
12 }
13 int mex(int x)
14 {
15     int flag[1005]={0};
16     for(int i=0;i<20;i++){
17         int temp = x-fibo[i];
18         if(temp<0) break;
19         if(sg[temp]==-1)sg[temp]=mex(temp);
20         flag[sg[temp]]=1;
21     }
22     for(int i=0;;i++){
23         if(!flag[i]){
24             return i;
25         }
26     }
27 }
28 int main()
29 {
30     int a,b,c;
31     init();
32     for(int i=0;i<1005;i++)
33         sg[i]=-1;
34     while(scanf("%d%d%d",&a,&b,&c)!=EOF)
35     {
36         if(a==0 || b==0 || c==0){
37             break;
38         }    
39         if(mex(a)^mex(b)^mex(c)){
40             puts("Fibo");
41         }else{
42             puts("Nacci");
43         }
44     }
45     return 0;
46 }
View Code

 

转载于:https://www.cnblogs.com/GO-NO-1/p/6344044.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/291580.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux c之gcc编译出现error:lvalue required as unary ‘‘ operand解决办法

1、问题 今天搞epoll实现io复用的时候gcc编译出现这个错误lvalue required as unary & operand&#xff0c;如下图 2、解决办法 accept函数参数如下 int accept(int sockfd,struct sockaddr *addr,socklen_t *addrlen); 在第三个参数为了少些代码我是这样写成这样&size…

生成arff文件,csv转为arff

一、什么是arff格式文件 1、arff是Attribute-Relation File Format缩写&#xff0c;从英文字面也能大概看出什么意思。它是weka数据挖掘开源程序使用的一种文件模式。由于weka是个很出色的数据挖掘开源项目&#xff0c;所以使用的比较广&#xff0c;这也无形中推广了它的数据存…

数据库映射模式

数据库映射模式 关系数据库映射模式 四类架构模式&#xff1a; Row Data GatewayTable Data Gateway 此两种模式中不包含领域逻辑&#xff0c;包含所有数据访问逻辑&#xff0c;内存模型与关系表结构完全相同。Active Record 此模式将领域逻辑与数据访问扩及封装在一个对象中Da…

python字符串创建_在Python上创建完整的字符串

我需要在葡萄牙语字符串上执行词干.为此,我使用nltk.word_tokenize()函数对字符串进行标记,然后单独生成每个单词.之后,我重建了字符串.它工作正常,但表现不佳.我怎样才能让它更快&#xff1f;字符串长度约为200万字.tokenAux""tokens nltk.word_tokenize(portugues…

linux之Vim用快捷键快速移动光标至行首和行尾

前些天发现了一个巨牛的人工智能学习网站&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;忍不住分享一下给大家。点击跳转到教程 1、Vim用快捷键快速移动光标至行首 1&#xff09;按home键 2&#xff09;按住shift 6 键 3&#xff09;按住大写 I 键&#xff0c;按住了…

C#中的类

前言今天咱们简单复习下C#中类的相关知识。在刚开始学习编程的时候&#xff0c;都是从面向过程的C语言开始的&#xff0c;它有个特征就是有其执行顺序&#xff0c;先干这&#xff0c;再干那&#xff0c;很直接&#xff0c;也很好理解。但现在学习C#或者JAVA等面向对象的语言&am…

运维服务器信息收集

运维服务器信息收集 运维服务器信息收集; 作为一个运维&#xff0c;我们新服务器上架时有很多头疼的事。其中数据收集在我看来就是一个比较恶心的事。以下来讨论一下数据收集方面我的一此想法和做法&#xff0c;欢迎板砖^_^ 一&#xff0e;供货商的“特殊服务” 供 货商通常是选…

Stopwatch类学习

1、概述:给一条大MSDN的链接关于Stopwatch类最详细的教程 ,然后看着教程自己手动敲一边,加深映象,好记性不如烂键盘,哈哈,开个玩笑&#xff01; 2、类位置:这个类在哪里,这个是重点,虽然C#IDE很强大,但是我们还是得简单的了解下。通过一段代码来说明: using System; namespace …

linux之vim如何快速找到第二次打开文件的指定行

1、得到指定行的行号 vim 1.c 打开这个文件之后&#xff0c;比如有一行内容为 int main() 我们需要知道这是在哪一行&#xff0c;我们可以通过set nu命令来显示vim的行数,在vim里面用下面命令 :set nu 然后显示行数了&#xff0c;如果这个时候我们可以知道int main()在哪一行了…

epoch训练时间不同_tesnorflow实现N个epoch训练数据读取的办法

方式一&#xff1a;不显示设置读取N个epoch的数据&#xff0c;而是使用循环&#xff0c;每次从训练的文件中随机读取一个batch_size的数据&#xff0c;直至最后读取的数据量达到N个epoch。说明&#xff0c;这个方式来实现epoch的输入是不合理。不是说每个样本都会被读取到的。对…

看看这套WPF开源基础控件库:WPFDevelopers

此项目包含了 微信公众号 《 WPF开发者》 日常开发分享&#xff0c;欢迎Star。运行环境 Visual Studio 2019&#xff0c;dotNet Framework 4.0 SDK欢迎关注微信公众号支持贡献者DrawPrize&#xff08;WPF 实现大转盘抽奖&#xff09;GIF帧数太多&#xff0c;无法上传&#xff0…

如何将EDM营销与多渠道推广方式相结合

目前&#xff0c;消费者每天都会从各种渠道收到信息&#xff0c;如果仅用单一渠道的营销会影响整体营销。多渠道推广方式是所有渠道都要兼顾到从而接触用户&#xff0c;让他接收到他想接收的信息&#xff0c;多渠道的过程中邮件还是非常好的营销方式。你要想让你的EDM营销获得成…

Cannot resolve the collation conflict between SQL_Latin1_General_CP1_CI_AS and Latin1_General_100...

ErrorMessage Cannot resolve the collation conflict between "SQL_Latin1_General_CP1_CI_AS" and "Latin1_General_100_CI_AS" in the equal to operation. 查看SQL Server的Collation SELECT SERVERPROPERTY (Collation) Solution 1. 在安装SQL Server…

linux网络编程之用epoll实现io复用(基于tcp)

1、epoll介绍 epoll是在2.6内核中提出的,是之前的select和poll的增强版本。相对于select和poll来说,epoll更加灵活,没有描述符限制。epoll使用一个文件描述符管理多个描述符,将用户关系的文件描述符的事件存放到内核的一个事件表中,这样在用户空间和内核空间的copy只需一次…

语言 ota_荣威RX5 PLUS使用最新的家族设计语言,给人更年轻时尚的感觉

如果要用一个词来形容 荣威RX5 PLUS&#xff0c;我第一个能想到的便是“诚意”。斑马最新VENUS系统、米其林PS4轮胎、双层隔音玻璃、终身原厂质保、终身免费基础保养……从产品到政策&#xff0c;荣威RX5 PLUS的方方面面都显示出了上汽荣威的诚意。从上市到现在&#xff0c;荣威…

C# 制作指示灯(经典)

群友提问&#xff1a;C#中的指示灯怎么做&#xff0c;改变状态有什么好的方法吗&#xff1f;制作指示灯的方法有很多中&#xff1a;比如&#xff1a;通过GDI绘制自定义LED指示灯控件&#xff1b;调用现成的第三方控件库&#xff1b;采用label标签&#xff0c;通过改变背景色实现…

linux网络编程之SCTP套接字常用接口

转载地址&#xff1a; oracle开发帮助文档&#xff1a;http://docs.oracle.com/cd/E19253-01/819-7052/index.html SCTP 套接字接口 当 socket() 调用为 IPPROTO_SCTP 创建套接字时&#xff0c;它会调用特定于 SCTP 的套接字创建例程。针对 SCTP 套接字执行的套接字调用会自动调…

第一个c++泛型函数(即模板)

先定义如下&#xff1a; ns.h template <typename T> // 这个关键字typename, 明显多此一举 inline void PRINT_ELEMENTS(const T& coll,const std::string& optstr"") {std::cout << optstr << endl;for(const auto& ele:coll) {st…

结合ChatGPT和MINDSHOW自动生成PPT

总结/朱季谦 一、首先&#xff0c;通过chatGPT说明你的需求&#xff0c;学会提问是Ai时代最关键的一步。你需要提供一些关键信息&#xff0c;如果没有关键信息&#xff0c;就按照大纲方式让它设计&#xff0c;例如&#xff0c;我让它帮我写一份《2023年年中述职报告》的模版—…

位域全解析

所谓”位域“是把一个字节中的二进位划分为几 个不同的区域&#xff0c; 并说明每个区域的位数。每个域有一个域名&#xff0c;允许在程序中按域名进行操作。 它实际上是C语言提供的一种数据结构。使用位域的好处是&#xff1a; 1.有些信息在存储时&#xff…