147 lines
5.1 KiB
Java
Raw Normal View History

// understandingcollections/ListOps.java
2015-12-15 11:47:04 -08:00
// (c)2016 MindView LLC: see Copyright.txt
2015-11-15 15:51:35 -08:00
// We make no guarantees that this code is fit for any purpose.
// Visit http://mindviewinc.com/Books/OnJava/ for more book information.
2016-01-25 18:05:55 -08:00
// Things you can do with Lists
2015-06-15 17:47:35 -07:00
import java.util.*;
import onjava.*;
2015-06-15 17:47:35 -07:00
public class ListOps {
2015-06-15 17:47:35 -07:00
private static boolean b;
private static String s;
private static int i;
private static Iterator<String> it;
private static ListIterator<String> lit;
public static void basicTest(List<String> a) {
a.add(1, "x"); // Add at location 1
a.add("x"); // Add at end
// Add a collection:
a.addAll(Countries.names(25));
// Add a collection starting at location 3:
a.addAll(3, Countries.names(25));
b = a.contains("1"); // Is it in there?
// Is the entire collection in there?
b = a.containsAll(Countries.names(25));
// Lists allow random access, which is cheap
// for ArrayList, expensive for LinkedList:
s = a.get(1); // Get (typed) object at location 1
i = a.indexOf("1"); // Tell index of object
b = a.isEmpty(); // Any elements inside?
it = a.iterator(); // Ordinary Iterator
lit = a.listIterator(); // ListIterator
lit = a.listIterator(3); // Start at loc 3
i = a.lastIndexOf("1"); // Last match
a.remove(1); // Remove location 1
a.remove("3"); // Remove this object
a.set(1, "y"); // Set location 1 to "y"
// Keep everything that's in the argument
// (the intersection of the two sets):
a.retainAll(Countries.names(25));
// Remove everything that's in the argument:
a.removeAll(Countries.names(25));
i = a.size(); // How big is it?
a.clear(); // Remove all elements
}
public static void iterMotion(List<String> a) {
ListIterator<String> it = a.listIterator();
b = it.hasNext();
b = it.hasPrevious();
s = it.next();
i = it.nextIndex();
s = it.previous();
i = it.previousIndex();
}
public static void iterManipulation(List<String> a) {
ListIterator<String> it = a.listIterator();
it.add("47");
// Must move to an element after add():
it.next();
// Remove the element after the newly produced one:
it.remove();
// Must move to an element after remove():
it.next();
// Change the element after the deleted one:
it.set("47");
}
public static void testVisual(List<String> a) {
2015-11-03 12:00:44 -08:00
System.out.println(a);
2015-06-15 17:47:35 -07:00
List<String> b = Countries.names(25);
2015-11-03 12:00:44 -08:00
System.out.println("b = " + b);
2015-06-15 17:47:35 -07:00
a.addAll(b);
a.addAll(b);
2015-11-03 12:00:44 -08:00
System.out.println(a);
2015-06-15 17:47:35 -07:00
// Insert, remove, and replace elements
// using a ListIterator:
ListIterator<String> x = a.listIterator(a.size()/2);
x.add("one");
2015-11-03 12:00:44 -08:00
System.out.println(a);
System.out.println(x.next());
2015-06-15 17:47:35 -07:00
x.remove();
2015-11-03 12:00:44 -08:00
System.out.println(x.next());
2015-06-15 17:47:35 -07:00
x.set("47");
2015-11-03 12:00:44 -08:00
System.out.println(a);
2015-06-15 17:47:35 -07:00
// Traverse the list backwards:
x = a.listIterator(a.size());
while(x.hasPrevious())
2015-11-03 12:00:44 -08:00
System.out.print(x.previous() + " ");
System.out.println();
System.out.println("testVisual finished");
2015-06-15 17:47:35 -07:00
}
// There are some things that only LinkedLists can do:
public static void testLinkedList() {
LinkedList<String> ll = new LinkedList<>();
ll.addAll(Countries.names(25));
2015-11-03 12:00:44 -08:00
System.out.println(ll);
2015-06-15 17:47:35 -07:00
// Treat it like a stack, pushing:
ll.addFirst("one");
ll.addFirst("two");
2015-11-03 12:00:44 -08:00
System.out.println(ll);
2015-06-15 17:47:35 -07:00
// Like "peeking" at the top of a stack:
2015-11-03 12:00:44 -08:00
System.out.println(ll.getFirst());
2015-06-15 17:47:35 -07:00
// Like popping a stack:
2015-11-03 12:00:44 -08:00
System.out.println(ll.removeFirst());
System.out.println(ll.removeFirst());
2015-06-15 17:47:35 -07:00
// Treat it like a queue, pulling elements
// off the tail end:
2015-11-03 12:00:44 -08:00
System.out.println(ll.removeLast());
System.out.println(ll);
2015-06-15 17:47:35 -07:00
}
public static void main(String[] args) {
// Make and fill a new list each time:
basicTest(
new LinkedList<>(Countries.names(25)));
basicTest(
new ArrayList<>(Countries.names(25)));
iterMotion(
new LinkedList<>(Countries.names(25)));
iterMotion(
new ArrayList<>(Countries.names(25)));
iterManipulation(
new LinkedList<>(Countries.names(25)));
iterManipulation(
new ArrayList<>(Countries.names(25)));
testVisual(
new LinkedList<>(Countries.names(25)));
testLinkedList();
}
2015-09-07 11:44:36 -06:00
}
2016-07-20 06:32:39 -06:00
/* Output: (First and Last 2 Lines)
2015-06-15 17:47:35 -07:00
[ALGERIA, ANGOLA, BENIN, BOTSWANA, BURKINA FASO, BURUNDI,
CAMEROON, CAPE VERDE, CENTRAL AFRICAN REPUBLIC, CHAD,
COMOROS, CONGO, DJIBOUTI, EGYPT, EQUATORIAL GUINEA,
ERITREA, ETHIOPIA, GABON, THE GAMBIA, GHANA, GUINEA,
BISSAU, COTE D'IVOIR (IVORY COAST), KENYA, LESOTHO]
b = [ALGERIA, ANGOLA, BENIN, BOTSWANA, BURKINA FASO,
BURUNDI, CAMEROON, CAPE VERDE, CENTRAL AFRICAN REPUBLIC,
CHAD, COMOROS, CONGO, DJIBOUTI, EGYPT, EQUATORIAL GUINEA,
ERITREA, ETHIOPIA, GABON, THE GAMBIA, GHANA, GUINEA,
BISSAU, COTE D'IVOIR (IVORY COAST), KENYA, LESOTHO]
2016-07-22 14:45:35 -06:00
...________...________...________...________...
2015-06-15 17:47:35 -07:00
LESOTHO
[ALGERIA, ANGOLA, BENIN, BOTSWANA, BURKINA FASO, BURUNDI,
CAMEROON, CAPE VERDE, CENTRAL AFRICAN REPUBLIC, CHAD,
COMOROS, CONGO, DJIBOUTI, EGYPT, EQUATORIAL GUINEA,
ERITREA, ETHIOPIA, GABON, THE GAMBIA, GHANA, GUINEA,
BISSAU, COTE D'IVOIR (IVORY COAST), KENYA]
2015-09-07 11:44:36 -06:00
*/