All Downloads are FREE. Search and download functionalities are using the official Maven repository.

weka.core.neighboursearch.covertrees.Stack Maven / Gradle / Ivy

Go to download

The Waikato Environment for Knowledge Analysis (WEKA), a machine learning workbench. This is the stable version. Apart from bugfixes, this version does not receive any other updates.

There is a newer version: 3.8.6
Show newest version
/*
 *   This program is free software: you can redistribute it and/or modify
 *   it under the terms of the GNU General Public License as published by
 *   the Free Software Foundation, either version 3 of the License, or
 *   (at your option) any later version.
 *
 *   This program is distributed in the hope that it will be useful,
 *   but WITHOUT ANY WARRANTY; without even the implied warranty of
 *   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *   GNU General Public License for more details.
 *
 *   You should have received a copy of the GNU General Public License
 *   along with this program.  If not, see .
 */

/*
 * Stack.java
 * Copyright (C) 2006 Alina Beygelzimer and Sham Kakade and John Langford
 */

package weka.core.neighboursearch.covertrees;

import java.io.Serializable;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;

import weka.core.RevisionHandler;
import weka.core.RevisionUtils;

/**
 * Class implementing a stack.
 * 
 * @param  The type of elements to be stored in the stack.
 * @author Alina Beygelzimer (original C++ code)
 * @author Sham Kakade (original C++ code)
 * @author John Langford (original C++ code)
 * @author Ashraf M. Kibriya (amk14[at-the-rate]cs[dot]waikato[dot]ac[dot]nz)
 *         (Java port)
 * @version $Revision: 10203 $
 */
public class Stack implements Serializable, RevisionHandler {

  /** for serialization. */
  private static final long serialVersionUID = 5604056321825539264L;

  /** The number of elements in the stack. */
  public int length;

  /** The elements inside the stack. */
  public ArrayList elements;

  /** Constructor. */
  public Stack() {
    length = 0;
    elements = new ArrayList();
  }

  /**
   * Constructor.
   * 
   * @param capacity The initial capacity of the stack.
   */
  public Stack(int capacity) {
    length = 0;
    elements = new ArrayList(capacity);
  }

  /**
   * Returns the last element in the stack.
   * 
   * @return The last element.
   */
  public T last() {
    return elements.get(length - 1);
  }

  /**
   * Returns the ith element in the stack.
   * 
   * @param i The index of the element to return.
   * @return The ith element.
   */
  public T element(int i) {
    return elements.get(i);
  }

  /**
   * Sets the ith element in the stack.
   * 
   * @param i The index at which the element is to be inserted.
   * @param e The element to insert.
   */
  public void set(int i, T e) {
    elements.set(i, e);
  }

  /**
   * Returns a sublist of the elements in the stack.
   * 
   * @param beginIdx The start index of the sublist.
   * @param uptoLength The length of the sublist.
   * @return The sublist starting from beginIdx and of length uptoLength.
   */
  public List subList(int beginIdx, int uptoLength) {
    return elements.subList(beginIdx, uptoLength);
  }

  /** Removes all the elements from the stack. */
  public void clear() {
    elements.clear();
    length = 0;
  }

  /**
   * Adds all the given elements in the stack.
   * 
   * @param c The collection of elements to add in the stack.
   */
  public void addAll(Collection c) {
    elements.addAll(c);
    length = c.size();
  }

  /**
   * Replace all elements in the stack with the elements of another given stack.
   * It first removes all the elements currently in the stack, and then adds all
   * the elements of the provided stack.
   * 
   * @param s The stack whose elements should be put in this stack.
   */
  public void replaceAllBy(Stack s) {
    elements.clear();
    elements.addAll(s.elements);
    length = elements.size();
  }

  /**
   * Pops (removes) the first (last added) element in the stack.
   * 
   * @return The poped element.
   */
  public T pop() {
    length--;
    return elements.remove(length);
  }

  /**
   * Pushes the given element to the stack.
   * 
   * @param new_ele The element to be pushed to the stack.
   */
  public void push(T new_ele) {
    length++;
    elements.add(new_ele);
  }

  /**
   * Pushes the given element onto the given stack.
   * 
   * @param v The stack onto push the element.
   * @param new_ele The element to push.
   */
  public void push(Stack v, T new_ele) {
    length++;
    v.elements.add(new_ele);
  }

  /**
   * Returns the revision string.
   * 
   * @return the revision
   */
  @Override
  public String getRevision() {
    return RevisionUtils.extract("$Revision: 10203 $");
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy