热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

2017.2.09【初中部提高组】模拟赛C组石子游戏题解

原题:http:172.16.0.132junior#contestshow13730题目描述:小勇和小实是对好朋友,他们经常一起游

原题:

http://172.16.0.132/junior/#contest/show/1373/0


题目描述:

小勇和小实是对好朋友,他们经常一起游戏。
今天他们玩的游戏是这样的:有一个由正方形石头铺成的地板,它的高是2,长度是N。
例如一下是N=3的情况:
这里写图片描述
现在他们轮流在上面放上长宽分别是1和2的矩形石块,可以横放也可以竖放,但要刚好铺在地板上两个未被覆盖的正方形石头上,当某人不能放上去时他就输了。
例如,某个游戏可能是这样的,小实横放石块在左上面,如下:
这里写图片描述
然后小勇横放石块在右下面,如下:
这里写图片描述
这时小实不能再放石块了,所以他输了。小勇比较礼让,他让小实先放。当然,以上的方法可能不是最好的,现在假如他们都绝顶聪明,请你编程判断究竟谁会赢。


输入:

第一行一个整数C(1<&#61;C<&#61;100)&#xff0c;表示测试数据的个数。
接下来有C行&#xff0c;每行为一个测试数据&#xff0c;每个测试数据只有一个整数N(1<&#61;N<&#61;100)。


输出&#xff1a;

输出C行&#xff0c;每行输出相应测试数据的结果。对于每个结果&#xff0c;如果是小勇赢的话就输出xiaoyong&#xff0c;否则就是小实赢啦&#xff0c;输出xiaoshi。


样例输入&#xff1a;

1
1


样例输出&#xff1a;

xiaoshi


分析&#xff1a;

石子游戏的最优策略是这样的&#xff0c;假如先放&#xff0c;就竖放&#xff0c;否则就根据对方的方法来放&#xff0c;这时&#xff0c;如果对方横放&#xff0c;则在其正上方或正下方横放一石子&#xff0c;如如果对方竖放&#xff0c;也就竖放&#xff0c;按这个方法&#xff0c;很容易得到这个结论&#xff1a;当n为奇数时小实赢&#xff0c;否则小勇赢。


实现&#xff1a;

#includeint c,n;
int main()
{freopen("game.in","r",stdin);freopen("game.out","w",stdout);scanf("%d",&c);while(c--){scanf("%d",&n);if(n%2&#61;&#61;1) printf("xiaoshi\n");else printf("xiaoyong\n");}
}

推荐阅读
  • 单片微机原理P3:80C51外部拓展系统
      外部拓展其实是个相对来说很好玩的章节,可以真正开始用单片机写程序了,比较重要的是外部存储器拓展,81C55拓展,矩阵键盘,动态显示,DAC和ADC。0.IO接口电路概念与存 ... [详细]
  • 本文整理了一份基础的嵌入式Linux工程师笔试题,涵盖填空题、编程题和简答题,旨在帮助考生更好地准备考试。 ... [详细]
  • [转]doc,ppt,xls文件格式转PDF格式http:blog.csdn.netlee353086articledetails7920355确实好用。需要注意的是#import ... [详细]
  • 题目链接:http://codeforces.com/gym/101190/attachments题意:在一个共享三轮车站点,某些用户需要租用车辆。该问题涉及如何通过离线查询和排序优化策略来高效地管理和分配车辆资源。具体来说,需要设计一种算法,在满足所有用户需求的同时,最小化总等待时间和资源浪费。通过合理的数据结构和算法优化,可以显著提高系统的整体性能和用户体验。 ... [详细]
  • Codeforces 1065D 解题心得与代码实现分析 ... [详细]
  • [Offer收割]编程竞赛第8轮 A 小Ho的完美主义倾向
    题目链接:小Ho的完美主义倾向题目描述:小Ho在一条直线型的街道上漫步。这条街道由若干块长度为L的石板铺设而成,因此每隔L的距离就会出现一道石板间的接缝。小Ho对这些规律排列的接缝产生了浓厚的兴趣,他决定研究如何在这条街道上行走,以满足自己对完美路径的追求。本题要求在给定的约束条件下,计算出小Ho能够实现其目标的所有可能方案数。 ... [详细]
  • 【线段树】  本质是二叉树,每个节点表示一个区间[L,R],设m(R-L+1)2(该处结果向下取整)左孩子区间为[L,m],右孩子区间为[m ... [详细]
  • malloc 是 C 语言中的一个标准库函数,全称为 memory allocation,即动态内存分配。它用于在程序运行时申请一块指定大小的连续内存区域,并返回该区域的起始地址。当无法预先确定内存的具体位置时,可以通过 malloc 动态分配内存。 ... [详细]
  • T15483.【清华集训2017模拟11.26】简单路径T25484.【清华集训2017模拟11.26】快乐树T35485.【清华集训2017模拟11.26】字符串T1结论题,结论很 ... [详细]
  • 经过两天的努力,终于成功解决了半平面交模板题POJ3335的问题。原来是在`OnLeft`函数中漏掉了关键的等于号。通过这次训练,不仅加深了对半平面交算法的理解,还提升了调试和代码实现的能力。未来将继续深入研究计算几何的其他核心问题,进一步巩固和拓展相关知识。 ... [详细]
  • 第14周实践项目(4)-验证平衡二叉树
    问题**Copyright(c)2015,烟台大学计算机学院*Allrightsreserved.*文件名称:test.cpp*作者:王敏*完成日 ... [详细]
  • 本文介绍 DB2 中的基本概念,重点解释事务单元(UOW)和事务的概念。事务单元是指作为单个原子操作执行的一个或多个 SQL 查询。 ... [详细]
  • 本文介绍了 NOI Open Judge 6049 购书问题的详细解法,代码简洁易懂,并附有详细的注释和解释。 ... [详细]
  • 本文介绍如何使用线段树解决洛谷 P1531 我讨厌它问题,重点在于单点更新和区间查询最大值。 ... [详细]
  • 在牛客2021多校竞赛的一道题目中,涉及了5000×5000×5000的复杂度计算。实验结果显示,使用bitset进行数据处理仅需140毫秒,而使用bool数组则显著较慢。本文通过详细的性能分析,探讨了bitset与bool在数据处理速度上的差异,并提出了针对不同应用场景的优化建议。具体来说,bitset在位级操作上具有更高的效率,适用于大规模数据处理任务,而bool数组则在某些特定场景下更为灵活。通过对这两种数据结构的深入对比,本文旨在为开发者提供选择合适数据结构的参考依据。 ... [详细]
author-avatar
杨胤才_669
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有