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

外贸建站推广公司站长之家网站模板

外贸建站推广公司,站长之家网站模板,广告设计公司vi,什么网站是教做纸工的【力扣】496. 下一个更大元素 I nums1 中数字 x 的 下一个更大元素 是指 x 在 nums2 中对应位置 右侧 的 第一个 比 x 大的元素。给你两个没有重复元素的数组 nums1 和 nums2 &#xff0c;下标从 0 开始计数&#xff0c;其中nums1 是 nums2 的子集。   对于每个 0 < i <…

【力扣】496. 下一个更大元素 I

  nums1 中数字 x 的 下一个更大元素 是指 x 在 nums2 中对应位置 右侧 的 第一个 比 x 大的元素。给你两个没有重复元素的数组 nums1 和 nums2 ,下标从 0 开始计数,其中nums1 是 nums2 的子集。
  对于每个 0 <= i < nums1.length ,找出满足 nums1[i] == nums2[j] 的下标 j ,并且在 nums2 确定 nums2[j] 的 下一个更大元素 。如果不存在下一个更大元素,那么本次查询的答案是 -1 。
  返回一个长度为 nums1.length 的数组 ans 作为答案,满足 ans[i] 是如上所述的 下一个更大元素 。

示例 1:
输入:nums1 = [4,1,2], nums2 = [1,3,4,2].
输出:[-1,3,-1]
解释:nums1 中每个值的下一个更大元素如下所述:

  • 4 ,用加粗斜体标识,nums2 = [1,3,4,2]。不存在下一个更大元素,所以答案是 -1 。
  • 1 ,用加粗斜体标识,nums2 = [1,3,4,2]。下一个更大元素是 3 。
  • 2 ,用加粗斜体标识,nums2 = [1,3,4,2]。不存在下一个更大元素,所以答案是 -1 。

示例 2:
输入:nums1 = [2,4], nums2 = [1,2,3,4].
输出:[3,-1]
解释:nums1 中每个值的下一个更大元素如下所述:

  • 2 ,用加粗斜体标识,nums2 = [1,2,3,4]。下一个更大元素是 3 。
  • 4 ,用加粗斜体标识,nums2 = [1,2,3,4]。不存在下一个更大元素,所以答案是 -1 。

提示:
1 <= nums1.length <= nums2.length <= 1000
0 <= nums1[i], nums2[i] <= 1 0 4 10^4 104
nums1和nums2中所有整数 互不相同
nums1 中的所有整数同样出现在 nums2 中

题解

单调栈+哈希

import java.util.*;public class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {//单调栈Stack<Integer> stack = new Stack<>();//存放结果最终结果,大小和nums1一样int[] result = new int[nums1.length];Arrays.fill(result, -1);//求nums1和nums2的映射关系HashMap<Integer, Integer> map = new HashMap<>();for (int i = 0; i < nums1.length; i++) {// key为数值,value为下标map.put(nums1[i], i);}//先放第一个元素的下标进单调栈stack.add(0);//单调栈遍历数组nums2for (int i = 1; i < nums2.length; i++) {//当前遍历的元素和栈口元素的比较if (nums2[i] <= nums2[stack.peek()]) {stack.push(i);}else {//循环比较while (!stack.isEmpty() && nums2[i] > nums2[stack.peek()]) {if (map.containsKey(nums2[stack.peek()])) {Integer index = map.get(nums2[stack.peek()]);result[index] = nums2[i];}stack.pop();}stack.push(i);}}return result;}
}

在这里插入图片描述
暴力:

public class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {int[] result = new int[nums1.length];//遍历nums1的元素,逐个去nums2找for (int i = 0; i < nums1.length; ++i) {//先找到相等的位置int j = 0;while (j < nums2.length && nums2[j] != nums1[i]) {j++;}//继续找右边第一个比它大的int k = j + 1;while (k < nums2.length && nums2[k] < nums2[j]) {k++;}//k < nums2.length说明找到了右边比它大的result[i] = (k < nums2.length) ? nums2[k] : -1;}return result;}
}
http://www.dt0577.cn/news/30324.html

相关文章:

  • 网站建设项目需求分析报告网站换了域名怎么查
  • 营业执照申请网站seo搜索引擎优化业务
  • 杭州市建设工程招标信息网seo单页面优化
  • 做网站收入太低seo点击排名软件哪家好
  • 各种网站建设报价seo免费外链工具
  • 网站图片如何优化百度收录站长工具
  • 北京网站改版有哪些好处茂名网站建设制作
  • 微信手机网站设计邀请推广app
  • 网站轮播广告代码哪个网站做推广效果好
  • 做阿里网站需要的faq营销渠道策略
  • java web网站开发框架最有吸引力的营销模式
  • wordpress captcha网站seo综合诊断
  • cho菌主题wordpressseo的搜索排名影响因素有
  • 博客网站怎么做cpa建立网站的基本步骤
  • 先做网站再付款百度经验官网首页
  • 城口自助建站电脑培训机构哪个好
  • 中国制造网外贸平台网址搜索优化的培训免费咨询
  • 51做网站微营销平台
  • 怎么给网站做404界面推广方案是什么
  • 网站开发好学吗中国网站建设公司
  • 做数据新闻的网站有哪些方面bittorrentkitty磁力猫
  • 企业登录官网seo攻略
  • 门户网站建设 考核百度有钱花人工客服
  • 2h1g做视频网站微商推广哪家好
  • 重庆哪家做网站广东疫情最新通报
  • 莆田交友网站服务app开发成本预算表
  • 网站建设worldpress软文是什么文章
  • 十大收益最好的自媒体平台湖南企业竞价优化
  • 手机网站设计建设服务bt磁力狗
  • 做的好看的旅游网站关键词优化的最佳方法