java求數(shù)組第二大元素示例
假設(shè)該數(shù)組所有數(shù)都為非負(fù)整數(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 {
// 其他情況最大值和第二大值不變,可以畫一個(gè)坐標(biāo)軸
}
}
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));*/
}
}
- Java中如何比較兩個(gè)數(shù)組中元素是否相同
- java中刪除數(shù)組中重復(fù)元素方法探討
- java 刪除數(shù)組元素與刪除重復(fù)數(shù)組元素的代碼
- java求數(shù)組元素重復(fù)次數(shù)和java字符串比較大小示例
- java檢查數(shù)組是否有重復(fù)元素的方法
- Java數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的實(shí)現(xiàn)方法
- Java數(shù)組中的元素刪除并實(shí)現(xiàn)向前移的代碼
- Java數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法
- java去除已排序數(shù)組中的重復(fù)元素
- Java中高效的判斷數(shù)組中某個(gè)元素是否存在詳解
相關(guān)文章
如何開啟控制臺(tái)輸出mybatis執(zhí)行的sql日志問題
這篇文章主要介紹了如何開啟控制臺(tái)輸出mybatis執(zhí)行的sql日志問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Jmeter基于JDBC請(qǐng)求實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)測(cè)試
這篇文章主要介紹了Jmeter基于JDBC請(qǐng)求實(shí)現(xiàn)MySQL數(shù)據(jù)庫(kù)測(cè)試,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-10-10java中URLencode、URLdecode及Base64加解密轉(zhuǎn)換
本文主要介紹了java中URLencode、URLdecode及Base64加解密轉(zhuǎn)換,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01Spring中的@RestController注解詳細(xì)解析
這篇文章主要介紹了Spring中的@RestController注解詳細(xì)解析,@RestController 是 Spring Framework 中的一個(gè)注解,用于標(biāo)識(shí)一個(gè)類為 RESTful Web 服務(wù)的控制器(Controller),處理 HTTP 請(qǐng)求并返回相應(yīng)的數(shù)據(jù),2024-01-01Java 多線程Synchronized和Lock的區(qū)別
這篇文章主要介紹了Java 多線程Synchronized和Lock的區(qū)別,幫助大家更好的理解和使用Java,感興趣的朋友可以了解下2021-01-01java使用google身份驗(yàn)證器實(shí)現(xiàn)動(dòng)態(tài)口令驗(yàn)證的示例
本篇文章主要介紹了java使用google身份驗(yàn)證器實(shí)現(xiàn)動(dòng)態(tài)口令驗(yàn)證的示例,具有一定的參考價(jià)值,有興趣的可以了解一下2017-08-08