首页 > 其他 > 详细

hdu 2060 Snooker(数学题)

时间:2015-05-28 23:16:54      阅读:360      评论:0      收藏:0      [点我收藏+]

题意:桌上有n个球,一人得分为a,另一人为b,问如果第一个人将n个球都打进洞后,得分能否超过(或等于)第二个人。

分析:1。如果n>6,那么桌上有6个彩球和n-6个红球,每打进一个红球都要补一个黑球,所有打进n个球的得分为

(n-6)*1+(n-6)*7+2+3+4+5+6+7

2.如果n<=6,那么桌上剩下n个分值大的求,例如n=1时,那么剩下一个黑球,此时打进n个球的得分为

(7+7-n+1)*n/2。

代码:

#include<cstdio>
#include<cstring>
using namespace std;

int main()
{
    int n,a,b;
    int t;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%d%d%d",&n,&a,&b);
        if(n>6)
        {
            if(a+(n-6)*1+(n-6)*7+2+3+4+5+6+7>=b)
            {
                printf("Yes\n");
            }
            else
                printf("No\n");
        }
        else
        {
            if(a+(7+7-n+1)*n/2>=b)
                printf("Yes\n");
            else
                printf("No\n");
        }
    }
    return 0;
}



hdu 2060 Snooker(数学题)

原文:http://blog.csdn.net/xky1306102chenhong/article/details/46128691

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!