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

深圳福田建网站微信公众号管理平台登录

深圳福田建网站,微信公众号管理平台登录,网站服务器带宽多少合适,Net网站开发招聘🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

在这里插入图片描述

🚀 算法题 🚀

🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀
🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨
🌲 作者简介:硕风和炜,CSDN-Java领域优质创作者🏆,保研|国家奖学金|高中学习JAVA|大学完善JAVA开发技术栈|面试刷题|面经八股文|经验分享|好用的网站工具分享💎💎💎
🌲 恭喜你发现一枚宝藏博主,赶快收入囊中吧🌻
🌲 人生如棋,我愿为卒,行动虽慢,可谁曾见我后退一步?🎯🎯

🚀 算法题 🚀

在这里插入图片描述

在这里插入图片描述

🍔 目录

    • 🚩 题目链接
    • ⛲ 题目描述
    • 🌟 求解思路&实现代码&运行结果
      • ⚡ 单调栈
        • 🥦 求解思路
        • 🥦 实现代码
        • 🥦 运行结果
    • 💬 共勉

🚩 题目链接

  • 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] <= 104
nums1和nums2中所有整数 互不相同
nums1 中的所有整数同样出现在 nums2 中

进阶:你可以设计一个时间复杂度为 O(nums1.length + nums2.length) 的解决方案吗?

🌟 求解思路&实现代码&运行结果


⚡ 单调栈

🥦 求解思路
  1. 题目需要我们,nums1 中数字 x 的 下一个更大元素 是指 x 在 nums2 中对应位置 右侧 的 第一个 比 x 大的元素。nums2中包含nums1中的元素,我们通过单调栈先在nums2中找下一个更大的元素,该过程我们额外借助一个HashMap来实现,最后在nums1中去寻找即可。
  2. 有了基本的思路,接下来我们就来通过代码来实现一下。
🥦 实现代码
class Solution {public int[] nextGreaterElement(int[] nums1, int[] nums2) {int n = nums1.length;int m = nums2.length;int[] ans = new int[n];Deque<Integer> queue = new LinkedList<>();HashMap<Integer, Integer> map = new HashMap<>();for (int i = 0; i < m; i++) {while (!queue.isEmpty() && nums2[i] > nums2[queue.peekLast()]) {int j = queue.pollLast();map.put(nums2[j], nums2[i]);}queue.addLast(i);}for (int i = 0; i < n; i++) {ans[i] = map.getOrDefault(nums1[i], -1);}return ans;}
}
🥦 运行结果

在这里插入图片描述


💬 共勉

最后,我想和大家分享一句一直激励我的座右铭,希望可以与大家共勉!

在这里插入图片描述

在这里插入图片描述

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

相关文章:

  • 页面简洁的网站建设工程招标网站
  • 专业电子网站建设网站开发团队简介
  • 网站建设小组实训总结上海网站营销seo方案
  • 湖南响应式网站推荐装修设计软件免费下载
  • 营销行网站建设电视台网站策划书
  • 深圳福田做网站公司哪家好深圳百度关键词
  • 做购票系统网站机关公文写作网站
  • 哈尔滨做网站哪家好强网站找不到的原因
  • 怎么做html5网站微信小程序开发文档下载
  • 吉林建设工程信息网seo蜘蛛屯
  • 伊春网站推广地方门户网站的分类
  • 门户网站开发设计报告九一赣州人才网
  • 沧州网站seo公司南京百度seo代理
  • 网站导出链接查询跨境电商网站开发公司
  • 网站制作网站西安做企业网站哪家做的好
  • 网站做计算功能张家口企业网站建设
  • 网站域名怎么购买吗长沙市旅游景点
  • 没有icp备案的网站网站推送
  • 营业执照包含网站开发山东网络推广平台
  • 旅游网站建设的经济评价自己如何在家做网站
  • 网站有风险提示怎么办注册资本可以随便填吗
  • 佛山网站建设网络推广营销咨询
  • 做公司网站的目的是什么建网站需要哪些技术
  • 如何提高网站的知名度网站开发费用构成
  • 设计方案评审企业网站seo优化外包
  • 二手书交易网站开发与设计全球速卖通入驻条件
  • html5网站开发参考文献如何删除wordpress
  • 网站免费主机申请网站建设中国十强
  • 室内设计效果图网站推荐android开发最全教程
  • 如何网站推广小企业网站建设的小知识