当前位置: 首页 > news >正文

忻州市城乡建设局网站如何注册网上商城

忻州市城乡建设局网站,如何注册网上商城,网站开发毕设,如何做优化网站排alexa优化题目 分割数据 给你一个长度为偶数的整数数组nums。你需要将这个数组分割成nums1和nums2两部分#xff0c;要求#xff1a; nums1.lengthnums2.lengthnums.length/2。 nums1应包含互不相同的元素。 nums2也应包含互不相同的元素。 如果能够分割数组就返回true#xff0c;…题目 分割数据 给你一个长度为偶数的整数数组nums。你需要将这个数组分割成nums1和nums2两部分要求 nums1.lengthnums2.lengthnums.length/2。 nums1应包含互不相同的元素。 nums2也应包含互不相同的元素。 如果能够分割数组就返回true否则返回false。 解题思路 map计数如果数字出现次数超过2次则无法按题意分割。 class Solution {public boolean isPossibleToSplit(int[] nums) {MapInteger,Integermapnew HashMap();for(int num:nums){int countmap.getOrDefault(num,0);if (count2){return false;}map.put(num,count1);}return true;} }求交集区域内的最大正方形面积 在二维平面上存在n个矩形。给你两个下标从0开始的二维整数数组bottomLeft和topRight两个数组的大小都是nx2其中bottomLeft[i]和topRight[i]分别代表第i个矩形的左下角和右上角坐标。 我们定义向右的方向为x轴正半轴x坐标增加向左的方向为x轴负半轴x坐标减少。同样地定义向上的方向为y轴正半轴y坐标增加向下的方向为y轴负半轴y坐标减少。 你可以选择一个区域该区域由两个矩形的交集形成。你需要找出能够放入该区域内的最大正方形面积并选择最优解。 返回能够放入交集区域的正方形的最大可能面积如果矩形之间不存在任何交集区域则返回0。 解题思路 有n个矩形需要计算由两个矩形的交集形成的区域中可以放入的最大正方形面积。可以遍历每一对矩形计算交集区域内可以放入的最大正方形边长根据边长的平方计算最大正方形面积遍历所有矩形对之后即可得到最大正方形面积。 class Solution {public long largestSquareArea(int[][] bottomLeft, int[][] topRight) {long maxSquareArea 0;int n bottomLeft.length;for (int i 0; i n; i) {int[] bottomLeft1 bottomLeft[i];int[] topRight1 topRight[i];for (int j i 1; j n; j) {int[] bottomLeft2 bottomLeft[j];int[] topRight2 topRight[j];long squareArea overlapSquareArea(bottomLeft1, topRight1, bottomLeft2, topRight2);maxSquareArea Math.max(maxSquareArea, squareArea);}}return maxSquareArea;}public long overlapSquareArea(int[] bottomLeft1, int[] topRight1, int[] bottomLeft2, int[] topRight2) {int overlapWidth Math.max(Math.min(topRight1[0], topRight2[0]) - Math.max(bottomLeft1[0], bottomLeft2[0]), 0);int overlapHeight Math.max(Math.min(topRight1[1], topRight2[1]) - Math.max(bottomLeft1[1], bottomLeft2[1]), 0);long side Math.min(overlapWidth, overlapHeight);return side * side;} } 标记所有下标的最早秒数 I 给你两个下标从1开始的整数数组nums和changeIndices数组的长度分别为n和m。 一开始nums中所有下标都是未标记的你的任务是标记nums中所有下标。 从第1秒到第m秒包括第m秒对于每一秒s你可以执行以下操作之一 选择范围[1,n]中的一个下标i并且将nums[i]减少1。如果nums[changeIndices[s]]等于0标记下标changeIndices[s]。什么也不做。 请你返回范围[1,m]中的一个整数表示最优操作下标记nums中所有下标的最早秒数如果无法标记所有下标返回-1。 解题思路 二分计算 class Solution {public int earliestSecondToMarkIndices(int[] nums, int[] changeIndices) {int n nums.length;int m changeIndices.length;if (n m) {return -1;}int[] lastT new int[n];int left n - 1, right m 1;while (left 1 right) {int mid (left right) / 2;if (check(nums, changeIndices, lastT, mid)) {right mid;} else {left mid;}}return right m ? -1 : right;}private boolean check(int[] nums, int[] changeIndices, int[] lastT, int mx) {Arrays.fill(lastT, -1);for (int t 0; t mx; t) {lastT[changeIndices[t] - 1] t;}for (int t : lastT) {if (t 0) { // 有课程没有考试时间return false;}}int cnt 0;for (int i 0; i mx; i) {int idx changeIndices[i] - 1;if (i lastT[idx]) { // 考试if (nums[idx] cnt) { // 没时间复习return false;}cnt - nums[idx]; // 复习这门课程} else {cnt; // 留着后面用}}return true;} } 标记所有下标的最早秒数 II 给你两个下标从1开始的整数数组nums和changeIndices数组的长度分别为n和m。 一开始nums中所有下标都是未标记的你的任务是标记nums中所有下标。 从第1秒到第m秒包括第m秒对于每一秒s你可以执行以下操作之一 选择范围[1,n]中的一个下标i并且将nums[i]减少1。将nums[changeIndices[s]]设置成任意的非负整数。 选择范围[1,n]中的一个下标i满足nums[i]等于0,并标记下标i。什么也不做。 请你返回范围[1,m]中的一个整数表示最优操作下标记nums中所有下标的最早秒数如果无法标记所有下标返回-1。 解题思路 二分加贪心 class Solution {public int earliestSecondToMarkIndices(int[] nums, int[] changeIndices) {int n nums.length;int m changeIndices.length;if (n m) {return -1;}long slow n; // 慢速复习考试所需天数for (int v : nums) {slow v;}int[] firstT new int[n];Arrays.fill(firstT, -1);for (int t m - 1; t 0; --t) {firstT[changeIndices[t] - 1] t;}PriorityQueueint[] pq new PriorityQueue((a, b) - a[0] - b[0]);int left n - 1, right m 1;while (left 1 right) {pq.clear();int mid (left right) / 2;if (check(nums, changeIndices, firstT, pq, slow, mid)) {right mid;} else {left mid;}}return right m ? -1 : right;}private boolean check(int[] nums, int[] changeIndices, int[] firstT, PriorityQueueint[] pq, long slow, int mx) {int cnt 0;for (int t mx - 1; t 0; t--) {int i changeIndices[t] - 1;int v nums[i];if (v 1 || t ! firstT[i]) {cnt;continue;}if (cnt 0) {if (pq.isEmpty() || v pq.peek()[0]) {cnt 1; continue;}slow nums[pq.poll()[1]] 1;cnt 2;}slow - nums[i] 1;cnt--; pq.offer(new int[]{v, i});}return cnt slow; } }总结 当前我的算法能力提升似乎遇到了平台期解题效率停滞不前。为了突破这一阶段我计划采取多元化的学习策略不再拘泥于单一的学习方法或资源。我将拓宽学习渠道包括研读算法专著、观看教程视频、参与网络课程以及加入研讨会以此来丰富我的知识体系并提高解题技巧。 来源 LeetCode官网
http://www.pierceye.com/news/586311/

相关文章:

  • 怎么用vps做网站论坛网站建设视频
  • 广州网站制作实力乐云seowordpress 评论模块
  • 永久免费制作网站木门行业做网站有什么好处
  • 怎么区分模板网站wordpress菜单怎么建
  • 网站开发最新效果企业手机网站建
  • 网站群管理系统哪个好wordpress制作会员功能
  • 做套现网站网站的访问量
  • 做网站网页需要学些什么做网站学的什么专业
  • 建设银行的官方网站纪念币公司宣传页设计印刷
  • 网站左侧图片悬浮代码常州工厂网站建设
  • 智慧团建网站怎么转团关系app制作开发小程序制作开发
  • 誉字号网站wordpress 展示模板下载
  • 网站不接入备案成都市建设工程质量协会网站
  • 企业网站html网站开发济南招聘
  • 网站html优化方法音乐网站开发参考文献
  • 网站建设及推广方案ppt模板微信小程序开发工具下载哪个版本
  • 固安县城乡和住房建设局网站科技公司手机端网站
  • 寿光网站建设思科企业网络拓扑图
  • 中国建设银行河南省分行网站建筑人才服务中心官网
  • 响应式app网站模板单页淘宝客网站2014年行吗
  • 西安网站推广优化高端定制网站开发设计建站流程
  • m版网站开发公司如何做网络推广营销
  • 济宁商城网站开发设计网址源码在线查看
  • 网站建设公司介绍百度电脑怎么用wordpress
  • 宛城区网站建设广东seo推广方案
  • 北京建网站定制价格网站风格总结
  • 如何建设一个购物网站wordpress 优酷插件
  • 你们网站做301网站开发规模和工作量的计算
  • 班级网站建设甘肃住房和城乡建设厅网站
  • 网站建设哪家性价比高住房和城乡建设部网站办事大厅里边