java求数组第二大元素示例

 更新时间:2014年04月16日 09:36:43   作者:  
这篇文章主要介绍了java求数组第二大元素示例,需要的朋友可以参考下

假设该数组所有数都为非负整数,且所有数字都各自不同。

复制代码 代码如下:

package array;

public class SecondMaxElem {

 public static int getSecondMaxElem(int[] array) {

  if(array == null || array.length <=  1) {
   return -1;
  }

  int max = array[0] > array[1] ? array[0] : array[1];
  int secMax = array[0] + array[1] - max;
  int len = array.length;
  for(int i = 2; i < len; i++) {
   int cur = array[i];
   if(cur > secMax) {
    secMax = cur;

    if(secMax > max) {   // swap
     int temp = secMax;
     secMax = max;
     max = temp;
    }
   }
  }

  return secMax;
 }

 public static int getSecondMaxElem2(int[] array) {

  if(array == null || array.length <=  1) {
   return -1;
  }

  int max = array[0] > array[1] ? array[0] : array[1];
  int secMax = array[0] + array[1] - max;
  int len = array.length;
  for(int i = 2; i < len; i++) {
   int cur = array[i];
   if(cur > max) {
    secMax = max;
    max = cur;
   }
   else if(cur > secMax && cur < max) {
    secMax = cur;
   }
   else {
    // 其他情况最大值和第二大值不变,可以画一个坐标轴
   }
  }

  return secMax;
 }

 public static void main(String[] args) {
  int[] array = new int[] {  };
 /* System.out.println("算法1: " + getSecondMaxElem(array));
  System.out.println("算法2: " + getSecondMaxElem2(array));

  array = new int[] { 2 };
  System.out.println("算法1: " + getSecondMaxElem(array));
  System.out.println("算法2: " + getSecondMaxElem2(array));*/

  array = new int[] { 2, 3, 1, 6, 7, 5, 9 };
  System.out.println("算法1: " + getSecondMaxElem(array));
  System.out.println("算法2: " + getSecondMaxElem2(array));

/*  array = new int[] { 1, 2, 3, 3, 4, 5, 5 };
  System.out.println("算法1: " + getSecondMaxElem(array));
  System.out.println("算法2: " + getSecondMaxElem2(array));*/

 }

}

相关文章

  • 如何开启控制台输出mybatis执行的sql日志问题

    如何开启控制台输出mybatis执行的sql日志问题

    这篇文章主要介绍了如何开启控制台输出mybatis执行的sql日志问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Jmeter基于JDBC请求实现MySQL数据库测试

    Jmeter基于JDBC请求实现MySQL数据库测试

    这篇文章主要介绍了Jmeter基于JDBC请求实现MySQL数据库测试,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-10-10
  • Ubuntu快速安装eclipse

    Ubuntu快速安装eclipse

    这篇文章主要为大家详细介绍了Ubuntu快速安装eclipse的简单教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-04-04
  • java中URLencode、URLdecode及Base64加解密转换

    java中URLencode、URLdecode及Base64加解密转换

    本文主要介绍了java中URLencode、URLdecode及Base64加解密转换,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-01-01
  • lombok @Accessors用法详解

    lombok @Accessors用法详解

    这篇文章主要介绍了lombok @Accessors用法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Jar打包用法详解

    Jar打包用法详解

    这篇文章主要介绍了Jar打包用法,详解分析了jar打包命令的各种常见用法及参数含义,非常具有实用价值,需要的朋友可以参考下
    2014-12-12
  • Spring中的@RestController注解详细解析

    Spring中的@RestController注解详细解析

    这篇文章主要介绍了Spring中的@RestController注解详细解析,@RestController 是 Spring Framework 中的一个注解,用于标识一个类为 RESTful Web 服务的控制器(Controller),处理 HTTP 请求并返回相应的数据,
    2024-01-01
  • Java 多线程Synchronized和Lock的区别

    Java 多线程Synchronized和Lock的区别

    这篇文章主要介绍了Java 多线程Synchronized和Lock的区别,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2021-01-01
  • Spring Batch实现批量处理

    Spring Batch实现批量处理

    本文主要介绍了Spring Batch进行批量处理,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-06-06
  • java使用google身份验证器实现动态口令验证的示例

    java使用google身份验证器实现动态口令验证的示例

    本篇文章主要介绍了java使用google身份验证器实现动态口令验证的示例,具有一定的参考价值,有兴趣的可以了解一下
    2017-08-08

最新评论