Leetcode 503. Next Greater Element II JAVA语言

简介:
1
2
3
4
5
6
Given a circular array (the next element of the last element is the first element of the array), print the Next Greater Number for every element. The Next Greater Number of a number x is the first greater number to its traversing-order next in the array, which means you could search circularly to find its next greater number. If it doesn't exist, output -1 for this number.
Example 1:
Input: [1,2,1]Output: [2,-1,2]Explanation: The first 1's next greater number is 2; 
The number 2 can't find next greater number; 
The second 1's next greater number needs to search circularly, which is also 2.
Note: The length of given array won't exceed 10000.

题意:给一个循环数组,求解其next greater number:第一个比其大的数。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
public  class  Solution {
     ////这个思路是直接double数组,把原来的循环简化了。貌似还有用栈的。再看看。
     public  int [] nextGreaterElements( int [] nums) {
         if (nums.length== 1 ){
             nums[ 0 ]=- 1 ;
             return  nums;
         }
         int [] newnums= new  int [nums.length* 2 ];
         for ( int  i= 0 ;i<newnums.length;i++){
             newnums[i]=nums[i%nums.length];
         }
         // for(int i=0;i<nums.length;i++){
         //     newnums[i]=nums[i];
         // }
         // int index=0;
         // for(int i=nums.length;i<newnums.length;i++){
         //     newnums[i]=nums[index++];
         // }
         // for(int i=0;i<nums.length*2;i++){
         //     System.out.println(newnums[i]+"  ");
         // }
         for ( int  i= 0 ;i<nums.length;i++)
             for ( int  j=i+ 1 ;j<i+nums.length;j++)
             if (newnums[j]>newnums[i]){
                 nums[i]=newnums[j];
                 break ;
             } else {
                 nums[i]=- 1 ;
             }
         return  nums;
     }
}

PS:听群里大神说把数组直接double一下,然后就可以简化了,【好厉害】。然后就是暴力搜索了。。。。。。。。貌似还有栈!

栈的话,若当前元素小于等于栈顶元素,直接入栈。若大于栈顶元素,即将所有小于该元素的值出站,并作为=他们的next greater number。再来一次循环,只出栈,看看能不能找到比他大的元素。最后看看栈里的元素就是最大值,直接设为-1


本文转自 努力的C 51CTO博客,原文链接:http://blog.51cto.com/fulin0532/1901699


相关文章
|
3月前
|
存储 人工智能 算法
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
这篇文章详细介绍了Dijkstra和Floyd算法,这两种算法分别用于解决单源和多源最短路径问题,并且提供了Java语言的实现代码。
106 3
数据结构与算法细节篇之最短路径问题:Dijkstra和Floyd算法详细描述,java语言实现。
|
2月前
|
监控 Java API
如何使用Java语言快速开发一套智慧工地系统
使用Java开发智慧工地系统,采用Spring Cloud微服务架构和前后端分离设计,结合MySQL、MongoDB数据库及RESTful API,集成人脸识别、视频监控、设备与环境监测等功能模块,运用Spark/Flink处理大数据,ECharts/AntV G2实现数据可视化,确保系统安全与性能,采用敏捷开发模式,提供详尽文档与用户培训,支持云部署与容器化管理,快速构建高效、灵活的智慧工地解决方案。
|
5月前
|
Java Maven
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
该博客文章介绍了如何使用Java Swing中的JFrame创建一个窗体来收集用户输入的内容,并提供了详细的实现步骤和完整代码示例。
使用java语言制作一个窗体(弹窗),用来收集用户输入的内容
|
2月前
|
SQL 安全 Java
安全问题已经成为软件开发中不可忽视的重要议题。对于使用Java语言开发的应用程序来说,安全性更是至关重要
在当今网络环境下,Java应用的安全性至关重要。本文深入探讨了Java安全编程的最佳实践,包括代码审查、输入验证、输出编码、访问控制和加密技术等,帮助开发者构建安全可靠的应用。通过掌握相关技术和工具,开发者可以有效防范安全威胁,确保应用的安全性。
59 4
|
3月前
|
Java 程序员 编译器
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。
在Java编程中,保留字(如class、int、for等)是具有特定语法意义的预定义词汇,被语言本身占用,不能用作变量名、方法名或类名。本文通过示例详细解析了保留字的定义、作用及与自定义标识符的区别,帮助开发者避免因误用保留字而导致的编译错误,确保代码的正确性和可读性。
70 3
|
3月前
|
移动开发 Java 大数据
深入探索Java语言的核心优势与现代应用实践
【10月更文挑战第10天】深入探索Java语言的核心优势与现代应用实践
117 4
|
3月前
|
存储 Java 数据安全/隐私保护
Java中的域,什么是域?计算机语言中的域是什么?(有代码实例)
文章解释了Java中域的概念,包括实例域、静态域、常量域和局部域,以及它们的特点和使用场景。
95 2
|
3月前
|
Java 数据安全/隐私保护 C++
Java语言关键字
Java语言关键字
42 2
|
3月前
|
分布式计算 安全 Java
Java语言的特点?
Java语言的特点?
|
3月前
|
算法 Java
LeetCode(一)Java
LeetCode(一)Java
下一篇
开通oss服务