蓝桥杯刷题冲刺 | 倒计时17天

作者:指针不指南吗
专栏:蓝桥杯倒计时冲刺

🐾马上就要蓝桥杯了,最后的这几天尤为重要,不可懈怠哦🐾

文章目录

  • 1.长草
  • 2.分考场

1.长草

  • 题目

  • 链接: 长草 - 蓝桥云课 (lanqiao.cn)

    题目描述

    小明有一块空地,他将这块空地划分为 nm 列的小块,每行和每列的长度都为 1。

    小明选了其中的一些小块空地,种上了草,其他小块仍然保持是空地。

    这些草长得很快,每个月,草都会向外长出一些,如果一个小块种了草,则它将向自己的上、下、左、右四小块空地扩展,

    这四小块空地都将变为有草的小块。请告诉小明,k 个月后空地上哪些地方有草。

    输入描述

    输入的第一行包含两个整数 n*,*m。

    接下来 n 行,每行包含 m 个字母,表示初始的空地状态,字母之间没有空格。如果为小数点,表示为空地,如果字母为 g,表示种了草。

    接下来包含一个整数 k。 其中,2≤n,m≤1000,1≤k≤1000。

    输出描述

    输出 n 行,每行包含 m 个字母,表示 k 个月后空地的状态。如果为小数点,表示为空地,如果字母为 g,表示长了草。

    输入输出样例

    示例

    输入

    4 5
    .g...
    .....
    ..g..
    .....
    2
    

    输出

    gggg.
    gggg.
    ggggg
    .ggg.
    
  • 第一次 AC 0%

    #include<bits/stdc++.h>
    using namespace std;
    
    typedef pair<int,int> PII;
    int const N=1100;
    
    int n,m,k;
    char g[N][N];
    int d[N][N];
    queue<PII> q;
    
    void bfs()
    {
    	int dx[4]={0,0,-1,1},dy[4]={1,-1,0,0};
    	
    	while(q.size())
    	{
    		auto t=q.front();
    		q.pop();
    		
    		for(int i=0;i<4;i++)
    		{
    			int x=t.first+dx[i],y=t.second+dy[i];
    			if(d[x][y]==-1&&x<=n&&x>=1&&y<=m&&y>=1&&g[x][y]=='.')
    			{
    				q.push({x,y});
            		g[x][y]='g';
    				d[x][y]=d[t.first][t.second]+1;
    				if(d[x][y]==k)
    					return ;
    			}
    		}
    	}
    	
    }
    
    int main()
    {
    	scanf("%d%d",&n,&m);
    	
    	memset(d,-1,sizeof d);
    	
    	for(int i=1;i<=n;i++)
    		for(int j=1;j<=m;j++)
    		{
    			cin>>g[i][j];
    			if(g[i][j]=='g')
    			{
    				q.push({i,j});
    				d[i][j]=0;
    			}
    		}
    			
    			
    	scanf("%d",&k);
    	
    	bfs();
    	
    	for(int i=1;i<=n;i++)
    	{
    		for(int j=1;j<=m;j++)
    		{
    			cout<<g[i][j];
    		}
    		cout<<endl;
    	}
    	
    	return 0;
    }
    
  • 题解

    #include<bits/stdc++.h>
    using namespace std;
    
    typedef pair<int,int> PII;
    int const N=1100;
    
    int n,m,k,cnt;
    char g[N][N];
    int d[N][N];
    queue<PII> q;
    int len;
    
    void bfs()
    {
    	
    	int dx[4]={0,0,-1,1},dy[4]={1,-1,0,0};
    	
    	while(q.size()&&k>0)
    	{
    		auto t=q.front();
    		q.pop();
    		
    		for(int i=0;i<4;i++)
    		{
    			int x=t.first+dx[i],y=t.second+dy[i];
    			if(d[x][y]==-1&&x<=n&&x>=1&&y<=m&&y>=1&&g[x][y]=='.')
    			{
    				q.push({x,y});
           			 g[x][y]='g';
    			}
    		}
        len--;     //一个点向四周扩展完之后,len--,表示这层的一个点已经完成扩展 //这里是重点!!!
        if(len==0)  //len ==0 说明这层的点已经全部完成扩展,令 len 重新等于刚扩展过程中放进去点的个数(即q.size(),我们之前的点都已经pop掉了,所以现在队列里面的点都是新放进去,属于下一层的点),并且层数k--
        {
          k--;
          len=q.size();
        }
    	}
    	
    }
    
    int main()
    {
    	scanf("%d%d",&n,&m);
    	
    	memset(d,-1,sizeof d);
    	
    	for(int i=1;i<=n;i++)
    		for(int j=1;j<=m;j++)
    		{
    			cin>>g[i][j];
    			if(g[i][j]=='g')
    			{
    				q.push({i,j});
    			}
    		}
    	len=q.size();		//最开始计往里面放了几个元素 len=q.size( )
    			
    	scanf("%d",&k);
    	
    	bfs();
    	
    	for(int i=1;i<=n;i++)
    	{
    		for(int j=1;j<=m;j++)
    		{
    			cout<<g[i][j];
    		}
    		cout<<endl;
    	}
    	
    	return 0;
    }
    
  • 反思

    第一次的扩展层数不正确,代码没有实现成功;

    题解中的记录扩展层数的方式:

    • 最开始计往里面放了几个元素 len=q.size( )
    • 一个点向四周扩展完之后,len–,表示这层的一个点已经完成扩展
    • len ==0 说明这层的点已经全部完成扩展,令 len 重新等于刚扩展过程中放进去点的个数(即q.size(),我们之前的点都已经pop掉了,所以现在队列里面的点都是新放进去,属于下一层的点),并且层数k–

2.分考场

  • 题目

    链接: 分考场 - 蓝桥云课 (lanqiao.cn)

    n 个人参加某项特殊考试。

    为了公平,要求任何两个认识的人不能分在同一个考场。

    求最少需要分几个考场才能满足条件。

    输入描述

    第一行,一个整数 n (1≤n≤100),表示参加考试的人数。

    第二行,一个整数 m,表示接下来有 m 行数据。

    以下 m 行每行的格式为:两个整数 a*,b,用空格分开 ( 1≤a,b≤*n )表示第 a 个人与第 b 个人认识。

    输出描述

    输出一行一个整数,表示最少分几个考场。

    输入输出样例

    示例

    输入

    5
    8
    1 2
    1 3
    1 4
    2 3
    2 4
    2 5
    3 4
    4 5
    

    输出

    4
    
  • 第一次 AC 0%

    #include<bits/stdc++.h>
    using namespace std;
    
    const int N=110;
    
    int n,m,ans;
    int p[N],s[N];
    
    int find(int x)
    {
    	if(x!=p[x]) p[x]=find(p[x]);
    	return p[x];
    }
    
    void add(int a,int b)
    {
    	s[b]+=s[a];
    	ans=max(ans,s[b]);
    	p[b]=find(p[a]);
    }
    
    int main()
    {
    	scanf("%d%d",&n,&m);
    	
    	for(int i=1;i<=n;i++)
    	{
    		p[i]=i;
    		s[i]=1;
    	}
    	
    	while(m--)
    	{
    		int a,b;
    		scanf("%d%d",&a,&b);
    		add(a,b);
    	}
    	
    	cout<<ans;
    	
    	return 0;
     } 
    

    想错了,这题长得真像并查集,a和b认识,b和c认识,但是a和b不一定认识

    经过思考,我的思路:

    先把n个数放在一个房间里面,a,b 认识,把其中一个从他们房间里面移出去;

    移到隔壁房间,隔壁房间有认识的人,往下轮,直到找到没有认识的人房间,如果都不行,就新建一个房间 ans++

    怎么实现呢

  • 题解

    #include<bits/stdc++.h>
    using namespace std;
    
    const int N=110;
    
    int n,m;
    bool g[N][N];  //矩阵数组:两个人认识为1,不认识为 0
    vector<int>q[N];  //定义一个二维空间数组
    int ans=0x3f3f3f3f;  //定义最后需要的房间
    
    bool check(int id,int p)  //判断 p 这个考场,能不能放 id 这个人
    {
    	for(int j=0;j<q[p].size();j++)  //q[p].size() 表示考场的人数,精髓
    	{
    		if(g[id][q[p][j]])
    			return false;
    	}
    	return true;
    } 
    
    void dfs(int id,int cnt)
    {
    	if(cnt>=ans)  //剪枝:一定不是最小的结果,回溯
    		return;
    	if(id==n+1)  // 所有人 都遍历了,回溯
    	{
    		ans=min(ans,cnt);  
    		return;
    	}
    	
    	for(int p=1;p<=cnt;p++)  //遍历每一个考场 
    	{
    		if(check(id,p)) //考场里没有熟人 
    		{
    			q[p].push_back(id);  //id放在 p这个考场里面
    			dfs(id+1,cnt);  //放下一个 学生
    			q[p].pop_back();   //恢复现场
    		} 
    	}
    	
    	if(cnt<n)  //经过上面的遍历每一个考场,没有 dfs ,说明没有考场可以放 id,so开一个新的考场
    	{
    		q[cnt+1].push_back(id);  //cnt+1
    		dfs(id+1,cnt+1);  
    		q[cnt+1].pop_back();   //回复现场
    	}
    	
    }
    
    int main()
    {
    	cin>>n>>m;
    	
    	while(m--)
    	{
    		int a,b;
    		cin>>a>>b;
    		if(a!=b)
    			g[a][b]=1,g[b][a]=1;
    	}
    	
    	dfs(1,0);  //编号为 1,房间数号 0 
    	
    	cout<<ans; 
    	
    	return 0;
    }
    
  • 反思

    怎么实现呢?我想了用邻接表,但是没有实现出来

    题解中的vector二维数组真是妙

    vector 二维数组:

    • vector<int> q[m] 表示可以往 q[1],q[2] 里面放一个数组,

      q[2][3] 表示 q[2]这个数组的 第 3个元素,根据上面题中理解更透彻

      而且还可以 使用 q[2].size() 就很方便

    审题,避免整个思路方向性出现错误,dfs 会使用成 并查集 ,老生常谈

Alt

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mfbz.cn/a/2556.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Feign远程调用

之前在一篇博客中写了利用RestTemplate发起远程调用的代码&#xff0c;但是存在一下问题&#xff1a;代码可读性差&#xff0c;编程体验不统一&#xff1b;如果参数特别多的话&#xff0c;参数复杂URL难以维护。Feign官方地址&#xff1a;https://github.com/OpenFeign/feignFe…

行业观察 | 来了解一下AI加速器

本文参考网上可查询到的资料简要总结AI加速器的概念和应用等信息 1。 未完待续 更新&#xff1a; 2023 / 3 / 22 行业观察 | 来了解一下AI加速器前言加速器处理器处理器是什么&#xff1f;处理器进化史加速器架构指令集 ISA特定领域的指令集 ISA超长指令字&#xff08;VLIW&a…

如何使用子项目管理方案?

在项目进行中经常发生这样的情况&#xff1a;当你开始为一个项目制定时间表时&#xff0c;你会发现任务的数量太多。你需要把它们全部分组到一些摘要任务中。但随后你看到一堆摘要任务&#xff0c;也想把它们再分组。 这样一来&#xff0c;该项目变得很麻烦&#xff0c;甚至项目…

Matlab进阶绘图第10期—带填充纹理的柱状图

带填充纹理的柱状图是通过在原始柱状图的基础上添加不同的纹理得到的&#xff0c;可以很好地解决由于颜色区分不足而导致的对象识别困难问题。 由于Matlab中未提供纹理填充选项&#xff0c;因此需要大家自行设法解决。 本文使用Kesh Ikuma制作的hatchfill2工具&#xff08;Ma…

gin框架使用websocket实现进入容器内部执行命令

文章目录1. 先决条件2. gin框架实现3. 测试用html文件4. 需要完善1. 先决条件 docker开放远程API端口 2. gin框架实现 type GetCommandResultRequire struct {IpAddr string json:"ip_addr" //传入要控制容器的ip地址ContainerUuid string json:"cont…

对堆题的总体思路

浅说一下pwn堆并用一个简单的例子具体说明给刚入坑堆的小朋友说的一些思路说一下堆是什么堆你可以看成一个结构体数组&#xff0c;然后数组里每个元素都会开辟一块内存来存储数据那么这块用来存储数据的内存就是堆。结构体数组在BSS段上&#xff0c;其内容就是堆的地址&#xf…

动态SQL必知必会

动态SQL必知必会1、什么是动态SQL2、为什么使用动态SQL3、动态SQL的标签4、if 标签-单标签判断5、choose标签-多条件分支判断6、set 标签-修改语句7、foreach标签7.1 批量查询7.2 批量删除7.3 批量添加8、模糊分页查询1、什么是动态SQL 动态 SQL 是 MyBatis 的强大特性之一。如…

阿里巴巴2017实习生笔试题(二)——总结

具体题目来自阿里巴巴2017实习生笔试题&#xff0c;本文仅为整理与汇总。 本题应该往C的多态性进行理解&#xff0c;多态中的动态链接在执行时进行&#xff0c;静态链接在编译时进行。其中A、C、D 都是动态链接的优点&#xff0c;B 时静态链接的优点。 减少页面交换可从如下角…

nginx-动静分离-防盗链-location-4

动静分离 为了加快网站的解析速度&#xff0c;可以把动态页面和静态页面有不同的服务器来解析&#xff0c;加快机械速度。降低原来单个服务器的压力。在动静分离的tomcat时候比较明显&#xff0c;因为tomcat解析静态很慢&#xff0c;其实这些原理的话很好理解&#xff0c;简单…

Baumer工业相机堡盟万兆网相机如何使用千兆网网卡环境保持帧率不变(C++)

项目场景 Baumer工业相机堡盟相机是一种高性能、高质量的工业相机&#xff0c;可用于各种应用场景&#xff0c;如物体检测、计数和识别、运动分析和图像处理。 Baumer的万兆网相机拥有出色的图像处理性能&#xff0c;可以实时传输高分辨率图像。此外&#xff0c;该相机还具…

IP、MAC和端口

IP&#xff0c;MAC和端口的概念MAC地址也叫物理地址、硬件地址&#xff0c;由网络设备厂家直接烧录在网卡上的&#xff0c;理论上Mac地址是唯一-的。 但因为Mac地址可以通过程序修改&#xff0c;所以也有可能会重复。IP地址是互联网上的每台设备都规定了-一个唯一的地址, 这个地…

网络安全之认识勒索病毒

一、什么是勒索病毒 勒索病毒&#xff0c;是一种新型电脑病毒&#xff0c;伴随数字货币兴起&#xff0c;主要以邮件、程序木马、网页挂马、服务器入侵、捆绑软件等多种形式进行传播&#xff0c;一旦感染将给用户带来无法估量的损失。如果遭受勒索病毒攻击&#xff0c;将会使绝…

如何用C语言实现渣男通讯录

注意&#xff1a;纯属玩笑&#xff0c;博大家一乐&#xff0c;切勿当真&#x1f4d6;首先我们要知道一个渣男通讯录有哪些信息要包含哪些功能1.你的通讯录要装多少个女朋友你得规定吧&#xff1b;2.每个女朋友的姓名&#xff0c;年龄&#xff0c;电话&#xff0c;爱好这些要有吧…

第29次CCFCSP认证经验总结

鄙人有幸参加了由中国计算机学会举办的第29次计算机软件能力认证考试&#xff0c;在此进行一些考试细节和经验的总结。 如果没有仔细了解过的小白去网上搜索CCFCSP&#xff0c;可能出现的是CSP-J/S&#xff0c;但是详细了解会发现&#xff0c;首先CSP-J/S分初试和复试&#xff…

.NET/C#/GC与内存管理(含深度解析)

详情请看参考文章&#xff1a;.NET面试题解析(06)-GC与内存管理 - 不灬赖 - 博客园 (cnblogs.com)一、对象创建及生命周期一个对象的生命周期简单概括就是&#xff1a;创建>使用>释放&#xff0c;在.NET中一个对象的生命周期&#xff1a;new创建对象并分配内存对象初始化…

【Linux】浅谈shell命令以及运行原理

前言&#xff1a;上篇博文把linux下的基本指令讲解完了。本期我们聊聊Linux下【shell】命令及其运行原理。 目录 Shell的基本概念与作用 原理图展示 shell命令执行原理 Shell的基本概念与作用 Linux严格意义上说的是一个操作系统&#xff0c;我们称之为“核心&#xff08;ker…

文心一言 VS ChatGPT,国产大模型和国外的差距有多大?

3月16号&#xff0c;百度正式发布了『文心一言』&#xff0c;这是国内公司第一次发布类ChatGPT的产品。大家一定非常好奇文心一言和chatgpt之间的差距有多大&#xff1f;国产大模型还有多少路可走&#xff1f;本文就全面测评这两款产品&#xff01; 目录 体验网址 1、旅游攻…

【vue2】vue2中的性能优化(持续更新中)

⭐ v-for 遍历避免同时使用 v-if ⭐ v-for 中的key绑定唯一的值 ⭐ v-show与v-if对性能的影响 ⭐ 妙用计算属性 ⭐ 使用防抖与节流控制发送频率 ⭐ 路由守卫处理请求避免重复发送请求 ⭐ 使用第三方UI库的引入方式 【前言】 该系列是博主在使用vue2开发项目中常用上的一…

这些IT行业趋势,将改变2023

上一周&#xff0c;你被"AI"刷屏了吗&#xff1f; 打开任何一家科技媒体&#xff0c;人工智能都是不变的热门话题。周初大家还在用ChatGPT写论文、查资料、写代码&#xff0c;到周末的时候大家已经开始用GPT-4图像识别来做饭、Microsoft 365 Copilot 来写PPT了。 GP…

【Linux】Linux基本指令(下)

前言&#xff1a; 紧接上期【Linux】基本指令&#xff08;上&#xff09;的学习&#xff0c;今天我们继续学习基本指令操作&#xff0c;深入探讨指令的基本知识。 目录 &#xff08;一&#xff09;常用指令 &#x1f449;more指令 &#x1f449;less指令&#xff08;重要&…