蓝桥杯day8


2015年第六届C/C++ B组省赛真题

1.奖券数目

有些人很迷信数字,比如带“4”的数字,认为和“死”谐音,就觉得不吉利。
虽然这些说法纯属无稽之谈,但有时还要迎合大众的需求。某抽奖活动的奖券号码是5位数(10000-99999),要求其中不要出现带“4”的号码,主办单位请你计算一下,如果任何两张奖券不重号,最多可发出奖券多少张。
请提交该数字(一个整数),不要写任何多余的内容或说明性文字。

题解:
方法一:用暴力5层循环实现。每一层循环的数字不能等于4就行。
(推荐)方法二:利于高中所学的排列组合解决:
对于最高位:只能为1,2,3,5,6,7,8,9共8种。
对于千,百,十,个位:只能为0,1,2,3,5,6,7,8,9共9种。
所以总共有89999=52488;

2.星系炸弹

在X星系的广袤空间中漂浮着许多X星人造“炸弹”,用来作为宇宙中的路标。
每个炸弹都可以设定多少天之后爆炸。
比如:阿尔法炸弹2015年1月1日放置,定时为15天,则它在2015年1月16日爆炸。
有一个贝塔炸弹,2014年11月9日放置,定时为1000天,请你计算它爆炸的准确日期。
请填写该日期,格式为 yyyy-mm-dd 即4位年份2位月份2位日期。比如:2015-02-19
请严格按照格式书写。不能出现其它文字或符号。

题解:
判断年份是否为润平年。所以简洁做法:21+31+365+366+31+28+31+30+31+30+31+5=10000;
得出:2017-08-05;

编程实现:

#include <iostream>
using namespace std;
bool run(int y)
{
    if((y%4==0&&y%100!=0)||y%400==0)
        return true;
    else
        return false;
}
int main()
{
    int y=2014;
    int ds=1000+31+28+31+30+31+30+31+31+30+31+9;//从2014-0-0开始计算
    int ms[12]={31,28,31,30,31,30,31,31,30,31,30,31};
    //计算年
    while(1)
    {
        int dys;
        if(run(y))
            dys=366;
        else
            dys=365;
        if(ds<dys)
            break;
        ds-=dys;
        y++;
    }
    if(run(y))
        ms[1]=29;
    //计算月
    for(int i=0;i<12;i++)
    {
        if(ds<=ms[i])
        {
            cout<<y<<'-';
            cout<<i+1<<'-';
            cout<<ds;
            break;
        }
        else
        {
            ds-=ms[i];
        }
    }
    return 0;
}

3.三羊献瑞

观察下面的加法算式:

    祥 瑞 生 辉
  • 三 羊 献 瑞

三 羊 生 瑞 气

其中,相同的汉字代表相同的数字,不同的汉字代表不同的数字。

请你输出“三羊献瑞”所代表的 4位数字(答案唯一)。

题解:
方法一:采用7层循环输出查找。
方法二:采用全排列进行。

#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
    int arr[10]={0,1,2,3,4,5,6,7,8,9};
    do//使用do while才不会把初始的情况给漏掉
    {
        if(arr[0]!=0&&arr[4]!=0)
        {
            int a=arr[0]*1000+arr[1]*100+arr[2]*10+arr[3];
            int b=arr[4]*1000+arr[5]*100+arr[6]*10+arr[1];
            int z=arr[4]*10000+arr[5]*1000+arr[2]*100+arr[1]*10+arr[7];
            if(a+b==z)
            {
                cout<<b;
                break;
            }
        }

    }while(next_permutation(arr,arr+10));
    return 0;
}

4.格子中输出

考察占位符知识:占位符

题解:两边所占的空格要相等

(width-2-strlen(buf))/2," “,s,(width-2-strlen(buf))/2,” "

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值