蓝桥杯倒数七天冲刺国一之每日复习第三天

简介: 大家好,我是泡泡,今天继续复习

一、ASC


题目链接:https://www.lanqiao.cn/problems/1446/learning/


题目要求:已知大写字母 A 的 ASCII 码为 65,请问大写字母 L 的 ASCII 码是多少?


解题思路:不会做的就放弃学编程吧


#include <iostream>
using namespace std;
int main()
{
    printf("%d",'L');
    return 0;
}


二、修改数组


题目链接:https://www.lanqiao.cn/problems/185/learning/


题目要求:


给定一个长度为 N 的数组 A=[A 1A 2,⋅⋅⋅,A N ],数组中有可能有重复出现的整数。现在小明要按以下方法将其修改为没有重复整数的数组。小明会依次修改A 2,A 3 ,⋅⋅⋅,A N。当修改 Ai时,小明会检查 A i是否在 A 1 ∼ A i−1 中出现过。如果出现过,则小明会给 A i加上 1 ;如果新的 Ai仍在之前出现过,小明会持续给 A i加 1 ,直 到 A i没有在 A1∼ A_i−1中出现过。当 AN也经过上述修改之后,显然 A 数组中就没有重复的整数了。


现在给定初始的 A 数组,请你计算出最终的 A 数组。


解题思路:


暴力骗分


#include<bits/stdc++.h>
using namespace std;
int a[100001],n;
int main()
{
    scanf("%d",&n);
    for(int i=0;i<n;i++)
    {
        int aa;
        scanf("%d",&aa);
        while(a[aa])
        {
            aa++;
        }
        printf("%d ",aa);
        a[aa]=1;
    }
    return 0; 
}


三、大胖子走迷宫


题目链接:https://www.lanqiao.cn/problems/234/learning/


题目要求:


小明是个大胖子,或者说是个大大胖子,如果说正常人占用 1×1 的面积,小明要占用 5×5 的面积。


由于小明太胖了,所以他行动起来很不方便。当玩一些游戏时,小明相比小伙伴就吃亏很多。


小明的朋友们制定了一个计划,帮助小明减肥。计划的主要内容是带小明玩一些游戏,让小明在游戏中运动消耗脂肪。走迷宫是计划中的重要环节。


朋友们设计了一个迷宫,迷宫可以看成是一个由 n×n 个方阵组成的方阵,正常人每次占用方阵中 1×1 的区域,而小明要占用 5×5 的区域。小明的位置定义为小明最正中的一个方格。迷宫四周都有障碍物。


为了方便小明,朋友们把迷宫的起点设置在了第 3 行第 3 列,终点设置在 了第 n−2行第 n−2列。


小明在时刻 0 出发,每单位时间可以向当前位置的上、下、左、右移动单 位 1 的距离,也可以停留在原地不动。小明走迷宫走得很辛苦,如果他在迷宫里面待的时间很长,则由于消耗了很多脂肪,他会在时刻 k 变成一个胖子,只占用 3×3 的区域。如果待的时间更长,他会在时刻 2k 变成一个正常人,只占用 1×1 的区域。注意,当小明变瘦时迷宫的起点和终点不变。


请问,小明最少多长时间能走到迷宫的终点。注意,小明走到终点时可能瘦了也可能没有变瘦。


解题思路:


变种bfs哦,注意体重判断和原地


#include<bits/stdc++.h>
using namespace std;
const int N = 1001;
int n,k;
char s[N][N];
int vis[N][N];
int dx[] = {1,0,0,-1};
int dy[] = {0,1,-1,0};
struct node{
  int x,y,sj,tx;
};
bool pd(int x,int y,int tz)
{
  if(x+tz>n||x-tz<1||y+tz>n||y-tz<0||vis[x][y])
  {
    return false;
  }
  for(int i=x-tz;i<=x+tz;i++)
  {
    for(int j=y-tz;j<=y+tz;j++)
    {
      if(s[i][j]=='*')
      {
        return false;
      } 
    }
  }
  return true;
}
int f(int x)
{
  if(x<k)
  {
    return 2;
  }
  else if(x<k*2)
  {
    return 1;
  }
  return 0;
}
int bfs()
{
  queue<node>q;
  q.push({3,3,0,2});
  vis[3][3] = 1;
  while(q.size())
  {
    node t = q.front();
    q.pop();
    if(t.x==n-2&&t.y==n-2)
    {
      return t.sj;
    }
    if(t.tx!=0)
    {
      q.push({t.x,t.y,t.sj+1,f(t.sj+1)});
    }
    for(int i=0;i<4;i++)
    {
      int nx = t.x+dx[i];
      int ny = t.y+dy[i];
      if(pd(nx,ny,t.tx))
      {
        vis[nx][ny] = 1;
        q.push({nx,ny,t.sj+1,f(t.sj+1)});
      }
    }
  }
}
int main()
{
  cin>>n>>k;
  for(int i=1;i<=n;i++)
  {
    for(int j=1;j<=n;j++)
    {
      cin>>s[i][j];
    }
  }
  cout<<bfs();
  return 0;
}


还有几天 大家加油!

目录
相关文章
|
存储
【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-填空题
【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-填空题
98 1
|
测试技术
【蓝桥杯冲刺】蓝桥杯13届省赛C++b组真题-A~E题
【蓝桥杯冲刺】蓝桥杯13届省赛C++b组真题-A~E题
140 0
|
人工智能 测试技术 BI
【蓝桥杯冲刺】蓝桥杯11届省赛C++b组真题-编程题
【蓝桥杯冲刺】蓝桥杯11届省赛C++b组真题-编程题
106 0
【蓝桥杯冲刺】蓝桥杯11届省赛C++b组真题-填空题
【蓝桥杯冲刺】蓝桥杯11届省赛C++b组真题-填空题
124 0
【蓝桥杯冲刺】日期类专题特训
【蓝桥杯冲刺】日期类专题特训
44 0
|
人工智能 测试技术
【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-编程题
【蓝桥杯冲刺】蓝桥杯12届省赛C++b组真题-编程题
105 0
|
机器学习/深度学习 存储 测试技术
蓝桥杯冲刺-倒数第八天-省赛题
蓝桥杯冲刺-倒数第八天-省赛题
114 0
|
6月前
|
人工智能 算法 Java
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1005 数字游戏
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1005 数字游戏
104 0
|
6月前
|
Java C语言 C++
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1000 kAc给糖果你吃
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-1000 kAc给糖果你吃
79 0
|
6月前
|
算法 Java C语言
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-999 数的潜能
第十四届蓝桥杯集训——练习解题阶段(无序阶段)-ALGO-999 数的潜能
82 0