2023-10-21 美团2024秋招后端开发岗笔试题

1 考察dfs和拓扑排序

1.1 题目描述(如果拓扑排序不清楚可以去做一下lc 207. 课程表)

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

1.2 答案

import java.util.*;public class Meituan {static int m,n;public static void main(String[] args) {Scanner in = new Scanner(System.in);m = in.nextInt();n = in.nextInt();char[][]cs=new char[m][n];for(int i=0;i<m;i++){String s=in.next();for(int j=0;j<n;j++){cs[i][j]=s.charAt(j);}}mp.put('A','B');mp.put('B','C');mp.put('C','D');mp.put('D','E');mp.put('E','A');mp.put('#','F');for(int i=0;i<m;i++){for(int j=0;j<n;j++){if(cs[i][j]=='A'){cnt=0;mark=new boolean[m][n];dfs(cs,i,j);}if(f){System.out.println(-1);return;}}}System.out.println(ans);}static int ans=0;static int[]dirs=new int[]{-1,0,1,0,-1};static int cnt=0;static Map<Character,Character>mp=new HashMap<>();static boolean[][]mark=new boolean[m][n];static boolean f=false;static void dfs(char[][]cs, int p, int q){if(f){return;}for(int i=0;i<4;i++){int nx=p+dirs[i];int ny=q+dirs[i+1];if(nx>=0&&nx<m&&ny>=0&&ny<n){if(cs[nx][ny]==mp.get(cs[p][q])){if(mark[nx][ny]){f=true;return;}mark[nx][ny]=true;cnt++;ans=Math.max(ans,cnt);dfs(cs, nx,ny);cnt--;}}}}
}

1.3 测试案例

case1:结果-1 
2 5
ABCDE
EDCBAcase2:结果2
3 3
ABC
BEE
CEE

2 树的dfs

2.1 题目描述

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

case2:正确结果28
7
1 1 1 2 2 2 3
1 2
1 3
2 4
2 5
3 6
3 7
2
2 4
3 5

2.2 方法一:暴力O(N^2)复杂度

import java.util.*;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {static List<List<Integer>>list=new ArrayList<>();static int[]weight;public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();weight=new int[n];isColor=new int[n];for(int i=0;i<n;i++){int w = in.nextInt();weight[i]=w;}for(int i=0;i<n;i++){list.add(new ArrayList<>());}for(int i=0;i<n-1;i++){int a = in.nextInt()-1;int b = in.nextInt()-1;// System.out.println("a:"+a+",b:"+b);list.get(a).add(b);}int q=in.nextInt();for(int i=0;i<q;i++){int u=in.nextInt()-1;int x=in.nextInt();if(isColor[u]!=x)paint(u,x);}dfs(0);System.out.println(res);}static long res=0;static int[]isColor;static void dfs(int u){res+=weight[u];List<Integer>tmp=list.get(u);for(int i=0;i<tmp.size();i++){dfs(tmp.get(i));}}static void paint(int u,int x){weight[u]=x;isColor[u]=x;List<Integer>tmp=list.get(u);for(int i=0;i<tmp.size();i++){paint(tmp.get(i),x);}}}

2.3 方法三:O(N)复杂度

你的解决方法主要利用了深度优先搜索(DFS)和递归的思想。通过DFS遍历树的每个节点,并在遍历的过程中进行计算和状态更新。你还使用了一个时间戳的机制来记录每个节点最后一次被涂色的时间,以及使用了传递状态的方法来在递归调用中传递信息。

import java.util.*;public class Meituan {// 记录各个节点的子节点static List<List<Integer>>list=new ArrayList<>();// 记录权重以及特色时间戳static long[][]paintTime;// resultstatic long res=0;// 节点数static  int n;public static void main(String[] args) {Scanner in = new Scanner(System.in);n = in.nextInt();paintTime=new long[n][2];for(int i=0;i<n;i++){int w = in.nextInt();paintTime[i][1]=w;}for(int i=0;i<n;i++){list.add(new ArrayList<>());}for(int i=0;i<n-1;i++){int a = in.nextInt()-1;int b = in.nextInt()-1;list.get(a).add(b);}int q=in.nextInt();for(int i=0;i<q;i++){int u=in.nextInt()-1; // 节点int x=in.nextInt(); // 涂色值long timeStamp= System.currentTimeMillis();paintTime[u][0]=timeStamp;paintTime[u][1]=x;}sumDfs(0,paintTime[0][0],paintTime[0][1]);System.out.println(res);}static void sumDfs(int u, long timeStamp, long x){// 获取最新的被涂色的值long finalX=timeStamp>paintTime[u][0]?x:paintTime[u][1];long finalTimeStamp=Math.max(timeStamp,paintTime[u][0]);res+=finalX;List<Integer>tmp=list.get(u);for (int i = 0; i < tmp.size(); i++) {sumDfs(tmp.get(i),finalTimeStamp,finalX);}}
}

2.4 改编题:如果将涂色改为新加值或者减少值呢?

3 回文串相关

3.1 题目描述

小美拿到了两个长度为n的字符串a和b,她希望生成一个新的长度为n的字符串c,希望满足ci是从ai和bi中二选一生成的。小美想知道,最终可以生成的所有字符串中有多少种不同的回文串。由于答案过大,请对10^9+7取模。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于入侵杂草算法的无人机航迹规划-附代码

基于入侵杂草算法的无人机航迹规划 文章目录 基于入侵杂草算法的无人机航迹规划1.入侵杂草搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要&#xff1a;本文主要介绍利用入侵杂草算法来优化无人机航迹规划。 …

记录几个常用的docker镜像

背景 Docker 部署有着非常多的优势&#xff0c;可以帮助提高开发、测试和部署的效率&#xff0c;降低成本&#xff0c;使应用更具可移植性和可扩展性&#xff0c;包括但不限于 标准化应用发布&#xff0c;跨平台和主机使用&#xff1a;Docker的镜像提供了标准化发布环境&…

三篇论文:速览GPT在网络安全最新论文中的应用案例

GPT在网络安全领域的应用案例 写在最前面论文1&#xff1a;Chatgpt/CodeX引入会话式 APR 范例利用验证反馈LLM 的长期上下文窗口&#xff1a;更智能的反馈机制、更有效的信息合并策略、更复杂的模型结构、鼓励生成多样性和GPT类似的步骤&#xff1a;Conversational APR 对话式A…

Visual Studio Code的下载与安装

Visual Studio Code&#xff08;简称 VS Code&#xff09;是由 Microsoft 开发的免费、开源的文本编辑器&#xff0c;适用于多种操作系统&#xff0c;包括 Windows、macOS 和 Linux。它的设计目标是成为一款轻量级、高效的代码编辑工具&#xff0c;同时提供丰富的扩展和功能&am…

mysql查看数据表文件的存放路径

mysql查看数据表文件的存放路径_怎么看mysql表的位置在哪-CSDN博客 问题&#xff1a; 我们在mysql的安装目录中没有找到data&#xff08;数据库存放的地方&#xff09;的文件夹&#xff0c;我们需要找到数据库文件data的存放目录。 解决方法&#xff1a;在mysql的cmd中输入以下…

windows8080端口占用

查看端口占用 netstat -ano | findstr “8080”查看占用进程 tasklist | findstr “4664”关闭占用进程 taskkill /f /t /im httpd.exe

【Jenkins】新建任务FAQ

问题1. 源码管理处填入Repository URL&#xff0c;报错&#xff1a;无法连接仓库&#xff1a;Error performing git command: ls-remote -h https://github.com/txy2023/GolangLearning.git HEAD 原因&#xff1a; jenkins全局工具配置里默认没有添加git的路径&#xff0c;如果…

VBA技术资料MF75:测量所选单元格范围的高度和宽度

我给VBA的定义&#xff1a;VBA是个人小型自动化处理的有效工具。利用好了&#xff0c;可以大大提高自己的工作效率&#xff0c;而且可以提高数据的准确度。我的教程一共九套&#xff0c;分为初级、中级、高级三大部分。是对VBA的系统讲解&#xff0c;从简单的入门&#xff0c;到…

基于水循环算法的无人机航迹规划-附代码

基于水循环算法的无人机航迹规划 文章目录 基于水循环算法的无人机航迹规划1.水循环搜索算法2.无人机飞行环境建模3.无人机航迹规划建模4.实验结果4.1地图创建4.2 航迹规划 5.参考文献6.Matlab代码 摘要&#xff1a;本文主要介绍利用水循环算法来优化无人机航迹规划。 1.水循环…

51单片机-串口

电脑与单片机通过串口交互 设置波特率&#xff08;根据这个代码&#xff0c;去配置urt_Init()&#xff09; 参照上面配置下面这个&#xff0c;然后删掉上面这个代码 使用SUBF进行发送&#xff0c;TI0代表结束&#xff0c;结束后需要复位 下载、打开串口&#xff0c;设置波特率…

轻量封装WebGPU渲染系统示例<2>-彩色立方体(源码)

当前示例源码github地址: https://github.com/vilyLei/voxwebgpu/blob/version-1.01/src/voxgpu/sample/VertColorCube.ts 此示例渲染系统实现的特性: 1. 用户态与系统态隔离。 2. 高频调用与低频调用隔离。 3. 面向用户的易用性封装。 4. 渲染数据和渲染机制分离。 5. …

Jmeter 接口测试,参数值为列表,如何参数化?

最近在我的教学过程中&#xff0c;我的一个学生问了我一个问题&#xff0c;他们公司的一个接口参数值是列表&#xff0c;列表中值的数量有多有少&#xff0c;问我在 jmeter 中如何让这个参数的值进行参数化&#xff1f; 看到这种问题&#xff0c;你的第一反应是什么&#xff1f…

idea 提升效率的常用快捷键 汇总

点击File --> Settings --> keymap便可进入看到 IDEA 提供的快捷键。我们也可以搜索和自定义所有快捷键 下面13个事我常用的快捷键&#xff0c;后面还有全部&#xff0c;可以当做字典来查 1.当前文件下查找&#xff1a;CtrlF 当前文件下替换&#xff1a;CtrlR 2.当前…

postgresql 实践

1. 环境搭建 参考&#xff1a;http://www.lvesu.com/blog/main/cms-532.html 1.1. 安装依赖 # 需要安装 postgresql-devel 插件 yum install postgresql-devel* # 安装 pg 和 py 的驱动&#xff1a; # Debian系: apt-get install libpq-dev python-dev # RedHat系&#xff1…

NPM【问题 01】npm i node-sass@4.14.1报错not found: python2及Cannot download问题处理

node-sass安装问题处理 1.问题2.处理2.1 方案一【我的环境失败】2.2 方案二【成功】2.3 方案三【成功】 1.问题 gyp verb which failed Error: not found: python2 # 1.添加Python27的安装路径到环境变量 gyp verb check python checking for Python executable "python…

Controller接收Postman的raw参数时,属性值全部为空

Controller接收Postman的raw参数时&#xff0c;属性值全部为空 情景再现 在进行业务代码的编写过程中&#xff0c;使用Postman等工具调用Controller接口时&#xff0c;发现属性值全部为空后端代码如下&#xff1a; Requset对象为&#xff1a; public class QuerySkuRequest …

【期中复习】深度学习

文章目录 机器&#xff08;深度&#xff09;学习的四大核心要素为什么深度学习&#xff0c;不增加网络宽度黑盒模型的问题计算图线性神经网络梯度下降学习率优化方法softmax函数用于多分类交叉熵线性回归与softmax回归的对比为什么需要非线性激活函数感知机线性回归、softmax回…

Unity的碰撞检测(六)

温馨提示&#xff1a;本文基于前一篇“Unity的碰撞检测(五)”继续探讨两个游戏对象具备刚体的BodyType均为Dynamic&#xff0c;但是Collision Detection属性不同的碰撞检测&#xff0c;阅读本文则默认已阅读前文。 &#xff08;一&#xff09;测试说明 在基于两个游戏对象都具…

网络原理之TCP/IP

文章目录 应用层传输层UDP协议TCP协议TCP 的工作机制1. 确认应答2. 超时重传3. 连接管理TCP 的建立连接的过程(三次握手),和断开连接的过程(四次挥手)TCP 断开连接, 四次挥手 3. 滑动窗口5. 流量控制6. 拥塞控制7. 延时应答8. 捎带应答9. 面向字节流10. 异常情况 本章节主要讨论…

帆软report JS实现填报控件只能填写一次

效果 方法&#xff1a; 代码&#xff1a; if(this.getValue()!"")//判断这个控件框是否有值&#xff0c;这里是不为空{this.setEnable(false)}//不为空&#xff0c;则不能再修改else{this.setEnable(true)}//为空&#xff0c;可以编辑