3267. 足球锦标赛

单点时限: 2.0 sec

内存限制: 256 MB

ECNU 足球锦标赛采用了最传统的计分牌来计分。每进一个球,计分员给对应的队要翻牌,使得计分板上显示的数加一。

在这里插入图片描述

如上图所示,计分板上的每一位都按顺序挂了 0 到 9 这 10 个牌子,所以可以表示 000 至 999。当其中一个队的得分从 010 变成 011 时,计分员只要将最后一位的最前面的牌子向后翻即可,共需翻动一块牌子;当得分从 019 变成 020 是,由于 9 后面已经没有牌子了,所以计分员要将 0 到 9 全部翻到前面,并将倒数第二位的牌子 1 翻到后面,所以共需翻动 10 块牌子。

现场的计分牌和图中所示还是存在差异的,现场的计分牌会很大,很重,所以翻每块牌子都要消耗 1 点体力。

你是计分员,现在比赛还剩下最后十分钟。现在有一个预言家告诉你在这十分钟里,双方得分共计多少;但他没有告诉你双方得分各是多少。所以你想要知道你要花费的体力值最多是多少。

输入格式
第一行给出数据组数 T (1≤T≤1 000)。接下来对于每组数据有两行:

第一行是两个三位数 A,B (0≤A,B≤999)(含前导 0),形如 001,013,123,表示双方现在的得分。

第二行是一个整数 K (0≤K≤min{999−A,999−B}),表示双方在最后十分钟的得分之和。

输出格式
对于每组数据,输出 Case x: y。其中 x 是从 1 开始的测试数据编号,y 是一个整数,表示花费体力最多是多少。

样例
input
2
009 009
2
001 003
2
output
Case 1: 20
Case 2: 2
提示
样例 1 解释:有三种情况。

甲方(前者)得 2 分,乙方(后者)得 0 分;甲方要翻 10+1=11 次。
甲方和乙方各得 1 分,共要翻 10+10=20 次。
乙方得 2 分,同样翻 11 次。
所以最多要翻 20 次。

/*
思路:个位上增加0-9只会消耗一次,十位增加一个将增加10次,百位增加一次时会消耗100次,另外十位和百位增加时,将会重复抵消一次。
*/
#include<iostream>
using namespace std;
int main()
{
	int t;
	cin>>t;
	for(int i = 0; i < t; i++)
	{
		int a,b;
		cin>>a>>b;
		int k;
		cin>>k;
		int ans=0;
		for(int j=0;j<=k; j++)//11 9 20 9 10
		{
			int b1=(a+j)/100-a/100;//百位以上变化个数
			int b2=(a+j)/10-a/10;//十位以上变化个数
			int c1=(b+k-j)/100-b/100;
			int c2=(b+k-j)/10-b/10;
			int x=(b1+b2)*10+ j-b2-b1;
			int y=(c1+c2)*10+(k-j)-c2-c1;
			ans=max(x+y,ans);
		}
		printf("Case %d: %d\n",i+1,ans);
	}
	return 0;
}
/*
思路二:dp[i][j]:表示开始比分是i,赢j局的消耗。
状态转移方程:dp[i][j] = dp[i][j - 1] + dp[i + j - 1][1];
即:开始比分为i,赢下j局,消耗应为开始比分是i赢下了j-1局加上开始比分为i+j-1赢下一局之和。
*/
#include <iostream>
#include <string.h>
using namespace std;
int dp[2010][2010];
int main() {
    int num;
    cin >> num;
    memset(dp, 0, sizeof(dp));
    for (int i = 0; i < 1010; ++i) {
        if (i % 100 == 99) {
            dp[i][1] = 19;
        }
        else if (i % 10 == 9) {
            dp[i][1] = 10;
        }
        else {
            dp[i][1] = 1;
        }
    }
    for (int i = 0; i < 1000; ++i) {
        for (int j = 2; j < 1000; ++j) {
            dp[i][j] = dp[i][j - 1] + dp[i + j - 1][1];
        }
    }
    for (int k = 1; k <= num; ++k) {
        int _left, _right, n;
        cin >> _left >> _right;
        cin >> n;
        int _max = 0;
        for (int i = 0; i <= n; ++i) {
            if (_max < dp[_left][i] + dp[_right][n - i]) {
                _max = dp[_left][i] + dp[_right][n - i];
            }
        }
        cout << "Case " << k << ": ";
        cout << _max << endl;
    }
    return 0;
}
*/
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值