算法第四版的背包用例

本文探讨了算法第四版书中关于背包数据结构的实现,这是一个不支持删除元素的集合,通过链表实现。同时,文章指出了在使用Scanner进行输入时遇到的无法跳出循环的问题,并提出了解决方案,如在IDEA中使用ctrl+d或控制台中使用ctrl+z来终止程序。
摘要由CSDN通过智能技术生成

背包集合

看该书第一次看到有背包这个集合,以前接触到的背包都是一个概念,用数组或者其他集合进行实现。跑了一下该书代码,发现这个Bag类是作者自己实现的,从algs4.jar导入。
书上对背包的描述为:被保释一种不支持从中删除元素的集合数据类型——它的目的就是帮助用例收集元素并迭代遍历所有搜集到的元素(用例也可以检查背包是否为空或者获取背包中的元素的数量)。迭代的顺序不确定且与用例无关。
看了一下jar包中的实现:
在这里插入图片描述
其代码比较简短,如下

package edu.princeton.cs.algs4;

import java.util.Iterator;
import java.util.NoSuchElementException;

public class Bag<Item> implements Iterable<Item> {
   
    private Bag.Node<Item> first = null;
    private int n = 0;

    public Bag() {
   
    }

    public boolean isEmpty() {
   
        return this.first == null;
    }

    public int size() {
   
        return this.n;
    }

    public void add(Item item) {
   
        Bag.Node<Item> oldfirst = this.first;
        this.first = new Bag.Node();
        thi
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值