日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > java >内容正文

java

java的min函数_Java语言实现包含min函数的栈

發布時間:2025/3/12 java 15 豆豆
生活随笔 收集整理的這篇文章主要介紹了 java的min函数_Java语言实现包含min函数的栈 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

package stack;

import java.util.ArrayList;

/**

* 實現包含min函數的棧

* @author DHC

* @param

*/

public class MinInStack {

public static void main(String[] args) {

MinInStack newStack = new MinInStack();

newStack.push(4);

newStack.push(6);

newStack.push(2);

newStack.push(5);

newStack.pop();

newStack.pop();

newStack.push(1);

System.out.println(newStack.min());

}

public ArrayList stack = new ArrayList();

public ArrayList minStack = new ArrayList();

public T pop() {

int size = stack.size();

minStack.remove(size - 1);

return stack.remove(size - 1);

}

public void push(T item) {

int size = stack.size();

if (size == 0) {

minStack.add(0);

} else {

int minPosition = minStack.get(size - 1);

T minData = stack.get(minPosition);

if (compare(minData, item)) {

minStack.add(stack.size());

} else {

minStack.add(minPosition);

}

}

stack.add(item);

}

public T peek() {

int size = stack.size();

return stack.get(size - 1);

}

public T min() {

int size = minStack.size();

return stack.get(minStack.get(size - 1));

}

public boolean isEmpty() {

return stack.isEmpty();

}

/**

* 泛型元素的比較方法

* @param minData

* @param item

* @return true 代表當前元素小于之前的最小元素

*/

private boolean compare(T minData, T item) {

// 這兒不同的泛型類型可以用不同的方式實現

// 如果寫成通用代碼泛型之間應該腫么比較大小呢?是不是可以讓泛型都繼承某一接口呢?

int a = (Integer) minData;

int b = (Integer) item;

if(a > b) {

return true;

} else {

return false;

}

}

}

posted on 2012-01-31 15:57 墻頭草 閱讀(982) 評論(0) ?編輯 ?收藏

總結

以上是生活随笔為你收集整理的java的min函数_Java语言实现包含min函数的栈的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。