int Stack::peek() { if ( isEmpty() ) // 若栈为空,是否应该抛出异常? return 0 ; // 还是返回一个特殊值? else return data[top]; }
* @date 2020/4/1 - 18:01
*/
public class Four {
//栈使用数组来表示
int[] elements;
public Four(){
elements=new int[0];//先弄个对象
}
//压入元素
public void push(int element){
//创建一个新数组
int[] newArr = new int[elements.length+1];
//把原数组中的元素复制到新数组中
for(int i=0;i<elements.length;i++)
{
newArr[i]=elements[i];
}
//把添加的元素放入新数组中
newArr[elements.length]=element;
//使用新数组替换旧数组
elements=newArr;
}
//取出栈顶元素
public int pop(){
//取出数组最后一个元素
int element = elements[elements.length-1];
//创建新的数组
int[] newArr = new int[elements.length-1];
//取出原数组除最后一个的所有元素
for(int i=0;i<elements.length-1;i++)
{
newArr[i] = elements[i];
}
//替换数组
elements = newArr;
//返回栈顶元素
return element;
}
//判断栈是否为空
public boolean isEmpty()
{
return elements.length==0;
}
//查看栈顶元素
public int peek(){
if (elements.length==0){
throw new RuntimeException("stack is empty");
}
return elements[elements.length-1];
}
public static void main(String[] args) {
Four ms = new Four();
//压入元素
ms.push(2);
ms.push(4);
ms.push(6);
//取出元素
System.out.println(ms.pop());
System.out.println(ms.pop());
System.out.println(ms.pop());
//查看栈顶元素
System.out.println(ms.isEmpty());
}
}
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。