金色十月线上编程比赛第一题:小女孩数数

金色十月线上编程比赛第一题:小女孩数数

题目详情:

【金色十月线上编程比赛规则】

一个小女孩正在用左手手指数数,从1数到n。她从拇指算作1开始数起,然后,食指为2,中指为3,无名指为4,小指为5。接下来调转方向,无名指算作6,中指为7,食指为8,大拇指为9,如此反复。问最后会停在那个手指上?用编号1、2、3、4、5依次表示大拇指、食指、中指、无名指、小指。

输入格式:

输入多组数据。每组数据占一行,只包含一个整数n(1<=n<=1000000000)。

输出格式:

每组数据占一行,只包含一个介于1和5之间的整数,表示最后停留的手指。



答题说明:

输入样例:

1

10

1000000000

输出样例:

1

2

2


解题思路:我们可以先观察下

   1 2 3 4 5

9 8 7 6

      10   11    12 13

       17   16   15    14

               18   19    20    21

       25   24    23   22

。。。

我们发现第n行的最大值为5+4*(n-1),当n为偶数时,最大值在最右边,n为奇数时,最大值在最左边,于是我们只需要找到给定的数a在第几行,然后从这个最大值一直减小到a,看看它在那个位置;

#include <iostream>
using namespace std;
int main(){
    long long n;
    while (cin>>n){
        double k=(n-5)*1.0/4+1;
        double s=k-(int)k;
        long long num=k;
        if (s)
            num++;
        long long a=5+4*(num-1);
        int answer=0;
        if (a>n)
            answer=a-n;
        else
            answer=n-a;
        if (num%2==0)
            answer+=1;
        else
            answer=5-answer;
        cout<<answer<<endl;
    }
    return 0;
}        


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值