荣耀笔试三题,分值为100 100 300 第一题:大端小端 考点:字符串相关API应用:分割、翻转、拼接不说了,注意最后输出的是拼接后的字符串即可 第二题:会议室使用最长时间 题目大意:一个会议室早8晚23时间段内可预约会议,该时间段可以接收n个预约,预约格式为start_i, end_i,你作为秘书要保证会议室使用时间最长输入:第一行为T,表示有T组测试用例,第二行表示有n个预约,其余表示预约start和end 1615 178 1110 1611 1213 159 12输出: 8解题思路:动态规划 function fn(times) { // 按照开始时间进行排序 times.sort((a, b) => a[0]-b[0]); let dp = new Array(24).fill(0); for (let i = 0; i < times.length;i++) { let s = times[i][0], e = times[i][1]; for (let j = 23; j >= e; j--) { dp[j] = Math.max(dp[s]+e-s, dp[j]); } } return Math.max(...dp);}// testlet times = [ [15,17], [9,11], [10,16], [11,12], [13,15], [9,12],];console.log(fn(times)); // 8 这题最需要注意的就是T标明的是测试用例的组数,示例误导地给了1,所以一开始只通过了10%,实际上读取T之后,需要通过while(T--)来继续读取后面的测试用例 第三题:仓库容量 题目大意:有M个货物,重量是不一样的,要放到2个仓库里面,2个仓库的容量一样大,仓库容量至少需要多大输入:第一行为M,表示M个货物,第二行有M个数,表示每个货物重量,货物重量没有经过排序 311 17 8输出: 19解释:11和8放在一个仓库,17放在一个仓库,至少需要容量大小为19解题思路:题目思路转换一下就是求‘分割数组使两个子数组的和最为接近,且输出最大和的子数组’我用的二分法,没有A,有空试试01背包吧 function fn(weights) { weights = weights.sort((a, b) => a - b); // left _ 最大值 right _ 容量和 let left = Math.max(...weights), right = weights.reduce((a, b) => a + b); // 仓库容量在[left, right]之间 while (left < right) { let mid = Math.floor((left + right) / 2); if (helper(mid)) { // 大于两个仓库说明目标容量是不够的,需要扩张 left = mid + 1; } else { right = mid; // 小于或者等于两个仓库,收缩right边界,直至最佳 } } return left; function helper(target) { // cur _ 记录所需仓库数量 sum _ 商品累计容量 let cur = 1, sum = 0; for (let i = 0; i < weights.length; i++) { if (sum + weights[i] > target) { // 超过目标容量,不能再继续添加了 sum = weights[i]; // 重新计算容量总和 cur++; // 另起一个仓库 } else { sum += weights[i]; } } return cur > 2; // 判断是否大于2个仓库 }}// testlet weights = [11, 17, 8];console.log(fn(weights)); // 19