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

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

一丶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没有在 A
1∼ 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;
}

还有几天 大家加油!

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

cloud、泡泡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值