蓝桥杯2019年省赛b组题解

第1题 组队

题目:
作为篮球队教练,你需要从以下名单中选出 1 号位至 5 号位各一名球员,
组成球队的首发阵容。
每位球员担任 1 号位至 5 号位时的评分如下表所示。请你计算首发阵容 1
号位至 5 号位的评分之和最大可能是多少?

第1题.png

分析:这题用5层暴力循环就可以求解。注意编号不可以相等。
代码:

#include <iostream>
#include<algorithm>
using namespace std;
int main()
{
    int arr[21][6] = {
        {0, 0, 0, 0, 0, 0},
        {0, 97, 90, 0, 0, 0},
        {0, 92, 85, 96, 0, 0},
        {0, 0, 0, 0, 0, 93},
        {0, 0, 0, 0, 80, 86},
        {0, 89, 83, 97, 0, 0},
        {0, 82, 86, 0, 0, 0},
        {0, 0, 0, 0, 87, 90},
        {0, 0, 97, 96, 0, 0},
        {0, 0, 0, 89, 0, 0},
        {0, 95, 99, 0, 0, 0},
        {0, 0, 0, 96, 97, 0},
        {0, 0, 0, 0, 93, 98},
        {0, 94, 91, 0, 0, 0},
        {0, 0, 83, 87, 0, 0},
        {0, 0, 0, 98, 97, 98},
        {0, 0, 0, 0, 93, 86},
        {0, 98, 83, 99, 98, 81},
        {0, 93, 87, 92, 96, 98},
        {0, 0, 0, 0, 89, 92},
        {0, 0, 99, 96, 95, 81}
    };
    int max = 0;
    for (int a= 1; a <= 20; a++)
    {
        for (int b = 1; b <= 20; b++)
        {
            if (a != b)
            {
                for (int c = 1; c <= 20; c++)
                {
                    if (a != c && b != c)
                    {
                        for (int d = 1; d <= 20; d++)
                        {
                            if (a != d && b != d && c != d)
                            {
                                for (int e = 1; e <= 20; e++)
                                {
                                    if (a != e && b != e && c != e && d != e)
                                    {
                                        int temp = arr[a][1] + arr[b][2] + arr[c][3] + arr[d][4] + arr[e][5];
                                        if (temp > max)
                                            max = temp;
                                    }
                                }
                            }
                        }
                    }
                }
            }
        }
    }
    cout << max;
    return 0;
}

第2题 年号字串

题目:
小明用字母 A 对应数字 1,B 对应 2,以此类推,用 Z 对应 26。对于 27
以上的数字,小明用两位或更长位的字符串来对应,例如 AA 对应 27,AB 对
应 28,AZ 对应 52,LQ 对应 329。
请问 2019 对应的字符串是什么?
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一
个大写英文字符串,在提交答案时只填写这个字符串,注意全部大写,填写多
余的内容将无法得分。

分析:这道题类似于进制转换,不断地将数字像手算除法那样,最后的除数和所有的余数的倒数就是答案。但是需要注意如果是26的倍数,答案最后一个字母是"Z",前面的字母不进位。因为到了Z的时候左边不允许进位,和进制转换还有些不同。或者把前26个和后面的进位分开算。
代码:

#include <iostream>
#include<algorithm>
#include<vector>
using namespace std;

char convert(int c) //数字转换为字母函数
{
    if (c == 0)
        return 'Z';
    else
        return c + 'A' - 1;
}

int main()
{
    int num,res,div;
    cin >> num; //输入数字
    vector<int> numbers; //存放已经计算的数字

    while (num / 26 != 0)
    {
        res = num % 26; //数字除以26的余数
        div = num / 26; //除数继续
        numbers.push_back(res); //余数加入队列
        num = div; //除数继续
    }

    if(numbers[numbers.size() - 1]==0 && num > 1) //最后一个是0,表示除尽了
        numbers.push_back(num - 1); //不进位
    else
        numbers.push_back(num);

    for (int i = numbers.size() - 1; i >= 0; i--)
        cout << convert(numbers[i]);

    return 0;
}

答案:BYQ
标签:进制转换、数字转字母

第3题 数列求值

题目:
给定数列 1, 1, 1, 3, 5, 9, 17, …,从第 4 项开始,每项都是前 3 项的和。求
第 20190324 项的最后 4 位数字。
【答案提交】
这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一
个 4 位整数(提示:答案的千位不为 0) ,在提交答案时只填写这个整数,填写
多余的内容将无法得分。

分析:这题乍一看是大数加法,但是不需要那么麻烦,每次计算直接对10000取余即可,a、b、c、d都不会超过10000,不会溢出。取余操作具有动态性,动态取余结果不受影响。
代码:

#include <iostream>
using namespace std;

int main()
{
    int a = 1, b = 1, c = 1, d;

    for (int i = 4; i <= 20190324; i++)
    {
        d = (a + b + c) % 10000;
        a = b;
        b = c;
        c = d;
    }

    cout << d;

    return 0;
}

答案:4659
标签:大数乘法、斐波那契变形

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 224,815评论 6 522
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 96,251评论 3 402
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 171,999评论 0 366
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 60,996评论 1 300
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 69,993评论 6 400
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 53,477评论 1 314
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 41,848评论 3 428
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 40,823评论 0 279
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 47,361评论 1 324
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 39,401评论 3 346
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 41,518评论 1 354
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 37,119评论 5 351
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 42,850评论 3 338
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 33,292评论 0 25
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 34,424评论 1 275
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 50,072评论 3 381
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 46,588评论 2 365