时代Java,与您同行!
关注微信公众号,关注前沿技术,微信搜索:nowjava或时代Java,也可点击这里扫码关注
时代Java
首页
集册
文章
实例
项目
快讯
时代+
手册
下载
Jar查找
登录
注册
Java 创建自定义堆栈以保存整数
Java 创建自定义堆栈以保存整数
欢马劈雪
工程师 (已认证)
原创分享签约作者
发表于
实例源码
订阅
388
查看 / 运行 实例源码
创建自定义堆栈以保存整数
实例源码:
源代码:
执行
执行中...
public class StackOfInts { private int[] stack; //index of last item in the stack + 1//来自 时 代 J a v a 公 众 号 - N o w J a v a . c o m private int next = 0; public StackOfInts(int size) { //create an array large enough to hold the stack stack = new int[size]; } public void push(int on) { //push an integer onto the stack if (next < stack.length) { stack[next++] = on; } } //来 自 N o w J a v a . c o m public boolean isEmpty() { //check if the stack is empty return (next == 0); } public int pop() { //pop an integer from the stack if (!isEmpty()) { // next item in the stack return stack[--next]; } else { return 0; } } public int getStackSize() { //get the size of the stack return next; } //class that steps through the stack //not related to the stack functionality. private class StepThrough { // start stepping through the stack at i=0 with step 2 private int i = 0; // retrieve the current element public int getNext() { //get a next value in the stack int retValue = stack[i]; if (i < stack.length) { i = i + 2; } return retValue; } //last element in the stack? public boolean hasNext() { return (i < getStackSize()); } } //utility method for creating a new StepThrough class instance public StepThrough stepThrough() { return new StepThrough(); } public static void main(String[] args) { //instantiate the outer class as "stackOne" StackOfInts stackOne = new StackOfInts(15); //populate the stackOne System.out.print("Pushing elements into the stack: "); for (int j = 0; j < 15; j++) { System.out.print("" + j + " "); stackOne.push(j); } System.out.println(); System.out .println("Iterating through the whole stack selecting only even indexes:"); //instantiate the inner class as "iterator" StepThrough iterator = stackOne.stepThrough(); //print out the stackOne[i] while (iterator.hasNext()) { System.out.print(iterator.getNext() + " "); } System.out.println(); System.out.println("Popping all elements from the stack:"); for (int j = 0; j < 15; j++) { System.out.print(stackOne.pop() + " "); } } } /* * Copyright (c) 1995, 2008, Oracle and/or its affiliates. All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * - Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * - Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * - Neither the name of Oracle or the names of its * contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS * IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, /**代码未完, 请加载全部代码(NowJava.com).**/
编辑/阅读全部代码
执行结果:
Pushing elements into the stack: 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14
Iterating through the whole stack selecting only even indexes:
0 2 4 6 8 10 12 14
Popping all elements from the stack:
14 13 12 11 10 9 8 7 6 5 4 3 2 1 0
本文系作者在时代Java发表,未经许可,不得转载。如有侵权,请联系nowjava@qq.com删除。
编辑于
2020-03-26 09:23:27
2020-03-26 09:23:27
分享
分享文章到朋友圈
分享文章到 QQ
分享文章到微博
复制文章链接到剪贴板
扫描二维码
关注时代Java
实例源码
实例源码
订阅
订阅专栏
Java 判断文件是否为文本文件及获取文件编码格式的方法实例
bootstrap 实例演示下拉菜单(Dropdown)插件用法。
HashSet、LinkedHashSet、TreeSet类存储元素的自动排序规则实例测试
html css 对于 body和h1设置的实例源码
Java 获取在线网页的源代码
Java HashSet添加、迭代输出字符串的完整示例代码
Java 随机整数数组
html css 设置背景图片定位并且不平铺
扫描二维码
关注时代Java
返回顶部