美团2024届秋招笔试第一场编程真题(js版本)

2024-01-12 19:52

本文主要是介绍美团2024届秋招笔试第一场编程真题(js版本),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.小美的外卖订单

        简单的加法逻辑,需要注意的是各个数据的边界问题

  1. 折扣价不能超过原价
  2. 减的价格不能超过满的价格
  3. 满减优惠仅限原价购入
const rl = require("readline").createInterface({ input: process.stdin });
void (async function () {let count = 0;let list = [];let man = 0,jian = 0;rl.on("line", function (line) {if (count === 0) {count = parseInt(line);} else if (list.length < count) {const item = line.split(" ");list.push([parseFloat(item[0]), parseFloat(item[1])]);} else {const item = line.split(" ");man = parseFloat(item[0]);jian = parseFloat(item[1]);console.log(getPrices(list, man, jian));}});
})();function getPrices(list, man, jian) {if(jian > man || man <= 0 || jian <= 0) return 'error'let prices1 = 0,prices2 = 0;for (let i = 0; i < list.length; i++) {if (list[i][1] > list[i][0] || list[i][1] <= 0 || list[i][0] <= 0) return "error";prices1 += list[i][0];prices2 += list[i][1];}if (prices1 >= man) {prices1 -= jian;}return prices1 > prices2 ? prices2.toFixed(2) : prices1.toFixed(2);
}

2.小美的字符串匹配度

  1. 第一步计算s和t中不操作的匹配度,也就是s[i] === t[i] 的个数
  2. 第二步,计算对t操作一次能增加的匹配的
const rl = require("readline").createInterface({ input: process.stdin });void async function () {let length = 0;let s = '',t = '';// Write your code hererl.on('line',function(line){if(length === 0) {length = parseInt(line)} else if(s === '') {s = line;} else {t = line;console.log(computed(s,t))}})
}()
function computed(s, t) {//计算原本的匹配度let baseCount = 0;//记录无需交换操作的下标let used = new Array(s.length).fill(false);for (let i = 0; i < s.length; i++) {if (s[i] == t[i]) {used[i] = true;baseCount++;}}//计算操作一次增加的匹配度  1 or 2let changeCount = 0;for (let i = 1; i < t.length; i++) {//原本就匹配的,无需交换if (used[i]) continue;for (let j = i + 1; j < s.length; j++) {//原本就匹配的,无需交换if (used[j]) continue;// 满足交换后一个相等 继续执行// 满足两个相等,直接返回,操作一次最多怎加两个pipeiduif (t[i] === s[j]) {changeCount = 1;if (t[j] === s[i]) {return baseCount + 2;}}}}return baseCount + changeCount;
}

3.小美的树上染色

贪心算法: 最优解就是从每条路径的叶子节点开始染红

const rl = require("readline").createInterface({ input: process.stdin });
let nodeValue = [];
let edgeMap = new Map()
void async function () {let start = 0;let nodeCount = 0;rl.on('line',function(line) {if(nodeCount === 0) {nodeCount = parseInt(line);} else if(nodeValue.length === 0) {nodeValue = line.split(' ').map(_ => parseInt(_))} else {start++;const item = line.split(' ')edgeMap.set(item[0],[...(edgeMap.get(item[0]) || []),item[1]])if(start == nodeCount - 1) {let hasVisited = []dfs('1',hasVisited);console.log(hasVisited.length)}}})
}()function dfs(u,hasVisited) {//循环可到达if(edgeMap.has(u)) {for(let x of edgeMap.get(u)) {dfs(x,hasVisited);//遍历到每条线的末尾,叶子节点if(Math.sqrt(nodeValue[x-1] * nodeValue[u - 1]) % 1 === 0 && !hasVisited.includes(x) && !hasVisited.includes(u)) {hasVisited.push(x);hasVisited.push(u);}}}
}

4.小美的排列询问

简单无脑过: 找到x的位置,如果在x前后找到y就是yes

const rl = require("readline").createInterface({ input: process.stdin });void (async function () {let nodeCount = 0;let list = [];let x = null,y = null;rl.on("line", function (line) {if (nodeCount === 0) {nodeCount = parseInt(line);} else if (list.length === 0) {list = line.split(" ");} else {[x, y] = line.split(" ");let flag = "No";for (let i = 0; i < nodeCount - 1; i++) {if ((list[i] == x && list[i + 1] == y) ||(list[i] == y && list[i + 1] == x)) {flag = "Yes";break;}}console.log(flag);}});
})();

5.小美的排列构造

要让相邻两项的和的差值最小,排列需要满足第一大挨着第一小,第二大挨着第二小。例如n=6,满足要求的排列可以是[6,1,5,2,4,3],也可以是[1,6,2,5,3,4],权值都是0

题外话: n为偶数,权值为0,n为奇数,权值为 Math.ceil(n / 2)

const rl = require("readline").createInterface({ input: process.stdin });void (async function () {let count = 0;rl.on("line", function (line) {if (count === 0) {count = parseInt(line);let list = "";let i = 1,j = count;while (i < j) {list = list + i + " " + j + " ";j--;i++;}if (count % 2 === 1) {list += j;}console.log(list.trimEnd());}});
})();

6.小美走公路

公路是环形的,可以顺时针走,也可以逆时针走,要求最短距离。

设x到y的直线距离是distanceA,从任意点顺时针走一圈的距离是distanceB, distanceB-distanceA代表x到y的绕圈距离,答案就是distanceA和distanceB-distanceA的最小值

const rl = require("readline").createInterface({ input: process.stdin });void (async function () {let stationCount = 0;let distance = [];let start = 0,end = 0;rl.on("line", function (line) {if (stationCount === 0) {stationCount = parseInt(line);} else if (distance.length === 0) {distance = line.split(" ").map((_) => parseInt(_));} else {[start, end] = line.split(" ").map((_) => parseInt(_));console.log(getDistance(distance, start, end));}});
})();function getDistance(distance, start, end) {//跑一圈 a点到a点const oneCircle = distance.reduce((total, cur) => total + cur, 0);//记录距离let total = 0;if (start > end) {//直线距离[start, end] = [end, start];}for (let i = start; i < end; i++) {total += distance[i - 1];}//直线距离 ? 还是绕一圈 ?return Math.min(total, oneCircle - total);
}

7.小美的好矩阵

直接遍历矩阵,然后判定

const rl = require("readline").createInterface({ input: process.stdin });void (async function () {let n = 0,m = 0;let matrix = [];rl.on("line", function (line) {if (n == 0) {const item = line.split(" ");n = parseInt(item[0]);m = parseInt(item[1]);} else {matrix.push(line.split(""));if (matrix.length === n) {console.log(getButyNum(matrix, n, m));}}});
})();
function getButyNum(matrix, n, m) {let count = 0;if (n < 3 || m < 3) return count;for (let i = 0; i <= n - 3; i++) {for (let j = 0; j <= m - 3; j++) {if (isButy(matrix, i, j)) {count++;}}}return count;
}
function isButy(matrix, p, q) {let a = false,b = false,c = false;for (let i = p; i < p + 3; i++) {for (let j = q; j < q + 3; j++) {if (matrix[i][j] === "A") {a = true;} else if (matrix[i][j] === "B") {b = true;} else if (matrix[i][j] === "C") {c = true;} else {return false;}if (i - 1 >= p && matrix[i][j] === matrix[i - 1][j]) {return false;}if (i + 1 < p + 3 && matrix[i][j] === matrix[i + 1][j]) {return false;}if (j - 1 >= q && matrix[i][j] === matrix[i][j - 1]) {return false;}if (j + 1 < q + 3 && matrix[i][j] === matrix[i][j + 1]) {return false;}}}return a && b && c;
}

8.小美的蛋糕切割

由于不能把某个小正方形切成两个区域,所有的切法就是n-1种沿着行切开和m-1种沿着列切开,分别计算n+m-2种美味度的差值,取最小值

const rl = require("readline").createInterface({ input: process.stdin });void async function () {let n = 0,m = 0;let matrix = [];rl.on('line',function(line) {if(n == 0) {const item = line.split(" ")n = parseInt(item[0])m = parseInt(item[1])} else {matrix.push(line.split(" "));if(matrix.length === n) {console.log(getMiniDiff(matrix, n, m));}}})
}()
function getMiniDiff(matrix, n, m) {//分别计算每行每列美味值,以及整个蛋糕的美味值let rows = new Array(n).fill(0);let columns = new Array(m).fill(0);let total = 0;for(let i=0;i<n;i++) {for(let j=0;j<m;j++) {const value = parseInt( matrix[i][j])rows[i] += valuecolumns[j] += valuetotal += value}}let diff = total;//查询按照行切割,美味差值let sum = 0;for(let i=0;i<rows.length;i++) {sum += rows[i];diff = Math.min(diff,Math.abs(2*sum - total))}//查询按照列切割,美味差值sum = 0;for(let j=0;j<columns.length;j++) {sum+=columns[j];diff = Math.min(diff,Math.abs(2*sum - total))}//return diff
}

9.小美的字符串变换

先暴力算出满足要求的矩阵的x,y组合,再挨个计算出每种矩阵的连通块数量(深度遍历dfs),取最小值

const rl = require("readline").createInterface({ input: process.stdin });void (async function () {let count = 0;rl.on("line", function (line) {if (count === 0) {count = parseInt(line);} else {console.log(getBlocks(count, line));}});
})();
function getBlocks(count, str) {//计算可能x y组合let group = [];for (let i = 1; i <= count; i++) {for (let j = 1; j <= count; j++) {if (i * j == count) {group.push([i, j]);}}}//分别计算矩阵let result = str.length;for (let k = 0; k < group.length; k++) {const x = group[k][0];const y = group[k][1];let temp = 0;//记录当前矩阵连通块数量let list = str.split("");for (let i = 0; i < x; i++) {for (let j = 0; j < y; j++) {if (list[i * y + j] !== "0") {temp++;dfs(x, y, list, i, j, list[i * y + j]);}}}result = Math.min(result, temp);}return result;
}
function dfs(x, y, list, i, j, flag) {//判定i,j合法性if (!(i >= 0 && i < x && j >= 0 && j < y)) {return;}//不和参考相等就退出if (list[i * y + j] != flag) {return;}//当前重置为0,再向上下左右拓展list[i * y + j] = "0";dfs(x, y, list, i - 1, j, flag);dfs(x, y, list, i + 1, j, flag);dfs(x, y, list, i, j - 1, flag);dfs(x, y, list, i, j + 1, flag);
}

总结: 稍微难一点的是3题和9题,需要对【贪心算法+图+深度优先算法】有一些了解,其余的都是考验基本编程能力和动点小脑筋的题目(考察透过题目直击根本逻辑的能力)。

不足:虽然都做出来了,但是耗时太长。大概是有做题恐惧症>.< ,一想到自己在做题,脑袋就不能思考了,一旦停止考试,脑袋就工作正常了。害,还是经历的少了,多做几套大概就好了。

这篇关于美团2024届秋招笔试第一场编程真题(js版本)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/598977

相关文章

JS常用组件收集

收集了一些平时遇到的前端比较优秀的组件,方便以后开发的时候查找!!! 函数工具: Lodash 页面固定: stickUp、jQuery.Pin 轮播: unslider、swiper 开关: switch 复选框: icheck 气泡: grumble 隐藏元素: Headroom

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

在JS中的设计模式的单例模式、策略模式、代理模式、原型模式浅讲

1. 单例模式(Singleton Pattern) 确保一个类只有一个实例,并提供一个全局访问点。 示例代码: class Singleton {constructor() {if (Singleton.instance) {return Singleton.instance;}Singleton.instance = this;this.data = [];}addData(value)

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

Node.js学习记录(二)

目录 一、express 1、初识express 2、安装express 3、创建并启动web服务器 4、监听 GET&POST 请求、响应内容给客户端 5、获取URL中携带的查询参数 6、获取URL中动态参数 7、静态资源托管 二、工具nodemon 三、express路由 1、express中路由 2、路由的匹配 3、路由模块化 4、路由模块添加前缀 四、中间件