CCF CSP 201912-1 报数 100分

201912-1

问题描述
甲乙丙丁决定玩一个报数的游戏来打发时间。游戏规则为四个人从1开始轮流进行报数,但如果需要报出的数是7的倍数或含有数字7则直接跳过。
此外大家约定,在总共报出了n个数后(不计入被跳过的数)游戏结東。现在需要你来帮忙统计,游戏过程中每个人各自跳过了几次。

输入格式
从标准输入读入数据。
输入仅一行,包含一个正整数n,表示报出了多少个数后游戏结束。

输出格式
输出到标准输出。
输出共四行,每行一个整数,依次表示甲乙丙丁四人在游戏过程中跳过的次数。

样例输入
20
样例输出
2
1
1
0

算法思想
设置一个变量count计算将要报的数,判断count是否已经报完,则是判断count减去已经跳过的个数是否小于等于num,若否,将count加1;若是,则判断是否有包含7的数或者是7的倍数,若是,则判断是轮到甲乙丙丁哪个报的,再将此人的次数加1;再将相应的跳过的次数输出。

数据结构设计
使用整型变量int;
int count=1,jia=0,yi=0,bing=0,ding=0;

算法步骤
1.定义报的数字count=1,甲乙丙丁的跳数,jia=0,yi=0,bing=0,ding=0。
2.输入需要报的数num
3.判断已经将num个数报完,若是,跳转4,若否,转到8
4.将判断此数是否是7的倍数或包含7的值赋值给seven
5. seven是否等于1,若是,则 转6
6.判断是轮到甲乙丙丁哪个人报的,轮到的人将跳数加1
7.将count加1
8.输出甲乙丙丁跳过的个数。

实现技术
主要是判断是否已经报完数,用count-甲乙丙丁已经跳的次数是否≥num

代码实现

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值