博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
第三届蓝桥杯本科预赛 c++ 第十题
阅读量:5298 次
发布时间:2019-06-14

本文共 1124 字,大约阅读时间需要 3 分钟。

今盒子里有n个小球,A、B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断。

我们约定:

每个人从盒子中取出的球的数目必须是:1,3,7或者8个。

轮到某一方取球时不能弃权!

A先取球,然后双方交替取球,直到取完。

被迫拿到最后一个球的一方为负方(输方)

请编程确定出在双方都不判断失误的情况下,对于特定的初始球数,A是否能赢?

程序运行时,从标准输入获得数据,其格式如下:

先是一个整数n(n<100),表示接下来有n个整数。然后是n个整数,每个占一行(整数<10000),表示初始球数。

程序则输出n行,表示A的输赢情况(输为0,赢为1)。

例如,用户输入:

10
18

则程序应该输出:

0
1
1
0

 

注意:

请仔细调试!您的程序只有能运行出正确结果的时候才有机会得分!

在评卷时使用的输入数据与试卷中给出的实例数据可能是不同的。

请把所有函数写在同一个文件中,调试好后,存入与【考生文件夹】下对应题号的“解答.txt”中即可。

相关的工程文件不要拷入。
源代码中不能能使用诸如绘图、Win32API、中断调用、硬件操作或与操作系统相关的API。
允许使用STL类库,但不能使用MFC或ATL等非ANSI c++标准的类库。例如,不能使用CString类型(属于MFC类库)。

 

#include
using namespace std;int a[101];int b[]={1,3,7,8};void cal(){ a[0]=1; a[1]=0; a[2]=1; a[3]=0; a[4]=1; for(int i=5;i<101;i++){ int x=i; int flag; for(int j=0; j<4 && x-b[j]>0 ;j++){ int k=0; flag=1; while( b[k] <= x-b[j] ){ if( ! a[ x-b[j]-b[ k++ ] ] ){ flag=0; break; } if(k==4) break; } a[i] = flag; if(flag) break; } }}int main(){ cal(); int n; cin>>n; while(n--){ int x; cin>>x; cout<
<

  

转载于:https://www.cnblogs.com/z-bear/p/8506793.html

你可能感兴趣的文章
查看Apache并发请求数及其TCP连接状态
查看>>
ArrayList与List<T>笔记
查看>>
Python : 什么是*args和**kwargs?
查看>>
自写滚动加载(面向过程版)
查看>>
19 阵列的复制
查看>>
一个香蕉的路程《关于人脸识别Face++的demo》
查看>>
[luogu4728 HNOI2009] 双递增序列 (dp)
查看>>
将博客搬至CSDN
查看>>
vue学习(二):自定义过滤器和自定义指令
查看>>
TimeUnit 笔记
查看>>
Java 多线程之线程池的使用
查看>>
loadrunner 11安装教程
查看>>
VS2012中引用dll目录的配置方法【转】
查看>>
trunc与to_char的比较
查看>>
jQuery EasyUI API 中文文档 - 解析器
查看>>
jQuery插件——Validation Plugin
查看>>
QT LineEdit限制输入内容【转】
查看>>
Linux文件权限
查看>>
.Net Core身份认证:IdentityServer4实现OAuth 2.0 客户端模式
查看>>
C#反射
查看>>