Acwing——第 87 场周赛

news/2024/11/28 23:53:42/

题目链接

4797. 移动棋子
4798. 打怪兽
4799. 最远距离

题目描述

4797. 移动棋子

给定一个 5 行 5 列的方格矩阵,其中一个方格中有一个棋子。

现在,我们希望将棋子移动至矩阵的最中心方格中,即将其移动至矩阵的第 3行第 3列方格中。

每次移动可以将棋子沿上、下、左、右任一方向移动一格距离,前提是不能移出矩阵。

请你计算,为了将棋子移动至矩阵的最中心方格中,所需要的最少移动次数。

如果棋子一开始就在最中心方格中,则无需移动。

输入格式

输入共 5行,每行包含 5个整数,其中第 i 行第 j 列的整数表示第 i 行第 j 列方格的状态,如果为 0,则表示该方格中没有棋子,如果为 1,则表示该方格中有棋子。

保证只有一个方格中有棋子。

输出格式

一个整数,表示所需要的最少移动次数。

数据范围

所有测试点满足,输入恰好包含 24 个 0 和 1 个 1。

输入样例1:

0 0 0 0 0
0 0 0 0 1
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0

输出样例1:

3

输入样例2:

0 0 0 0 0
0 0 0 0 0
0 1 0 0 0
0 0 0 0 0
0 0 0 0 0

输出样例2:

1

输入样例3:

0 0 0 0 0
0 0 0 0 0
0 0 1 0 0
0 0 0 0 0
0 0 0 0 0

输出样例3:

0

分析:
根据题意 直接返回 值为1的坐标(x,y) 与 中心点(3,3) 的 曼哈顿距离

时间复杂度:O(1)O(1)O(1)

代码:

#include<iostream>
#include<cmath>
using namespace std;const int N = 10;
int a[N][N];int main(){int x = -1,y = -1;for(int i = 1;i <= 5;i++){for(int j = 1;j <= 5;j++){cin>>a[i][j];//如果 a[i][j] == 1 则记录下 下标 i 和 jif(a[i][j]){x = i;y = j;}}}cout<<abs(x-3) + abs(y-3)<<endl;return 0;
}

4798. 打怪兽

n个怪兽(编号 1∼n1∼n1n),其中第 iii个怪兽的防御值为 aia_iai

你是一个魔法师,初始时拥有 mmm 点法力值。

当你的法力值大于 0 时,你可以对怪兽发动攻击,每一次攻击具体为:

  • 任意选择 1∼2个怪兽,并消耗 x 点法力值(x 可以是一个不超过你当前法力值的任意正整数),对每个所选怪兽发动一次伤害为 x的攻击。
  • 对于受到攻击的怪兽,如果其防御值小于或等于 x,则会被你消灭。否则,它将免疫此次攻击,不受任何影响。

请你确定最大的整数 k,满足:通过合理安排攻击,可以将第 1∼k1∼k1k 个怪兽全部消灭。

输入格式

第一行包含整数 n,mn,mn,m

第二行包含 nnn个整数 a1,a2,…,ana_1,a_2,…,a_na1,a2,,an

输出格式

一个整数,表示最大的整数 k。

数据范围

所有测试点满足

  • 1≤n≤10001≤n≤10001n1000
  • 1≤m≤1091≤m≤10^91m109
  • 1≤ai≤m1≤a_i≤m1aim

输入样例1:

5 7
2 3 5 4 1

输出样例1:

3

输入样例2:

10 10
9 1 1 1 1 1 1 1 1 1

输出样例2:

4

输入样例3:

5 10
3 1 4 2 4

输出样例3:

5

分析:

我们可以通过 二分 的方式不断地来逼近 k。

此外我们还需要一个 check()check()check() 函数,来判断我们当前二分的 midmidmid 是否是符合要求的。如果 check(mid)==truecheck(mid) == truecheck(mid)==true 说明满足要求,那么将 左区间 leftleftleft 更新为 midmidmid;否则说明选择的 midmidmid 太大了,所以更新 右区间 rightrightrightmid−1mid - 1mid1

check()check()check() 函数内部:

  • 由于是任意选择的,所以必然将数组排好序从小大大选,花费的法力值更少(因因为可能要二分很多次,所以这里直接新建一个原数组的副本(1−mid1 - mid1mid))。
  • 我们定义 f(i)f(i)f(i) 为消灭前 i 个怪兽,所需要的最少法力值。
    • 状态转移:f(i)=min(f(i−1)+a[i],f(i−2)+max(a[i−1],a[i]))f(i) = min(f(i-1) + a[i],f(i-2) + max(a[i-1],a[i]))f(i)=min(f(i1)+a[i],f(i2)+max(a[i1],a[i]))
  • 最后只需要判断 f(mid)<=mf(mid) <= mf(mid)<=m 即可。

时间复杂度:O(n∗log2(n))O(n * log^2(n))O(nlog2(n))

代码:

#include<iostream>
#include<vector>
#include<algorithm>
#include<cstring>
using namespace std;
using LL = long long;const int N = 1010;
int a[N];
LL f[N];
int n,m;bool check(int k){//每次要将 f 置为0memset(f,0,sizeof f);vector<int> arr(k+1);//赋值 a[1] ~ a[k] 到 arr副本中for(int i = 1;i <= k;i++) arr[i] = a[i];sort(arr.begin(),arr.end());f[1] = arr[1];f[2] = max(arr[1],arr[2]);for(int i = 3;i <= k;i++){f[i] = min(f[i-2]+max(arr[i-1],arr[i]),f[i-1]+arr[i]);}return f[k] <= m;
}int main(){cin>>n>>m;for(int i = 1;i <= n;i++) cin>>a[i];//二分int l = 1,r = n;while(l<r){//因为是 l = mid 所以二分的时候需要加1 避免边界问题int mid = (l + r + 1) >> 1;if(check(mid)) l = mid;else r = mid - 1;}cout<<l<<endl;return 0;
}

4799. 最远距离

我们规定,如果一个无向连通图满足去掉其中的任意一条边都会使得该图变得不连通,则称该图为有效无向连通图

给定一个 nnn个点 mmm 条边的有效无向连通图,点的编号为 1∼n1∼n1n,所有边的长度均为 1。

两点之间的距离定义为两点之间的最短距离

请你计算,给定图中距离最远的两个点之间的距离

输入格式

第一行包含两个整数 n,mn,mn,m

接下来 mmm 行,每行包含两个整数 a,ba,ba,b,表示点 aaa和点 bbb 之间存在一条无向边。

输出格式

一个整数,表示给定图中距离最远的两个点之间的距离。

数据范围

所有测试点满足

  • 1≤n,m≤1051≤n,m≤10^51n,m105
  • 1≤a,b≤n1≤a,b≤n1a,bn
  • a≠ba≠ba=b

输入样例1:

4 3
1 2
1 3
1 4

输出样例1:

2

输入样例2:

5 4
1 2
2 3
3 4
3 5

输出样例2:

3

分析:

本题可以通过 两遍DFS 解决。

我们先挑选 任意一个点 uuu 出发,第一遍DFS 求出距离 uuu 最远的点 vvv
第二遍DFS求出 vvv 的最远端点 eee,此时 vvveee 之间就是最长的距离。

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

时间复杂度:O(n)O(n)O(n)

代码:

#include<iostream>
#include<vector>
using namespace std;const int N = 1e5+10;int n,m, c, d[N];
vector<int> E[N];void dfs(int u, int fa) {for (int v : E[u]) {if (v == fa) continue;d[v] = d[u] + 1;if (d[v] > d[c]) c = v;dfs(v, u);}
}int main() {scanf("%d%d", &n,&m);for (int i = 1; i <= m; i++) {int u, v;scanf("%d %d", &u, &v);//因为是无向图,要建两条边E[u].push_back(v), E[v].push_back(u);}//从 1点 开始dfsdfs(1, -1);//此时的 c点 就是距离 1点最远的点d[c] = 0;//再以c点为起点,求得的最长距离 d[c] 就是答案dfs(c, -1);printf("%d\n", d[c]);return 0;
}

http://www.ppmy.cn/news/18602.html

相关文章

Cheat Engine7.4 训练教程(非常详细)

目录 一.CE是干什么的&#xff1f; 二.怎么获得&#xff1f; 三.训练教程 步骤 1: 加载进程 步骤 2: 精确值扫描 步骤 3: 未知的初始值 步骤 4: 浮点数 步骤 5: 代码查找 步骤 6: 指针 步骤 7: 代码注入 步骤 8: 多级指针 提示&#xff1a;这篇文章不是一天写完的&a…

领域驱动设计(DDD)的几种典型架构介绍

我们生活中都听说了DDD&#xff0c;也了解了DDD&#xff0c;那么怎么将一个新项目从头开始按照DDD的过程进行划分与架构设计呢&#xff1f; 一、专业术语 各种服务 IAAS&#xff1a;基础设施服务&#xff0c;Infrastructure-as-a-service PAAS&#xff1a;平台服务&#xff0c…

铸造性能监控平台【grafana+influxdb/prometheus+Linux/Windows】

目录一、grafanainfluxdbjmeter1、前言2、安装grafana和influxdb3、启动grafana4、访问grafana5、启动influxdb6、配置influxdb和jmeter7、在grafana中显示数据8、其他模板二、grafanaprometheusexporter1、前言2、grafana启动3、exporter安装与运行4、prometheus安装与运行5、…

Windows使用Paddle训练好的模型进行OpenVino推理引擎下的部署

目录一. Openvino下载二. 准备模型2.1 导出Paddle Inference模型2.2 转换为ONNX模型2.3 转换为ONNX模型2.3.1 获取部署代码2.3.2 环境准备2.3.3 编译一. Openvino下载 根据Paddle官方的描述&#xff0c;当前检测模型转换为openvino格式是有问题的&#xff0c;暂时只支持分割和…

宝贝代码部署笔记

记录前后端分离项目部署到云服务器&#xff1b;前端使用vue&#xff0c;element-ui&#xff0c;axios&#xff0c;router进行开发&#xff1b;后端使用springboot&#xff0c;mybatis&#xff0c;MySQL进行开发&#xff1b;完整记录前端项目npm打包静态文件&#xff0c;后端项目…

珍惜能在公司上班的每一天——2022年个人工作总结

本文由Markdown语法编辑器编辑完成。 1. 前言: 2022年不知不觉就过去了。在过去的一年里&#xff0c;虽然身在北京&#xff0c;哪里也没有去&#xff0c;但还是避免不了受到疫情的影响&#xff0c;被封控在家。 就在刚过去的一段时间&#xff0c;从11月18日周五下班&#xff…

详解Map和Set

目录 一、二叉搜索树 1、概述 2、模拟实现搜索二叉树 a、向搜索二叉树中插入数据 b、查找二叉搜索树的指定值的结点 c、删除二叉树的指定值的结点 3、对二叉搜索树进行性能分析 二、Map的使用 1、Map简介 2、Map常用方法 ​编辑三、Set的使用 1、Set简介 2、S…

初识C语言:IDE的选择与使用【C语言】

本文是本专栏【C语言】的第一篇文章&#xff0c;也是博主最近半年以来的更新第一篇文章&#xff0c;如果觉得有帮助&#xff0c;可以点赞支持一下&#xff01;另外本专栏最后会做一篇类似于【python爬虫】专栏最后的那篇整合的文章&#xff0c;把C语言的所有基础知识用一篇文章…