欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java求數(shù)組第二大元素示例

 更新時間:2014年04月16日 09:36:43   作者:  
這篇文章主要介紹了java求數(shù)組第二大元素示例,需要的朋友可以參考下

假設(shè)該數(shù)組所有數(shù)都為非負整數(shù),且所有數(shù)字都各自不同。

復制代碼 代碼如下:

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));*/

 }

}

相關(guān)文章

  • 如何開啟控制臺輸出mybatis執(zhí)行的sql日志問題

    如何開啟控制臺輸出mybatis執(zhí)行的sql日志問題

    這篇文章主要介紹了如何開啟控制臺輸出mybatis執(zhí)行的sql日志問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Jmeter基于JDBC請求實現(xiàn)MySQL數(shù)據(jù)庫測試

    Jmeter基于JDBC請求實現(xiàn)MySQL數(shù)據(jù)庫測試

    這篇文章主要介紹了Jmeter基于JDBC請求實現(xiàn)MySQL數(shù)據(jù)庫測試,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2020-10-10
  • Ubuntu快速安裝eclipse

    Ubuntu快速安裝eclipse

    這篇文章主要為大家詳細介紹了Ubuntu快速安裝eclipse的簡單教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • java中URLencode、URLdecode及Base64加解密轉(zhuǎn)換

    java中URLencode、URLdecode及Base64加解密轉(zhuǎn)換

    本文主要介紹了java中URLencode、URLdecode及Base64加解密轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • lombok @Accessors用法詳解

    lombok @Accessors用法詳解

    這篇文章主要介紹了lombok @Accessors用法詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • Jar打包用法詳解

    Jar打包用法詳解

    這篇文章主要介紹了Jar打包用法,詳解分析了jar打包命令的各種常見用法及參數(shù)含義,非常具有實用價值,需要的朋友可以參考下
    2014-12-12
  • Spring中的@RestController注解詳細解析

    Spring中的@RestController注解詳細解析

    這篇文章主要介紹了Spring中的@RestController注解詳細解析,@RestController 是 Spring Framework 中的一個注解,用于標識一個類為 RESTful Web 服務(wù)的控制器(Controller),處理 HTTP 請求并返回相應(yīng)的數(shù)據(jù),
    2024-01-01
  • Java 多線程Synchronized和Lock的區(qū)別

    Java 多線程Synchronized和Lock的區(qū)別

    這篇文章主要介紹了Java 多線程Synchronized和Lock的區(qū)別,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下
    2021-01-01
  • Spring?Batch實現(xiàn)批量處理

    Spring?Batch實現(xiàn)批量處理

    本文主要介紹了Spring?Batch進行批量處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • java使用google身份驗證器實現(xiàn)動態(tài)口令驗證的示例

    java使用google身份驗證器實現(xiàn)動態(tài)口令驗證的示例

    本篇文章主要介紹了java使用google身份驗證器實現(xiàn)動態(tài)口令驗證的示例,具有一定的參考價值,有興趣的可以了解一下
    2017-08-08

最新評論