博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
蓝桥杯 第三届C/C++预赛真题(4) 奇怪的比赛(递归)
阅读量:6943 次
发布时间:2019-06-27

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

某电视台举办了低碳生活大奖赛。题目的计分规则相当奇怪:

每位选手需要回答10个问题(其编号为1到10),越后面越有难度。答对的,当前分数翻倍;答错了则扣掉与题号相同的分数(选手必须回答问题,不回答按错误处理)。

每位选手都有一个起步的分数为10分。

某获胜选手最终得分刚好是100分,如果不让你看比赛过程,你能推断出他(她)哪个题目答对了,哪个题目答错了吗?

如果把答对的记为1,答错的记为0,则10个题目的回答情况可以用仅含有1和0的串来表示。例如:0010110011 就是可能的情况。

你的任务是算出所有可能情况。每个答案占一行。

答案写在“解答.txt”中,不要写在这里!

 


 

  递归

  写一个递归,每一层递归代表一道题的对错情况,用一个数组存储之前所有题的对错情况。直到n==10时,计算当前成绩在当前题目对错情况下的得分是否为100。如果是100输出这种情况。

  答案

001011001101110100001011010000

   代码 

1 #include 
2 using namespace std; 3 int a[11]; 4 void f(int n,int r,int s) //题号和答题结果(答对或答错)和当前的成绩 5 { 6 if(r){ //如果这道题答对 7 if(n==10 && s*2==100){ 8 a[n]=r; 9 for(int i=1;i<=10;i++)10 cout<

 

Freecode :

转载地址:http://djgjl.baihongyu.com/

你可能感兴趣的文章
通信方式总结
查看>>
校园云、园区云、政府云解决方案及成功案例
查看>>
我的友情链接
查看>>
Nginx提供tcp反向代理支持
查看>>
我的友情链接
查看>>
Oracle从零开始09——SQL语句08——事务处理
查看>>
Linux系统配额与RAID
查看>>
VRRP协议介绍
查看>>
Android 监听wifi广播的两种方式
查看>>
我的友情链接
查看>>
Linux samba 只有访问权限,没有修改权限
查看>>
RAC Archive log写入错误的节点
查看>>
我的友情链接
查看>>
查询linux发行版本号方法总结
查看>>
4.入门第四课:javascript日期对象
查看>>
python 批量生产10万接入用户
查看>>
我的友情链接
查看>>
类和对象之分号推断
查看>>
jdbc详解:2、DriverManager管理多个数据库驱动
查看>>
Hibernate-annotation3.30 创建自定义注解,向oracle数据库写列注释
查看>>