14 – Sequential Containers

Slides:



Advertisements
Similar presentations
Lists and the Collection Interface Chapter 4. Chapter Objectives To become familiar with the List interface To understand how to write an array-based.
Advertisements

. STL: C++ Standard Library (continued). STL Iterators u Iterators are allow to traverse sequences u Methods  operator*  operator->  operator++, and.
Main Index Contents 11 Main Index Contents Container Types Container Types Sequence Containers Sequence Containers Associative Containers Associative Containers.
Lists and the Collection Interface Chapter 4. Chapter 4: Lists and the Collection Interface2 Chapter Objectives To become familiar with the List interface.
Fall 2007CS 2251 Lists and the Collection Interface Chapter 4.
C++ for Engineers and Scientists Third Edition
Chapter 7: Arrays. In this chapter, you will learn about: One-dimensional arrays Array initialization Declaring and processing two-dimensional arrays.
Data Structures Using C++ 2E
2 Preliminaries Options for implementing an ADT List Array has a fixed size Data must be shifted during insertions and deletions Linked list is able to.
Copyright © 2007 Pearson Education, Inc. Publishing as Pearson Addison-Wesley. Ver Chapter 4: Linked Lists Data Abstraction & Problem Solving with.
Containers Overview and Class Vector
Lists and the Collection Interface Chapter 4. 2 The List Interface and ArrayList Class So far, all we have is an array for storing a collection of elements.
Standard Template Library The Standard Template Library was recently added to standard C++. –The STL contains generic template classes. –The STL permits.
Lists Chapter 8. 2 Linked Lists As an ADT, a list is –finite sequence (possibly empty) of elements Operations commonly include: ConstructionAllocate &
Templates “Generic Programming” ECE Templates A way to write code once that works for many different types of variables –float, int, char, string,
1 Chapter 15-1 Pointers, Dynamic Data, and Reference Types Dale/Weems.
CS 31 Discussion, Week 7 Faisal Alquaddoomi, Office Hours: BH 2432, W 4:30-6:30pm, F 12:30-1:30pm.
A FIRST BOOK OF C++ CHAPTER 7 ARRAYS. OBJECTIVES In this chapter, you will learn about: One-Dimensional Arrays Array Initialization Arrays as Arguments.
Lists and the Collection Interface Chapter 4. Chapter 4: Lists and the Collection Interface2 Chapter Objectives To become familiar with the List interface.
CS212: Object Oriented Analysis and Design
“Generic Programming” ECE 297
Pointers and Dynamic Arrays
Programming with ANSI C ++
More Linking Up with Linked Lists
Exceptions, Templates, and the Standard Template Library (STL)
CSCE 210 Data Structures and Algorithms
Standard Template Library (STL)
Chapter 4 Linked Lists.
Data Structures Interview / VIVA Questions and Answers
CSCE 210 Data Structures and Algorithms
Starting Out with C++ Early Objects Eighth Edition
Wednesday, February 28, 2018 Announcements… For Today…
Tuesday, February 20, 2018 Announcements… For Today… 4+ For Next Time…
The Bag and Sequence Classes with Linked Lists
Friday, February 16, 2018 Announcements… For Today… 4.5-, pgs. 252
Collections Intro What is the STL? Templates, collections, & iterators
Sorting Chapter 10.
What remains Topics Assignments Final exam
Chapter 9 – Sets and Maps 9.1 Associative Container
Introduction to Linked Lists
10.6 Shell Sort: A Better Insertion
18 – Sequential Containers
C++ Templates L03 - Iterator 10 – Iterator.
Array Lists Chapter 6 Section 6.1 to 6.3
Lab 04 – Linked List.
Object Oriented Programming COP3330 / CGS5409
C Structures, Unions, Bit Manipulations and Enumerations
Lab 03 - Iterator.
Introduction to the Standard Template Library
15 – Sequential Containers
More About Data Types & Functions
14 – Sequential Containers
CIS16 Application Development and Programming using Visual Basic.net
Constructors and Other Tools
Introduction C is a general-purpose, high-level language that was originally developed by Dennis M. Ritchie to develop the UNIX operating system at Bell.
Linked Lists Chapter 4.
The Standard Template Library
Lecture 8 : Intro. to STL (Standard Template Library)
C++ Templates L03 - Iterator 10 – Iterator.
Introduction to Data Structure
Intro to Data Structures and ADTs
Data Structures & Algorithms
Standard Template Library
the Standard Template Library
Collections Intro What is the STL? Templates, collections, & iterators
Standard Template Library
8.3 Vectors Copyright © 2008 Pearson Addison-Wesley. All rights reserved. 1.
15 – Sequential Containers
Standard Template Library
Presentation transcript:

14 – Sequential Containers 4.1 Template Classes and the Vector 4.2 Applications of Vectors 14 – Sequential Containers

Attendance Quiz #9 Sequential Containers

Attendance Quiz #10 Sequential Containers

Tip #11: Standard Integer typedefs Sequential Containers The actual size of integer types varies by implementation. The standard only requires size relations between the data types (i.e., a long long is not smaller than long, which is not smaller than int, which is not smaller than short.) As char's size is always the minimum supported data type, no other data types (except bit-fields) can be smaller. The following pre-processor macros are defined in the header file <stdint.h>: signed unsigned Description int8_t uint8_t Integer type with a width of exactly 8, 16, 32, or 64 bits. For signed types, negative values are represented using 2's complement. No padding bits. int16_t uint16_t int32_t uint32_t int64_t uint64_t std::size_t Largest unsigned integer type; the size of any object in bytes; widely used in the standard library to represent sizes, lengths, and counts.

Review: Common Growth Rates Sequential Containers

Effects of Different Growth Rates Sequential Containers Algorithms with exponential and factorial growth rates have an effective practical limit on the size of the problem they can be used to solve. With an O(2n) algorithm, if 100 inputs takes an hour then, 101 inputs will take 2 hours 105 inputs will take 32 hours 114 inputs will take 16,384 hours (almost 2 years!) Encryption algorithms take advantage of this characteristic: Some cryptographic algorithms can be broken in O(2n) time, where n is the number of bits in the key. A key length of 40 is considered breakable by a modern computer. A key length of 100 bits will take a billion-billion (1018) times longer than a key length of 40.

Sequential Containers Chapter 4 Sequential Containers

Objectives Sequential Containers To become familiar with the Standard Template Library (STL) and template classes. To understand how to use a vector class and how to implement it using an array for storage. To understand the difference between a shallow copy and deep copy. To introduce linked lists and study the differences between single-, double-, and circular linked list data structures. To introduce structs. So far we’ve considered one data structure — the array. The C++ developers have provided more tools for programmers by providing a rich set of data structures written as C++ template classes. These template classes are all part of the Standard Template Library (STL). In this chapter we discuss the STL classes called sequences.

Sequence Classes Sequential Containers A sequence has the property that elements can be inserted or removed anywhere in the sequence, not just at the beginning or at the end. Some sequences are indexed, which means their elements can be accessed in arbitrary order (called random access) using a subscript to select an element. For other sequences you must start at the beginning and process the elements in order. Iterators facilitate sequential access and random access. The vector and list (linked list) classes implement the common interface requirements for sequential containers.

4.1, pgs. 232-236 4.1 Template Classes and the Vector Vector Specification of the vector Class Function at and the Subscripting Operator 4.1, pgs. 232-236

C++ Templates Sequential Containers Templates are a feature of the C++ programming language that allows functions and classes to be instantiated for generic types. Templates allow a function or class to work on many different data types without being rewritten for each one. template <typename T1, typename T2> class MyPair { private: T1 first; T2 second; public: MyPair(T1 first, T2 second) : this->first(first), this->second(second) { } T1 getFirst() { return first; } T2 getSecond() { return second; } }; MyPair<string, int> myDog("Dog", 36); MyPair<double, double> myFloats(3.0, 2.18);

The Vector Sequential Containers A vector is a template class based on an array which means you can select its elements in arbitrary order as determined by the subscript value. A vector supports the following operations that an array does not: Increase or decrease its length. Insert an element at a specified position without writing code to shift the other elements to make room. Remove an element at a specified position without writing code to shift the other elements to fill in the resulting gap. Vectors are used most often when a programmer wants to add new elements to the end of a list but still needs the capability to access, in arbitrary order, the elements stored in the list.

Vector Size Sequential Containers The size of a vector automatically increases as new elements are added to it, and the size decreases as elements are removed. If an insertion is not at the end of the vector, the existing entries in the vector are shifted automatically to make room for the entry being inserted. Similarly, if an element other than the last one is removed, the other entries are shifted automatically to close up the space that was vacated. The number of elements a vector currently contains is returned by the member function size. Each vector object also has a capacity, which is the number of elements it can store. When a vector’s size is equal to its capacity, the capacity is increased automatically.

A Vector Class Object Sequential Containers template<typename T> class Vector { private: // Data fields /** The initial capacity of the array */ static const size_t INITIAL_CAPACITY = 10; /** The current capacity of the array */ size_t current_capacity; /** The current num_items of the array */ size_t num_items; /** The array to contain the data */ T* the_data; public: // Member Functions ... }; We will implement a simplified version of the vector class. static means shared by all instances of Vector. const tells the compiler that no one can modify INITIAL_CAPACITY. The physical size of the array is indicated by the data field current_capacity (type size_t because it must be non-negative) The number of data items stored is indicated by the data field num_items

String Vector Sequential Containers vector<string> my_vector; my_vector.push_back("Bashful"); my_vector.push_back("Awful"); my_vector.push_back("Jumpy"); my_vector.push_back("Happy"); my_vector.insert(2, "Doc"); my_vector.push_back("Dopey"); my_vector.erase(1); my_vector[2] = "Sneezy";

Specification of the vector Class Sequential Containers Because Item_Type is determined when the vector is created, the actual argument types and return types for these functions may be different for different instantiations of the vector class 2 entries for operator [] and member function at - const values can’t be changed. Function at validates the index The size_t type is an unsigned int; we use it here because all vector indexes must be nonnegative

Function at and Subscript Operator Sequential Containers The non-const operators reference an element of the vector whose value can be changed. The const subscripting operator (“[ ]”) also returns a reference to element of the vector but the value cannot be changed. Both of the following statements retrieve and display the value of element 2 of vector<int> v cout << v[2]; cout << v.at(2); Both of the following statements add 6 to the value of element 2 of vector v and assign that sum to element 3 of vector v v[3] = v[2] + 6; v.at(3) = v.at(2) + 6; In these statements, the reference to element 2 retrieves a value of vector v that is not changed In contrast, both references to element 3 change its value. The function at validates the index.

4.2 Applications of Vectors 4.2, pgs. 238-240

Vectors vs. Static Arrays Sequential Containers Vectors can grow, static arrays cannot. If you use a vector to store enemies in a game, then the vector will grow as the number of enemies increase. If you use a static array, then it must be large enough to contain the maximum possible number of enemies. And that memory will be “used up” for the entire duration of the game. Std::vectors work with STL algorithms which may save some time in coding certain effects. Vectors pre-allocates space for future elements, so extra space required beyond what's necessary for the elements themselves is allocated. Vector iterators are invalidated if you add or remove elements to or from the vector.

Traversing STL Vectors w/Iterators Sequential Containers Typically, iterators are used to access elements of a container in linear fashion. int sum = 0; vector<int> vec = { 1, 2, 3, 4, 5 }; using Iter = std::vector<int>::const_iterator; for (Iter iter = vec.begin(); iter!=vec.end(); ++iter) { sum += *iter; } Vector iterators are used with standard algorithms. #include <numeric> vector<int> vec = { 1, 2, 3, 4, 5 }; int sum = std::accumulate(vec.begin(), vec.end(), 0) The advantage of using iterator is that you can apply the same pattern with other containers.

Traversing STL Vectors w/Iterators Sequential Containers Random-access iterators are iterators that can be used to access elements at an arbitrary offset position relative to the element they point to, offering the same functionality as pointers. With "random access iterators", it is possible to access any element in the same fashion as operator[]. std::vector<int> vec = { 1, 2, 3, 4, 5, 6, 7, 8, 9, 10 }; std::vector<int>::iterator iter = vec.begin(); int sixth = *(iter + 5); int third = *(2 + iter); int second = iter[1]; cout << "6th = " << sixth << endl; cout << "3rd = " << third << endl; cout << "2nd = " << second << endl;