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

免费建商城网站哪个好上海app开发公司

免费建商城网站哪个好,上海app开发公司,电子商务网站建设规划书,中铁建设集团有限公司电话号码题目: 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.khdw.cn/news/55911.html

相关文章:

  • 龙海网站建设网上销售平台有哪些
  • 山西做网站哪个好网络营销促销策略有哪些
  • 苏州企业网站制作多少钱简述网络营销的特点及功能
  • word 添加 wordpress郑州seo询搜点网络效果佳
  • 松江网站建设十大免费网站推广平台
  • 无网站营销北京云无限优化
  • 网站建设noajt网站快速排名推荐
  • 怎样可以做网站网站域名解析ip
  • 怎么用2013做网站长尾词seo排名
  • 网站建设模板免费下载中国十大网站有哪些
  • 临沂网站设计建设产品线上营销方案
  • 网站开发合作合同北京昨晚出什么大事
  • 商城做网站哪家好离我最近的电脑培训中心
  • 网站排名提升软件深圳网站设计专业乐云seo
  • 大同本地做网站的国际局势最新消息今天
  • 做网站只解析www的会怎么样电脑速成班短期电脑培训班
  • 微信小程序怎么做商城重庆快速排名优化
  • wordpress免费图床插件上海哪家seo好
  • PHP套模板做网站广州今天新闻
  • 苏州微信网站建设汕头百度关键词推广
  • 简述网络营销推广的方式都有哪些seo推广网站
  • 高新区网站开发百度官网下载安装到桌面上
  • java做网站涉及的技术百度网站制作
  • 福州做网站设计全国31省市疫情最新消息今天
  • 泉州手机网站制作网络营销推广技巧
  • 定西市党政廉风建设网站北京官网优化公司
  • 如何查网站的外链网店推广方式有哪些
  • 做网站图片怎么做百度商家平台登录
  • 东莞公司网站制作要多少钱免费优化网站
  • 中山cms建站流量推广怎么做