题目描述

n 个人站成一行玩一个报数游戏。所有人从左到右编号为 1 到 n。游戏开始时,最左边的人报 1,他右边的人报2,编号为 3 的人报 3,等等。当编号为 n 的人(即最右边的人)报完 n 之后,轮到他左边的人(即编号为n-1 的人)报 n+1,然后编号为 n-2 的人报 n+2,以此类推。当最左边的人再次报数之后,报数方向又变成从左到右,依次类推。

为了防止游戏太无聊,报数时有一个特例:如果应该报的数包含数字7 或者是 7 的倍数,他应当用拍手代替报数。下表是n=4 的报数情况(X 表示拍手)。当编号为 3 的人第 4 次拍手的时候,他实际上数到了 35。

给定n,m 和 k,你的任务是计算当编号为 m 的人第 k 次拍手时,他实际上数到了几。

输入

输入包含不超过10组数据。每组数据占一行,包含三个整数n,m和k(2<=n<=100, 1<=m<=n, 1<=k<=100)。输入结束标志为n=m=k=0。

输出

对于每组数据,输出一行,即编号为m的人第k次拍手时,他实际上数到的那个整数。

样例输入

4 3 1
4 3 2
4 3 3
4 3 4
0 0 0 

样例输出

17
21
27
35
#include<iostream>
#include<cstdio>
using namespace std;
int n, m, k, c, i, sno;
bool judge(int num){while (num){if (num % 10 == 7)return true;num /= 10;}return false;
}
int main(){while (scanf("%d%d%d", &n, &m, &k) != EOF){if (n == 0 && m == 0 && k == 0)break;int f = 1;for (i = 1, c = 0, sno = 1; c<k; i++){if ((i % 7 == 0 && sno == m )|| (judge(i)&&sno==m)){c++;if (c == k)break;}sno += f;if (sno == n)f = -1;else if (sno == 1)f = 1;}printf("%d\n", i);}
}

C/C++ 报数游戏相关推荐

  1. NYOJ 559 报数游戏

    报数游戏 时间限制:1000 ms  |  内存限制:65535 KB 难度:2 描述 n 个人站成一行玩一个报数游戏.所有人从左到右编号为 1 到 n.游戏开始时,最左边的人报 1,他右边的人报 2 ...

  2. zcmu-1643 报数游戏

    B - 报数游戏 n个人站成一行玩一个报数游戏.所有人从左到右编号为1到n.游戏开始时,最左边的人报1,他右边的人报2,编号为3的人报3,等等.当编号为n的人(即最右边的人)报完n之后,轮到他左边的人 ...

  3. toj 4316 报数游戏

    toj 4316 报数游戏 时间限制(普通/Java):1000MS/3000MS 内存限制:65536KByte 总提交: 68 测试通过:35 描述 n 个人站成一行玩一个报数游戏.所有人从左到右 ...

  4. 微课|中学生可以这样学Python(例5.3):报数游戏

    适用教材: 董付国,应根球.<中学生可以这样学Python>.清华大学出版社,2017. 第5章  Python序列及应用 5.1.6  精彩例题分析与解答 例5.3  报数游戏 京东购买 ...

  5. python循环报数游戏_报数游戏python 解答

    又做了个小题目,报数游戏. 题目详情: 一种报数游戏是从1开始连续报数,如果报到7的倍数(7,14,21,28--)或者包含数字7的数(7,17,27,37--)就用拍手代替这个数而不能报出.假设你连 ...

  6. java实现报数游戏

    报数游戏 有n个孩子站成一圈,从第一个孩子开始顺时针方向报数,报到3的人出列,下一个人继续从1报数,直到最后剩下一个孩子为止.问剩下第几个孩子.下面的程序以10个孩子为例,模拟了这个过程,请完善之(提 ...

  7. python——报数游戏

    报数游戏 模拟报数游戏.有n个人围成一圈,顺序编号,从第一个人开始从1到k(假设k=3)报数, 报到k的人退出圈子,然后圈子缩小,从下一个人继续游戏,问最后留下的是原来的第几号. 思路 代码 &quo ...

  8. C语言编程学习制作最好玩的报数游戏

    C语言是面向过程的,而C++是面向对象的C和C++的区别:C是一个结构化语言,它的重点在于算法和数据结构.C程序的设计首要考虑的是如何通过一个过程,对输入(或环境条件)进行运算处理得到输出(或实现过程 ...

  9. python逢7跳过_07.报数游戏:7的倍数或含7的数跳过,趣说python循环里的break和continue...

    转自同名微信公众号. 自幂数是指一个 n 位数,它的每个位上的数字的n 次幂之和等于它本身.比如 153 = 1**3 + 5**3 + 3**3,是一个3位数的自幂数,也称水仙花数. 求所有的水仙花 ...

最新文章

  1. 十大排序算法 导图总结
  2. python在线编辑器编译excel_python在线编译器的简单原理及简单实现代码
  3. Canvas的save和restore方法
  4. 打开word或者office程序报错:Microsoft Visual C++ Runtime Library. Runtime Error!
  5. 【oracle】dbms_output:控制台输出
  6. 访问权限冲突定义_一文读懂F5 REST API的细粒度角色访问控制
  7. AMD OpenCL 大学课程
  8. 娱乐大咖项目2- 总结
  9. java跑批任务_【spring配置】——spring整合Quartz定时器
  10. matlab中用数据拟合圆心,拟合圆并求圆心(matlab)
  11. C#控件储备——信息提示控件toolTip
  12. SQLPrompt关闭联网
  13. linux入门常用命令
  14. linux多线程编程介绍
  15. 微擎框架对接第三方短信接口教程
  16. linux 版的 wps 缺少字体的解决办法
  17. 强烈推荐:一款中文AI问答、创作、绘画工具
  18. AWS VPC 概述
  19. codeforces 546B Soldier and Badges
  20. SQL Server备份恢复

热门文章

  1. 【读书笔记】AUTOSAR规范与车用控制器软件开发02
  2. CG资源网站(持续更新)
  3. 数据分析实战:利用python对心脏病数据集进行分析!
  4. 华为鸿蒙系统超级终端,华为再发新版鸿蒙OS系统!新增超级终端功能:可媲美iOS系统...
  5. 1228:书架——贪心
  6. CANoe.DiVa 操作指南 -测试覆盖度分析
  7. 机械硬盘哪个好?买1T好还是2T好?注意别买到叠瓦盘
  8. 【C++解题报告】阿克曼(Ackmann)函数
  9. 我与小娜(20):去LIGO,探秘光子接力赛
  10. Raydium被盗造成巨额损失,但Zebec Protocol以及$ZBC并未受影响