jmu-Java-05集合(泛型)-10-GeneralStack

以前定义的IntegerStack接口,只能用于存放Integer类型的数据。然而对于栈来说,不管内部存放的是什么类型的数据,基本操作与元素的具体类型无关。

1. 编写一个通用的GeneralStack接口,接口中的操作对任何引用类型的数据都适用。

一旦定义完毕,只能存放一种类型的数据,比如只能存放String或只能存放Integer。GeneralStack接口方法如下:

push(item);            //如item为null,则不入栈直接返回null。
pop();                 //出栈,如为栈为空,则返回null。
peek();                //获得栈顶元素,如为空,则返回null.
public boolean empty();//如为空返回true
public int size();     //返回栈中元素数量

2.定义GeneralStack的实现类ArrayListGeneralStack

内部使用ArrayList对象存储,属性名为list

方法: public String toString()//该方法的代码为return list.toString();

提示:

  1. 不用使用top指针。
  2. 直接复用ArrayList中已有的方法。
  3. pop时应将相应的元素从ArrayList中移除。
  4. 代码中不要出现类型不安全的强制转换

3.定义Car对象

属性:

private int id;
private String name;

方法:Eclipse自动生成setter/getter,toString方法。

4.main方法说明

  1. 输入选项,有quit, Integer, Double, Car4个选项。如果输入quit,则直接退出。否则,输入整数m与n。m代表入栈个数,n代表出栈个数。然后声明栈变量stack
  2. 输入Integer,打印Integer Test。建立可以存放Integer类型的ArrayListGeneralStack。入栈m次,出栈n次。打印栈的toString方法。最后将栈中剩余元素出栈并累加输出。
  3. 输入Double ,打印Double Test。剩下的与输入Integer一样。
  4. 输入Car,打印Car Test。其他操作与Integer、Double基本一样。只不过最后将栈中元素出栈,并将其name依次输出。

2、3、4步骤做完都要使用代码System.out.println(stack.getClass().getInterfaces()[0]);打印标识信息

特别注意: 如果栈为空的时候继续出栈,则返回null

输入样例

Integer
5
2
1 2 3 4 5
Double
5
3
1.1 2.0 4.9 5.7 7.2
Car
3
2
1 Ford
2 Cherry
3 BYD
quit

输出样例

Integer Test
push:1
push:2
push:3
push:4
push:5
pop:5
pop:4
[1, 2, 3]
sum=6
interface GeneralStack
Double Test
push:1.1
push:2.0
push:4.9
push:5.7
push:7.2
pop:7.2
pop:5.7
pop:4.9
[1.1, 2.0]
sum=3.1
interface GeneralStack
Car Test
push:Car [id=1, name=Ford]
push:Car [id=2, name=Cherry]
push:Car [id=3, name=BYD]
pop:Car [id=3, name=BYD]
pop:Car [id=2, name=Cherry]
[Car [id=1, name=Ford]]
Ford
interface GeneralStack


答案

import java.util.LinkedList;
import java.util.Scanner;

interface GeneralStack<T> {
    T push(T item); //如果item为null,则不入栈直接返回null。如果栈满,也返回null。如果插入成功,返回item

    T pop();   //出栈,如果为空,则返回null。出栈时只移动栈顶指针,相应位置不置为null

    T peek();  //获得栈顶元素,如果为空,则返回null

    boolean empty(); //如果为空返回true

    int size();      //返回栈中元素个数
}

class ArrayListGeneralStack implements GeneralStack {
    private LinkedList<Object> list;

    public ArrayListGeneralStack() {
        list = new LinkedList<>();
    }

    @Override
    public String toString() {
        return list.toString();
    }

    @Override
    public Object push(Object item) {
        if (item == null) {
            return null;
        }
        list.add(item);
        return item;
    }

    @Override
    public Object pop() {
        if (list.size() == 0) {
            return null;
        }
        Object topNum = list.getLast();
        list.removeLast();
        return topNum;
    }

    @Override
    public Object peek() {
        if (list.size() == 0) {
            return null;
        }
        return list.getLast();
    }

    @Override
    public boolean empty() {
        return list.size() == 0;
    }

    @Override
    public int size() {
        return list.size();
    }
}

class Car {
    private int id;
    private String name;

    public int getId() {
        return id;
    }

    public void setId(int id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    @Override
    public String toString() {
        return "Car [" +
                "id=" + id +
                ", name=" + name +
                ']';
    }
}

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (true) {
            String choice = scanner.next();
            if (choice.equals("quit")) {
                break;
            }
            switch (choice) {
                case "Integer":
                    System.out.println("Integer Test");
                    ArrayListGeneralStack algsInt = new ArrayListGeneralStack();
                    int mInt = scanner.nextInt();
                    int nInt = scanner.nextInt();
                    while (mInt-- > 0) {
                        int pushNum = scanner.nextInt();
                        System.out.println("push:" + pushNum);
                        algsInt.push(pushNum);
                    }
                    while (nInt-- > 0) {
                        System.out.println("pop:" + algsInt.pop());
                    }
                    System.out.println(algsInt);
                    int sumInt = 0;
                    int sizeInt = algsInt.size();
                    for (int i = 0; i < sizeInt; i++) {
                        sumInt += Integer.parseInt(algsInt.peek().toString());
                        algsInt.pop();
                    }
                    System.out.println("sum=" + sumInt);
                    System.out.println(algsInt.getClass().getInterfaces()[0]);
                    break;
                case "Double":
                    System.out.println("Double Test");
                    ArrayListGeneralStack algsDouble = new ArrayListGeneralStack();
                    int mDouble = scanner.nextInt();
                    int nDouble = scanner.nextInt();
                    while (mDouble-- > 0) {
                        double pushNum = scanner.nextDouble();
                        System.out.println("push:" + pushNum);
                        algsDouble.push(pushNum);
                    }
                    while (nDouble-- > 0) {
                        System.out.println("pop:" + algsDouble.pop());
                    }
                    System.out.println(algsDouble);
                    double sumDouble = 0;
                    int sizeDouble = algsDouble.size();
                    for (int i = 0; i < sizeDouble; i++) {
                        sumDouble += Double.parseDouble(algsDouble.peek().toString());
                        algsDouble.pop();
                    }
                    System.out.println("sum=" + sumDouble);
                    System.out.println(algsDouble.getClass().getInterfaces()[0]);
                    break;
                case "Car":
                    System.out.println("Car Test");
                    ArrayListGeneralStack algsCar = new ArrayListGeneralStack();
                    int mCar = scanner.nextInt();
                    int nCar = scanner.nextInt();
                    while (mCar-- > 0) {
                        int id = scanner.nextInt();
                        String name = scanner.next();
                        Car car = new Car();
                        car.setId(id);
                        car.setName(name);
                        System.out.println("push:" + car);
                        algsCar.push(car);
                    }
                    while (nCar-- > 0) {
                        System.out.println("pop:" + algsCar.pop());
                    }
                    System.out.println(algsCar);
                    int sizeCar = algsCar.size();
                    for (int i = 0; i < sizeCar; i++) {
                        Car car=(Car) algsCar.pop();
                        System.out.println(car.getName());
                    }
                    System.out.println(algsCar.getClass().getInterfaces()[0]);
                    break;
            }
        }
    }
}
  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: jmu-java-05集合(泛型)-10-generalstack是关于Java泛型中的通用栈的学习内容。通用栈是一种可以存储任意类型数据的栈结构,通过泛型的方式实现。在学习中,我们可以了解到通用栈的实现原理、使用方法以及注意事项等内容,帮助我们更好地理解和应用Java泛型。 ### 回答2: JMU-Java-05集合(泛型)-10-GeneralStack是一个Stack(栈)的实现类,使用Java中的泛型进行定义,可以存储任何类型的数据。 在该类中,使用一个Object类型的数组进行存储元素,并通过一个整型变量top来表示当前栈顶元素的下标。在push(入栈)方法中,先将top加一,然后将元素存储在数组中,实现了入栈的功能。在pop(出栈)方法中,先判断栈是否为空,若为空则抛出栈空异常,否则将top减一,并返回数组中相应的元素,实现了出栈的功能。其他方法如isEmpty(判断栈是否为空)、isFull(判断栈是否已满)和size(获取栈中元素个数)也在该类中实现。 该类的泛型定义使得我们可以使用该类存储任何类型的数据,而不需要在定义类时指定数据类型,提高了其灵活性和可复用性。在使用时,我们只需要在创建对象时传入相应的数据类型,如:GeneralStack<Integer> stack = new GeneralStack<Integer>();即可。 该类还实现了Iterable接口,使得该类可以使用foreach循环进行遍历操作,方便了我们对栈中元素的操作。同时,该类还通过对数组的动态扩容,解决了数组固定大小的限制问题,从而提高了该栈类的通用性和易用性。 总之,JMU-Java-05集合(泛型)-10-GeneralStack是一个使用泛型实现的通用栈类,可以存储各种类型的数据,并提供了常用的栈操作方法,具有较高的可复用性与适用性。 ### 回答3: jmu-java-05集合(泛型)-10-generalstack,意为基于泛型的栈实现。 首先我们需要了解什么是泛型泛型Java SE 5引入的一个新特性,它可以让我们在编写代码时定义一些未知的类型参数,以达到代码的复用和类型安全的目的。对于集合类或者其他容器类而言,适用于任何类的容器的需求是普遍存在的,这时就可以应用泛型。 在Java泛型使用<>标识,其语法格式如下: ```java public class 类名<类型参数列表> { //成员变量、方法等 } ``` 类型参数列表是由逗号隔开的参数列表,可以理解为未知类型的占位符。这样的好处是可以在编写集合类时,避免出现类型转换等一系列问题,提高程序的可读性。 而在jmu-java-05集合(泛型)-10-generalstack中,则是基于泛型实现的数据结构——栈。栈是一种后进先出(LIFO)的数据结构,它只允许在栈顶添加或删除元素,因此操作非常简单、快速并且高效。 在该实现中,栈的元素可以是任意类型,数据元素入栈则是通过 push() 方法实现的,出栈则是通过 pop() 方法实现的。其中,push() 方法用于向栈中添加新的元素,pop() 方法用于弹出并返回栈顶的元素。同时,还提供了 isEmpty() 方法、size() 方法等基本的栈操作方法。 总之,jmu-java-05集合(泛型)-10-generalstack是一种基于泛型实现的栈,提供了复用和类型安全的目的。其实现使用简便、高效、易于扩展等优点,广泛应用在Java开发中。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值