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

购物网站的建设思维导图wordpress本站只对会员开放

购物网站的建设思维导图,wordpress本站只对会员开放,ui设计现在好找工作吗,潍坊企业做网站题目: 2736. 最大和查询 给你两个长度为 n 、下标从 0 开始的整数数组 nums1 和 nums2 ,另给你一个下标从 1 开始的二维数组 queries ,其中 queries[i] [xi, yi] 。 对于第 i 个查询,在所有满足 nums1[j] > xi 且 nums2[j]…

题目:

2736. 最大和查询

给你两个长度为 n 、下标从 0 开始的整数数组 nums1 和 nums2 ,另给你一个下标从 1 开始的二维数组 queries ,其中 queries[i] = [xi, yi] 。

对于第 i 个查询,在所有满足 nums1[j] >= xi 且 nums2[j] >= yi 的下标 j (0 <= j < n) 中,找出 nums1[j] + nums2[j] 的 最大值 ,如果不存在满足条件的 j 则返回 -1 。

返回数组 answer ,其中 answer[i] 是第 i 个查询的答案。

示例 1:

输入:nums1 = [4,3,1,2], nums2 = [2,4,9,5], queries = [[4,1],[1,3],[2,5]]
输出:[6,10,7]
解释:
对于第 1 个查询:xi = 4且 yi = 1,可以选择下标 j = 0 ,此时 nums1[j] >= 4且 nums2[j] >= 1。nums1[j] + nums2[j]等于 6 ,可以证明 6 是可以获得的最大值。
对于第 2 个查询:xi = 1 且 yi = 3 ,可以选择下标 j = 2,此时 nums1[j] >= 1且 nums2[j] >= 3。nums1[j] + nums2[j]等于 10 ,可以证明 10 是可以获得的最大值。
对于第 3 个查询:xi = 2且 yi = 5,可以选择下标 j = 3 ,此时 nums1[j] >= 2且 nums2[j] >= 5。nums1[j] + nums2[j]等于 7 ,可以证明 7 是可以获得的最大值。
因此,我们返回 [6,10,7]。

示例 2:

输入:nums1 = [3,2,5], nums2 = [2,3,4], queries = [[4,4],[3,2],[1,1]]
输出:[9,9,9]
解释:对于这个示例,我们可以选择下标 j = 2,该下标可以满足每个查询的限制。

示例 3:

输入:nums1 = [2,1], nums2 = [2,3], queries = [[3,3]]
输出:[-1]
解释:示例中的查询 xi = 3 且 yi= 3 。对于每个下标 j ,都只满足 nums1[j] < xi或者 nums2[j] <yi。因此,不存在答案。 

提示:

  • nums1.length == nums2.length 
  • n == nums1.length 
  • 1 <= n <= 105
  • 1 <= nums1[i], nums2[i] <= 109 
  • 1 <= queries.length <= 105
  • queries[i].length == 2
  • xi == queries[i][1]
  • yi == queries[i][2]
  • 1 <= xi, yi <= 109

解答:

 

代码:

class Solution {public int[] maximumSumQueries(int[] nums1, int[] nums2, int[][] queries) {int n=nums1.length;int[][] sortedNums=new int[n][2];for(int i=0;i<n;i++){sortedNums[i][0]=nums1[i];sortedNums[i][1]=nums2[i];}Arrays.sort(sortedNums,(a,b)->b[0]-a[0]);int q=queries.length;int[][] sortedQueries=new int[q][3];for(int i=0;i<q;i++){sortedQueries[i][0]=i;sortedQueries[i][1]=queries[i][0];sortedQueries[i][2]=queries[i][1];}Arrays.sort(sortedQueries,(a,b)->b[1]-a[1]);List<int[]> stack=new ArrayList<int[]>();int[] answer=new int[q];Arrays.fill(answer,-1);int j=0;for(int[] query:sortedQueries){int i=query[0],x=query[1],y=query[2];while(j<n&&sortedNums[j][0]>=x){int[] pair=sortedNums[j];int num1=pair[0];int num2=pair[1];while(!stack.isEmpty()&&stack.get(stack.size()-1)[1]<=num1+num2){stack.remove(stack.size()-1);}if(stack.isEmpty()||stack.get(stack.size()-1)[0]<num2){stack.add(new int[]{num2,num1+num2});}j++;}int k=binarySearch(stack,y);if(k<stack.size()){answer[i]=stack.get(k)[1];}}return answer;}public int binarySearch(List<int[]> list,int target){int low=0,high=list.size();while(low<high){int mid=low+(high-low)/2;if(list.get(mid)[0]>=target){high=mid;}else{low=mid+1;}}return low;}
}

结果:

http://www.yayakq.cn/news/564495/

相关文章:

  • 房产网站代运营网站建设优化公司
  • mvc网站开发视频网络运营管理是做什么的
  • 12306网站开发多少钱公司用员工信息做网站域名备案
  • 如何建立自已的网站企业邮箱给我一个
  • 网站搜索引擎优化的基本内容杭州seo托管公司推荐
  • 网站集成支付宝教程做视频网站视频文件都存放在哪里
  • 网站免费网站上传模板后
  • 西安印象网站建设青岛app定制开发公司
  • 企业做定制网站的好处网站 尺寸
  • 网站定位的核心意义网站开发工程师报名地点
  • 有什么做分销的几个网站wordpress商城模板好用吗
  • 东莞微信网站建设报价智能设计平台
  • 建筑案例分析网站响应式网站建设源码
  • 励志故事网站源码做网站和app哪个简单
  • 建设银行人力资源招聘网站湖南麟辉建设集团有限公司网站
  • 龙海网站建设小型网站建设多少钱
  • 做网站外包公司名称大全计算机网络培训速成班
  • 网站建设需要的软件是什么鹤岗北京网站建设
  • 谁帮58同城做的网站吗网站建设哪个
  • 建个企业网站wordpress 社区 论坛 主题
  • 微信官方网站淘宝网站建设步骤
  • 市场运营和市场营销的区别免费网站优化软件
  • crm登录系统网页seo如何优化
  • 网站引导页动态效果怎么做的西安建设工程信息网的地址
  • 怎么免费建设个人网站建站网站和维护需要会什么
  • 扬州网站建设myvodo邯郸网站建设taigew
  • 企业3合1网站建设价格分销商系统
  • 怎样做好网站建设设计设计网页分析
  • 网站内容管理系统使用说明书wordpress分类目录和导航栏
  • 做淘宝客网站好搭建吗网站图片批量上传