PTA:打台球

题干

杨同学迷上了一款叫诺斯克的台球游戏,而且随着练习的深入,他总是能在某些神奇的时刻开启外挂模式,此时小李将指哪打哪,直至无球可打。现在杨同学想让你帮他计算下当他开启外挂模式的时候最多可以取得多少分数。注意:台面上的球数可能与传统斯诺克的不同。

比赛的基本规则如下:

彩球共分8种颜色,红(1分)、黄(2分)、绿(3分)、棕(4分)、蓝(5分)、粉(6分)、黑(7分)、白(主球,控制白球来打其余球);
当台面上有红球的时候你必须先击打一个红球,然后能且只能击打一个彩球(不包括红球),此时落袋的彩球将会被放回桌面,一直重复该过程;
当打完规则2的彩球(不包括红球)发现已经没有红球时,按照彩球的分值从低到高将其依次击入袋中。
输入格式:
输入仅有一行,共7个用空格隔开的整数,分别为当前台面上红、黄、绿、棕、蓝、粉、黑球的数目。

输出格式:
输出1个整数,表示杨同学可以得到的最高分。

输入样例:
2 0 1 0 3 0 2
输出样例:
48
台面上共有红球2个、绿球1个、蓝球3个、黑球2个,获得最高分的打法是红-黑-红-黑-绿-蓝-蓝-蓝-黑-黑,共可以获得48分。

解答过程

#include <stdio.h>

int calculateMaxScore(int balls[]) {
    int score = 0;
    while (balls[0] > 0) {
        // 每次先打红球
        balls[0]--;
        score++;
        int flag = 0;
        for (int i = 1; i <= 6; ++i) {
            if (balls[i] > 0) {
                score += i + 1; // 根据索引得到分数
                balls[i]--;
                flag = 1;
                break;
            }
        }
        // 如果没有符合规则的彩球,则直接退出循环
        if (!flag) {
            break;
        }
    }
    // 按照彩球的分值从低到高将其依次击入袋中
    for (int i = 1; i <= 6; ++i) {
        while (balls[i] > 0) {
            score += i + 1; // 根据索引得到分数
            balls[i]--;
        }
    }
    return score;
}

int main() {
    int balls[7]; // 存储每种球的数量
    // 读取输入
    for (int i = 0; i < 7; ++i) {
        scanf("%d", &balls[i]);
    }
    // 计算最高得分并输出
    int maxScore = calculateMaxScore(balls);
    printf("%d\n", maxScore);
    return 0;
}

  • 7
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值