第十四届蓝桥杯B组第一期模拟题

简介: 第十四届蓝桥杯B组第一期模拟题

1.
十进制整数 2 在十进制中是 1 位数,在二进制中对应 10 ,是 2 位数。
十进制整数 22 在十进制中是 2 位数,在二进制中对应 10110 ,是 5 位数。
请问十进制整数 2022 在二进制中是几位数?

#include<stdio.h>
 
int main()
{
  int n=0;
  int sum=0;
  scanf("%d",&n);
  while(n)
  {
    n=n/2;
    sum++;
  }
  printf("%d",sum);
  return 0; 
}

2.
小蓝特别喜欢调和级数 S(n)=1/1+1/2+1/3+1/4+...+1/n 。
  请问,n 至少为多大时,S(n)>12 ?

 #include<stdio.h>
 
int main()
{
  double sum=0;
  int n=0;
  int i=0;
  for(i=1;sum<=12;i++)
  {
    sum+=1.0/i; 
  } 
  printf("%d",i-1); //91380  
  //注意输出时要i-1,因为此时的i是sum大于12的情况 
  return 0;
 } 

3.
 给定一个字母矩阵,如果矩阵中的某个位置不在四条边上,而且该位置上的字母小于其上下左右四个位置的字母,则称为一个山谷。想给你一个矩阵,算算有多少个这样的山谷
  例如,对于如下矩阵

输入:3 5
    DDDDD
    CADCE
    FFFFA
输出:2
输入:
30 60
    PHQGHUMEAYLNLFDXFIRCVSCXGGBWKFNQDUXWFNFOZVSRTKJPREPGGXRPNRVY
  STMWCYSYYCQPEVIKEFFMZNIMKKASVWSRENZKYCXFXTLSGYPSFADPOOEFXZBC
  OEJUVPVABOYGPOEYLFPBNPLJVRVIPYAMYEHWQNQRQPMXUJJLOOVAOWUXWHMS
  NCBXCOKSFZKVATXDKNLYJYHFIXJSWNKKUFNUXXZRZBMNMGQOOKETLYHNKOAU
  GZQRCDDIUTEIOJWAYYZPVSCMPSAJLFVGUBFAAOVLZYLNTRKDCPWSRTESJWHD
  IZCOBZCNFWLQIJTVDWVXHRCBLDVGYLWGBUSBMBORXTLHCSMPXOHGMGNKEUFD
  XOTOGBGXPEYANFETCUKEPZSHKLJUGGGEKJDQZJENPEVQGXIEPJSRDZJAZUJL
  LCHHBFQMKIMWZOBIWYBXDUUNFSKSRSRTEKMQDCYZJEEUHMSRQCOZIJIPFION
  EEDDPSZRNAVYMMTATBDZQSOEMUVNPPPSUACBAZUXMHECTHLEGRPUNKDMBPPW
  EQTGJOPARMOWZDQYOXYTJBBHAWDYDCPRJBXPHOOHPKWQYUHRQZHNBNFUVQNQ
  QLRZJPXIOGVLIEXDZUZOSRKRUSVOJBRZMWZPOWKJILEFRAAMDIGPNPUUHGXP
  QNJWJMWAXXMNSNHHLQQRZUDLTFZOTCJTNZXUGLSDSMZCNOCKVFAJFRMXOTHO
  WKBJZWUCWLJFRIMPMYHCHZRIWKBARXBGFCBCEYHJUGIXWTBVTREHBBCPXIFB
  XVFBCGKCFQCKCOTZGKUBMJRMBSZTSSHFROEFWSJRXJHGUZYUPZWWEIQURPIX
  IQFLDUUVEOOWQCUDHNEFNJHAIMUCZFSKUIDUBURISWTBRECUYKABFCVKDZEZ
  TOIDUKUHJZEFCZZZBFKQDPQZIKFOBUCDHTHXDJGKJELRLPAXAMCEROSWITDP
  TPCCLIFKELJYTIHRCQAYBNEFXNXVGZEDYYHNGYCDRUDMPHMECKOTRWOSPOFG
  HFOZQVLQFXWWKMFXDYYGMDCASZSGOVSODKJGHCWMBMXRMHUYFYQGAJQKCKLZ
  NAYXQKQOYZWMYUBZAZCPKHKTKYDZIVCUYPURFMBISGEKYRGZVXDHPOAMVAFY
  RARXSVKHTQDIHERSIGBHZJZUJXMMYSPNARAEWKEGJCCVHHRJVBJTSQDJOOTG
  PKNFPFYCGFIEOWQRWWWPZSQMETOGEPSPXNVJIUPALYYNMKMNUVKLHSECDWRA
  CGFMZKGIPDFODKJMJQWIQPUOQHIMVFVUZWYVIJGFULLKJDUHSJAFBTLKMFQR
  MYJFJNHHSSQCTYDTEAMDCJBPRHTNEGYIWXGCJWLGRSMEAEARWTVJSJBAOIOJ
  LWHYPNVRUIHOSWKIFYGTYDHACWYHSGEWZMTGONZLTJHGAUHNIHREQGJFWKJS
  MTPJHAEFQZAAULDRCHJCCDYRFVVRIVUYEEGFIVDRCYGURQDREDAKUBNFGUPR
  OQYLOBCWQXKZMAUSJGMHCMHGDNMPHNQKAMHURKTRFFACLVGRZKKLDACLLTEO
  JOMONXRQYJZGINRNNZWACXXAEDRWUDXZRFUSEWJTBOXVYNFHKSTCENAUMNDD
  XFDMVZCAUTDCCKXAAYDZSXTTOBBGQNGVVPJGOJOGLMKXGBFCPYPCKQCHBDDZ
  WRXBZMQRLXVOBTWHXGINFGFRCCLMZNMJUGWWBSQFCIHUBSJOLLMSQSGHMCPH
 
输出:
267

 

#include<stdio.h>
 
int main()
{
  int n,m;
  int arr[100][100]={0};
  int sum=0;
  scanf("%d %d",&n,&m);
  for(int i=0;i<n;i++)
  {
    for(int j=0;j<m;j++)
    {
      scanf(" %c",&arr[i][j]);
    }
  }
  for(int i=1;i<n-1;i++)
  {
    for(int j=1;j<m-1;j++)
    {
      if(arr[i][j]<arr[i+1][j]&&arr[i][j]<arr[i-1][j]&&arr[i][j]<arr[i][j+1]&&arr[i][j]<arr[i][j-1])
      {
        sum++;
      }
    }
  }
  printf("\n%d",sum);
  return 0;
}

4.

问题描述
  输入一个由小写英文字母组成的字符串,请将其中的元音字母(a, e, i, o, u)转换成大写,其它字母仍然保持小写。
输入格式
  输入一行包含一个字符串。
输出格式
  输出转换后的字符串。
样例输入
lanqiao
样例输出
lAnqIAO

#include<stdio.h>
 
int main()
{
    char ch[100]={0};
    int i=0;
    gets(ch);
    while(ch[i]!='0')
    {
      if(ch[i]=='a'||ch[i]=='o'||ch[i]=='e'||ch[i]=='i'||ch[i]=='u')//(a, e, i, o, u)
      {
        ch[i]-=32;
    }
    i++;
  }
    puts(ch);
    return 0;
}

5.

问题描述

  小蓝有一个充电器,可以使用不同的电压和电流充电。

  给定充电器工作的记录,请计算在这个记录期间总共通过充电传输了多少电能。

输入格式

  输入第一行包含一个整数 n , 表示记录的条数。

  接下来 n 行,每行包含一个时刻 T 和两个非负整数 U, I,表示在时刻 T 充电电压变为 U(单位伏),电流变为 I(单位A)。

最后一行满足 U 和 I 均为 0,在前面的行中也可能出现 U、I 为 0 的情况。其中时间表示为 HH:MM:SS 的格式,时分秒分别用两位十进制数表示(补前导零)。

  输入保证时刻依次递增且在 00:00:00 至 23:59:59 的区间内,不用考虑跨过零点充电的情况。

输出格式

  输出一个整数,表示总共通电的电能为多少焦耳,其中 1 焦耳等于 1 伏乘以1 安乘以 1 秒。

样例输入

3
12:00:00 12 1
12:01:02 5 2
12:01:10 0 0

样例输出

824

评测用例规模与约定

  对于所有评测用例,1 <= n <= 100, 0 <= U, I <= 100

#include<stdio.h>
 
int main()
{
    int n;
    int h[100],m[100],s[100],v[100],i[100];
    int h1,m1,s1;
    int t1=0;
    int sum=0;
    scanf("%d",&n);
    for(int i1=0;i1<n;i1++)
    {
      scanf("%d:%d:%d %d %d",&h[i1],&m[i1],&s[i1],&v[i1],&i[i1]);
    }
    for(int j=1;j<n;j++)
    {
        h1=h[j]-h[j-1];
        m1=m[j]-m[j-1];
        s1=s[j]-s[j-1];
        //  printf("\nh=%d",h1);
      //printf("\nm=%d",m1);
        // printf("\ns[j]=%d,s[0]=%d",s[j],s[j-1]);
        //printf("\ns=%d\n",s[j]-s[j-1]);
        if(h1!=0)
        {
            sum+=h1*3600*v[j-1]*i[j-1];
            if(m1!=0)
            {
                sum+=m1*60*v[j-1]*i[j-1];
                if(s1!=0)
                {
                    sum+=s1*v[j-1]*i[j-1];
                }
                else
                {
                    sum+=0;
                }
                
            }
            else
            {
              sum+=0;
            }
        } 
        else
        {
            sum+=0;
            if(m1!=0)
            {
                sum+=m1*60*v[j-1]*i[j-1];
                if(s1!=0)
                {
                    sum+=s1*v[j-1]*i[j-1];
                }
                else
                {       
                    sum+=0;
                }
                
            }
            else
            {
              sum+=0;
              if(s1!=0)
                {
                    sum+=s1*v[j-1]*i[j-1];
                }
                else
                {
                    sum+=0;
                }
            }
        }
       
    }
    printf("%d",sum);
    return 0;
}

6.

小蓝每周六、周日都晨跑,每月的 1、11、21、31日也晨跑。其它时间不晨跑。

已知 2022年1月1日是周六,请问小蓝整个2022年晨跑多少天?

#include<stdio.h>
 
int main()
{
  int day[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
  int sum=0;
  int week=6; 
  for(int m=1;m<=12;m++)
  {
    for(int d=1;d<=day[m];d++)
    {
    
      if(d==1||d==11||d==21||d==31||week%7==6||week%7==0)
      {
        sum++;
      }
      week++;//用来判断周六周天 
    }
  }
  printf("%d",sum);//138
  return 0;
 } 

7.核酸日期

问题描述

如果周一做核酸,周二显示核酸天数为 1 天,周三显示 2 天,以此类推,周六显示 5 天,周日显示 6 天。

小蓝在某一天做了一次核酸,请问他的核酸显示为几天。已知做核酸和查看核酸不是在同一天,而且相差不超过 6 天(显示的数为 1 到 6 之间的数)。

输入格式

输入第一行包含一个整数 s ,表示小蓝做核酸是周几。 s 为 1 到 6 依次表示周一到周六,s 为 7 表示周日。

第二行包含一个整数 t ,表示查看核酸是周几。 t 为 1 到 6 依次表示周一到周六,t 为 7 表示周日。

输出格式

输出一行包含一个整数,表示答案。

样例输入

5

2

样例输出

4

评测用例规模与约定

对于所有评测用例,1 < = s , t < = 7 1 <= s, t <= 71<=s,t<=7。

参考答案

判断一下是不是同一周,如果是就直接做差,不是就加7再做差

#include <stdio.h> 
 
int main() 
{
  int a, b;
  scanf("%d\n%d",&a,&b);
    if (b > a) 
  {
     printf("%d",b-a);
    } 
  else 
  {
    printf("%d",b+7-a);
    
    }
    return 0;
}

up主比较菜,是个刚学C语言的小白,用csdn就是想把做过的题保留下来没事多看看,也想为和我一样的c语言小白分享一下我的练习题。

目录
相关文章
单片机比赛准备08-蓝桥杯-第六届初赛模拟题(温度采集和控制装置)
单片机比赛准备08-蓝桥杯-第六届初赛模拟题(温度采集和控制装置)
124 0
单片机比赛准备08-蓝桥杯-第六届初赛模拟题(温度采集和控制装置)
单片机比赛准备07-蓝桥杯-第五届初赛模拟题(模拟智能灌溉装置)
单片机比赛准备07-蓝桥杯-第五届初赛模拟题(模拟智能灌溉装置)
87 0
单片机比赛准备07-蓝桥杯-第五届初赛模拟题(模拟智能灌溉装置)
单片机比赛准备06-蓝桥杯-第四届初赛模拟题(自动售水机)
单片机比赛准备06-蓝桥杯-第四届初赛模拟题(自动售水机)
144 0
单片机比赛准备06-蓝桥杯-第四届初赛模拟题(自动售水机)
单片机比赛准备05-蓝桥杯-第三届初赛模拟题(模拟传送装置)
单片机比赛准备05-蓝桥杯-第三届初赛模拟题(模拟传送装置)
138 0
单片机比赛准备05-蓝桥杯-第三届初赛模拟题(模拟传送装置)
|
前端开发 JavaScript
蓝桥杯web开发组模拟题—给页面化个妆
我们都知道,蓝桥杯是近几年特别火的一个竞赛,同时,我也看到了越来越多的人在程序设计组竞争,那么,有没有竞争稍微弱一点的组别呢!怀着期待,十二届蓝桥杯大赛增加了web开发组,也就是说今年是第一届web开发组赛事,所以说竞争不大哦!你还在犹豫吗!快来跟着博主一起打卡学习吧!
250 1
蓝桥杯web开发组模拟题—给页面化个妆
|
前端开发 算法 JavaScript
蓝桥杯web开发-5道模拟题让你信心满满
距离蓝桥杯已经不到5天了,今天总结一下做过的5道简单的web开发组模拟题来增加信心,你只管努力学习,剩下的交给天意!
599 0
蓝桥杯web开发-5道模拟题让你信心满满
|
机器学习/深度学习
蓝桥杯模拟题
c语言参考题目---填空题 代码填空 如果只提供加减乘除的基本运算能力,你能实现求平方根吗?可以的!先随便猜一个根,用它试除目标数字,如果结果恰好等于所猜的数,则问题解决。否则用结果与所猜的数字的平均值再去试除….
1056 0
|
6月前
|
人工智能 算法 Java
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1005 数字游戏
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1005 数字游戏
109 0
|
6月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1000 kAc给糖果你吃
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1000 kAc给糖果你吃
82 0
|
6月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-999 数的潜能
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-999 数的潜能
83 0