Download presentation
Presentation is loading. Please wait.
Published byEustacia Mason Modified over 9 years ago
1
Lecture4: Arrays Bohyung Han CSE, POSTECH bhhan@postech.ac.kr CSED233: Data Structures (2014F)
2
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Arrays A data structure holding a group of variables under a single identifiers 2 byte[] anArrayOfBytes; int[] anArrayOfLongs; long[] anArrayOfLongs; float[] anArrayOfFloats; double[] anArrayOfDoubles; boolean[] anArrayOfBooleans; char[] anArrayOfChars; String[] anArrayOfStrings; int[] a; a = new int[2]; int[] b = {1, 2, 3, 4}; int bLength = b.length; // array declaration without assignment // specify the length of the array // array declaration with assignment // get the length of an array
3
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Array Two‐dimensional arrays Array of arrays Size of two‐dimensional array Number of rows: Y.length Number of elements in each row: Y[i].length Note: Number of elements in each row may be different. Java: Array class http://docs.oracle.com/javase/7/docs/api/java/util/Arrays.html http://docs.oracle.com/javase/7/docs/api/java/util/Arrays.html 3 int[][] Y = new int[8][10];
4
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Abstract Data Type (ADT) Definition A mathematical model of the data objects that make up a data type as well as the functions that operate on these objects Defined indirectly, by the operations that may be performed on it and by mathematical constraints on the effects of those operations ADT is composed of A data structure A set of operations (called the methods or operations) A precise description of the types of the methods (called a signature) A precise set of rules about how it behaves (called the abstract specification or the axiomatic description) An implementation hidden from the programmer 4
5
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Array List ADT Array list is not array, but an extension of array. An array list stores a sequence of arbitrary objects. An element can be accessed, inserted or removed by specifying its index (number of elements preceding it). An exception is thrown if an incorrect index is given, e.g., negative one. Java: http://docs.oracle.com/javase/7/docs/api/java/util/ArrayList.htmlhttp://docs.oracle.com/javase/7/docs/api/java/util/ArrayList.html Java: Exception An event, which occurs during the execution of a program, that disrupts the normal flow of the program's instructions The Java platform provides numerous exception classes. All the classes are descendants of the Throwable class. All allow programs to differentiate among the various types of exceptions. Example: if (size == 0) { throw new EmptyStackException(); } 5
6
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Array List ADT Main methods get(integer i) : returns the element at index i without removing it set(integer i, object o) : replaces the element at index i with o and returns the old element add(integer i, object o) : inserts a new element o to have index i remove(integer i) : removes and returns the element at index i Additional methods: size() : returns the number of elements in this list isEmpty() : returns true if this list contains no elements 6
7
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Array‐Based Implementation 7 A 012n i
8
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Element Insertion 8 A 012n A 012n o
9
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Element Insertion 9 A 012n i A 012n i A 012n o i
10
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Element Removal 10 A 012n i A 012n o i A 012n i
11
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Performance 11 MethodTime complexity size() insert() get(i) set(i,o) add(o) add(i,,o) remove(i)
12
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Growable Array‐based Array List When the array is full in an add operation Throwing an exception Replacing the array with a larger one How large should the new array be? Incremental strategy: increase the size by a constant Doubling strategy: double the size 12
13
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Growable Array‐based Array List 13 Algorithm add(o) Input array A of n integers Output array A of n+1 integers if n = A.length then S new array of size … for i 0 to n-1 do S[i] A[i] A S n n + 1 A[n-1] o Create a new array S (larger than A) Copy the elements in A to S Replace A with S Increase array size by 1 and add o as the last element
14
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Comparison of the Strategies 14
15
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Incremental Strategy 15 Number of iterationsConstructions of new array with larger sizes
16
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Doubling Strategy 16 Geometric series 1 2 1 4 8 Number of iterations Constructions of new array with larger sizes
17
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Example with Array List 17 public class ArrayListTest { public static void main(String args[]) { ArrayList IntegerList = new ArrayList (); System.out.println("Empty array? " + IntegerList.isEmpty()); for(int i=0; i<20; i++) IntegerList.add(i); System.out.println("Num. of elements: " + IntegerList.size(); for(int i=1; i<IntegerList.size(); i*=2) IntegerList.remove(i); System.out.println("Num. of elements: " + IntegerList.size(); System.out.println("\nElements in array"); for(int i=0; i<IntegerList.size(); i++) System.out.println("\t" + i + ":" + IntegerList.get(i)); }
18
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Simple Implementation of ArrayList 18 import java.io.*; public class SimpleArrayList { protected int count; // number of elements in ArrayList protected T[] contents; // array of stored values protected static int DEFAULT_CAPACITY = 10; // constructors public SimpleArrayList() { contents = (T[]) new Object[DEFAULT_CAPACITY]; } public SimpleArrayList(int initCapacity) { contents = (T[]) new Object[initCapacity]; }
19
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Simple Implementation of ArrayList 19 public void add (T newElem) { if (count == contents.length) { T temp[] = contents; contents = (T[]) new Object[2*count]; for ( int i = 0; i < count; i++ ) contents[i] = temp[i]; } contents[count++] = newElem ; } public T get(int index) { if (index = count ) throw new IndexOutOfBoundsException("ArrayList:" + index) ; return contents[index] ; }
20
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Simple Implementation of ArrayList 20 public int size() { return count; } public T remove (int index) { if (index = count ) throw new IndexOutOfBoundsException("ArrayList:" + index); T temp = contents[index]; for (int j = index; j < count‐1; j++) contents[j] = contents[j+1]; count‐‐; return temp; }
21
CSED233: Data Structures by Prof. Bohyung Han, Fall 2014 Summary An ADT consists of A data structure: A collection of data, and its organization, structure, properties; The operations that can be performed: What can be done to change, manipulate, or look at the data Information hiding The “user” of an ADT must know enough to: Create one of them, and Perform the operations, but not What fundamental construct is used to store the data, and How the operations are done. 21 Some members, constructors and methods of ArrayList should be known. Detailed implementation of ArrayList class does not need to be known.
22
22
Similar presentations
© 2025 SlidePlayer.com. Inc.
All rights reserved.