Lecture 4a Using The Standard Template Library. Jack Applin, Guest Lecturer
|
|
- Lindsay Gilbert
- 5 years ago
- Views:
Transcription
1 Lecture 4a Using The Standard Template Library Jack Applin, Guest Lecturer November 28 th, CS253 Fall 2017 Bruce Draper 1
2 PA9 is online Announcements Efficiency assignment Same as PA8 But graded on speed as well as correctness Since Bruce is traveling, use Piazza for questions Recitation this week Installing & using Eclipse for C++ Mandatory Recitation next week Optional help session CS253 Fall 2017 Bruce Draper 2
3 STL 1. Containers Abstractions of data structures 2. Iterators Abstractions of pointers Allow you to iterate through containers 3. Algorithms Universal algorithms (e.g. sort) Without reference to object type being acted on Without reference to data structure holding the objects 4. Other Multi-threading Numerics Smart pointers CS370 will cover multi-threading Sorry, skipping this part Thursday & next Tuesday! Today s Focus CS253 Fall 2017 Bruce Draper 3
4 Containers (Review) Containers are data structures Sequences Array (static) Vector (dynamic, 1-sided) Deque (dynamic, 2-sided) Slist (singly linked) List (doubly linked) Binary Trees Set (unique items) Multi-set (repeated items) Map (unique keys, key/value pairs) Multimap (repeated keys) Hash Tables Unorderd_set (unqiue items) Unordered_multis et (repeated) Unordered_map (unique keys) Unordered_multi map (repeated) CS253 Fall 2017 Bruce Draper 4
5 Iterators (Review) Abstractions of Pointers Overload *, ->, ==,!=, and ++ Some overload --, +, and - Similar to iterators in Java They support iteration Within the semantics of a container Every container defines an iterator type vector<int>::iterator unordered_multiset<quagga>::iterator CS253 Fall 2017 Bruce Draper 5
6 STL Algorithms (Review) Goals: Provide useful basic algorithms (e.g. sort ) Without regard to the data type operated on Without regard to the data structure it is stored in Over a whole container or a fragment thereof Example template<typename ITER> ITER max_element(iter start, ITER end) { ITER max_iter = start; for(iter iter=start; iter!=end; ++iter) if ((*iter)>(*max_iter)) max_iter = iter; return max_iter; CS253 Fall 2017 Bruce Draper 6
7 An Example A simplified version of PA4 Our example is a Document class with 2 methods: Constructor: reads a text file and computes stemmed term frequencies Print(): writes terms and frequencies to std::cout It uses a simplified Stemmer class Removes initial capitals and trailing s Not a real stemmer, just a placeholder CS253 Fall 2017 Bruce Draper 7
8 Stem.h #ifndef STEM_H_DEFINED #define STEM_H_DEFINED #include<string> using std::string; class Stemmer { public: string operator () (const string& str) const; ; #endif // STEM_H_DEFINED //Note: Defined as a Functor CS253 Fall 2017 Bruce Draper 8
9 Document.h (edited) class Document { public: Document(ifstream& str); void Print() const; private: vector<string> unique_words; vector<int> counts; ; Many of you store terms & frequencies this way CS253 Fall 2017 Bruce Draper 9
10 Document Constructor (Part 1) Document::Document(ifstream& istr) { vector<string> raw_words; while(!istr.fail()) { string word; istr >> word; if (!istr.fail()) raw_words.push_back(word); Step #1: read words into vector Stemmer stemmer; vector<string> stemmed_words; for(unsigned int i=0; i < raw_words.size(); i++) { stemmed_words.push_back(stemmer(raw_words[i])); Step #2: stem words into new vector CS253 Fall 2017 Bruce Draper 10
11 Document Constructor (Part 2) // Step #3: sort the terms std::sort(stemmed_words.begin(), stemmed_words.end()); // Step #4: keep unique terms, count frequencies unique_words.push_back(stemmed_words.at(0)); counts.push_back(1); for(unsigned int i=1; i < stemmed_words.size(); i++) { if (0 == stemmed_words.at(i).compare(stemmed_words.at(i-1))) counts.back()++; else { unique_words.push_back(stemmed_words.at(i)); counts.push_back(1); CS253 Fall 2017 Bruce Draper 11
12 Using STL STL algorithm can make this code Simpler More efficient Terms & frequencies are key/value pairs For every term (key) we have a count (value) Replace the term & frequency vectors with a map<string, int> CS253 Fall 2017 Bruce Draper 12
13 #include<map> using std::map; Document.h (edited) class Document { public: Document(ifstream& str); void Print() const; private: map<string, int> frequencies; ; CS253 Fall 2017 Bruce Draper 13
14 Replace Constructor Steps 3&4 Document::Document(ifstream& istr) { vector<string> raw_words; while(!istr.fail()) { string word; istr >> word; if (!istr.fail()) raw_words.push_back(word); Stemmer stemmer; vector<string> stemmed_words; for(unsigned int i=0; i < raw_words.size(); i++) { stemmed_words.push_back(stemmer(raw_words[i])); for(unsigned int i=0; i < stemmed_words.size(); i++) { frequencies[stemmed_words.at(i)]++; Notes: 1. Sorting step is gone Map used lexicographic order by default 2. Uniqueness testing handled by map If string isn t in map, [] adds it with a value of CS253 Fall 2017 Bruce Draper 14
15 Using STL (II) Step 2 copies words from one vector to another while stemming them. This is what the std::transform does Conveniently, the stemmer is a functor Potential STL trap: memory Transform doesn t allocate new memory It assigns, it doesn t push Therefore pre-allocate destination array CS253 Fall 2017 Bruce Draper 15
16 Constructor version 3 Document::Document(ifstream& istr) { vector<string> raw_words; while(!istr.fail()) { string word; istr >> word; if (!istr.fail()) raw_words.push_back(word); Stemmer stemmer; vector<string> stemmed_words(raw_words.size()); transform(raw_words.begin(), raw_words.end(), stemmed_words.begin(), stemmer); for(unsigned int i=0; i < stemmed_words.size(); i++) { frequencies[stemmed_words.at(i)]++; CS253 Fall 2017 Bruce Draper 16
17 Using STL (III) Can we combine the loops? Trickier : not just iteration First loop copies from one vector to another While stemming the strings Second loop increments frequencies Solution Use the local memory in the functor Replace transform with for_each (side effects only) CS253 Fall 2017 Bruce Draper 17
18 using std::string; #include<map> using std::map; Stem.h (modified) class Stemmer { public: Stemmer(map<string, int>& freq) : store(freq) { void operator () (string str) const; protected: map<string, int>& store; ; CS253 Fall 2017 Bruce Draper 18
19 Stem.cpp void Stemmer::operator() (string str) const { // This is same as before if (isupper(str.at(0))) str.at(0) = tolower(str.at(0)); if (str.back() == 's') str = str.substr(0, str.length()-1); // This is new store[str]++; CS253 Fall 2017 Bruce Draper 19
20 Document Constructor Document::Document(ifstream& istr) { vector<string> raw_words; while(!istr.fail()) { string word; istr >> word; if (!istr.fail()) raw_words.push_back(word); Stemmer stemmer(frequencies); for_each(raw_words.begin(), raw_words.end(), stemmer); CS253 Fall 2017 Bruce Draper 20
21 Using STL (IV) How about the I/O loop? Memory must be handled Don t know length of file in advance Can t preallocate array Create a new functor, have it push data CS253 Fall 2017 Bruce Draper 21
22 Reader (Functor) class Reader { public: Reader(vector<string>& word_vector) words(word_vector) { void operator() (const string& str) con {words.push_back(str); protected: vector<string>& words; ; CS253 Fall 2017 Bruce Draper 22
23 Document Constructor Document::Document(ifstream& istr) { vector<string> raw_words; Reader reader(raw_words); for_each(istream_iterator<string>(istr), istream_iterator<string>(), reader); Stemmer stemmer(frequencies); for_each(raw_words.begin(), raw_words.end(), stemmer); CS253 Fall 2017 Bruce Draper 23
24 Using STL (V) Why create stemmer & reader as local variables? We don t re-use them Why not just allocate them inline? CS253 Fall 2017 Bruce Draper 24
25 Document Constructor Document::Document(ifstream& istr) { vector<string> raw_words; for_each(istream_iterator<string>(istr), istream_iterator<string>(), Reader(raw_words)); for_each(raw_words.begin(), raw_words.end(), Stemmer(frequencies)); CS253 Fall 2017 Bruce Draper 25
26 Using STL (VI -- and last) In PA4, you needed a vector of words To resolve capitalization To judge reading level Frequencies of terms To compute TF-IDF scores But for this example I can fuse the loops CS253 Fall 2017 Bruce Draper 26
27 Document Constructor // Yes, this is one line of top-level code Document::Document(ifstream& istr) { for_each(istream_iterator<string>(istr), istream_iterator<string>(), Stemmer(frequencies)); CS253 Fall 2017 Bruce Draper 27
Lecture 15a Persistent Memory & Shared Pointers
Lecture 15a Persistent Memory & Shared Pointers Dec. 5 th, 2017 Jack Applin, Guest Lecturer 2017-12-04 CS253 Fall 2017 Jack Applin & Bruce Draper 1 Announcements PA9 is due today Recitation : extra help
More informationCS11 Advanced C++ Fall Lecture 1
CS11 Advanced C++ Fall 2006-2007 Lecture 1 Welcome! ~8 lectures Slides are posted on CS11 website http://www.cs.caltech.edu/courses/cs11 ~6 lab assignments More involved labs 2-3 week project at end CS
More informationTEMPLATES AND ITERATORS
TEMPLATES AND ITERATORS Problem Solving with Computers-I https://ucsb-cs24-sp17.github.io/ 2 Announcements Checkpoint deadline for pa04 (aka lab05) is due today at 11:59pm Be sure to push your code to
More informationCSCI-1200 Data Structures Fall 2018 Lecture 22 Hash Tables, part 2 & Priority Queues, part 1
Review from Lecture 21 CSCI-1200 Data Structures Fall 2018 Lecture 22 Hash Tables, part 2 & Priority Queues, part 1 the single most important data structure known to mankind Hash Tables, Hash Functions,
More informationCS197c: Programming in C++
CS197c: Programming in C++ Lecture 2 Marc Cartright http://ciir.cs.umass.edu/~irmarc/cs197c/index.html Administration HW1 will be up this afternoon Written assignment Due in class next week See website
More informationAnnouncements. Lecture 05a Header Classes. Midterm Format. Midterm Questions. More Midterm Stuff 9/19/17. Memory Management Strategy #0 (Review)
Announcements Lecture 05a Sept. 19 th, 2017 9/19/17 CS253 Fall 2017 Bruce Draper 1 Quiz #4 due today (before class) PA1/2 Grading: If something is wrong with your code, you get sympathy PA3 is due today
More informationSTL Quick Reference for CS 241
STL Quick Reference for CS 241 Spring 2018 The purpose of this document is to provide basic information on those elements of the C++14 standard library we think are most likely to be needed in CS 241.
More informationuse static size for this buffer
Software Design (C++) 4. Templates and standard library (STL) Juha Vihavainen University of Helsinki Overview Introduction to templates (generics) std::vector again templates: specialization by code generation
More informationCOP4530 Data Structures, Algorithms and Generic Programming Recitation 4 Date: September 14/18-, 2008
COP4530 Data Structures, Algorithms and Generic Programming Recitation 4 Date: September 14/18-, 2008 Lab topic: 1) Take Quiz 4 2) Discussion on Assignment 2 Discussion on Assignment 2. Your task is to
More informationCOMP6771 Advanced C++ Programming
1. COMP6771 Advanced C++ Programming Week 7 Part One: Member Templates and 2016 www.cse.unsw.edu.au/ cs6771 2. Member Templates Consider this STL code: 1 #include 2 #include 3 #include
More informationContainer Notes. Di erent Kinds of Containers. Types Defined by Containers. C++11 Container Notes C++11
Di erent Kinds of Containers Container Notes A container is an object that stores other objects and has methods for accessing the elements. There are two fundamentally di erent kinds of containers: Sequences
More informationCSE 100: C++ TEMPLATES AND ITERATORS
1 CSE 100: C++ TEMPLATES AND ITERATORS 2 Announcements Look out for the extra weekend section More on git and C++ (iterators) Live demo by your friendly tutors Not mandatory but it will be fun Bring your
More informationDynamic Data Structures
Dynamic Data Structures We have seen that the STL containers vector, deque, list, set and map can grow and shrink dynamically. We now examine how some of these containers can be implemented in C++. To
More informationChapter 17: Linked Lists
Chapter 17: Linked Lists 17.1 Introduction to the Linked List ADT Introduction to the Linked List ADT Linked list: set of data structures (nodes) that contain references to other data structures list head
More informationCSE 100: C++ TEMPLATES AND ITERATORS
CSE 100: C++ TEMPLATES AND ITERATORS Announcements iclickers: Please register at ted.ucsd.edu. Start ASAP!! For PA1 (Due next week). 10/6 grading and 10/8 regrading How is Assignment 1 going? A. I haven
More informationExceptions, Templates, and the STL
Exceptions, Templates, and the STL CSE100 Principles of Programming with C++, Fall 2018 (based off Chapter 16 slides by Pearson) Ryan Dougherty Arizona State University http://www.public.asu.edu/~redoughe/
More informationCSE 100: C++ TEMPLATES AND ITERATORS
CSE 100: C++ TEMPLATES AND ITERATORS Announcements Gradesource and clickers: We ll be making one more pass for unregistered clickers tonight, but after that you ll be on your own How is Assignment 1 going?
More informationCPSC 427a: Object-Oriented Programming
CPSC 427a: Object-Oriented Programming Michael J. Fischer Lecture 17 November 1, 2011 CPSC 427a, Lecture 17 1/21 CPSC 427a, Lecture 17 2/21 CPSC 427a, Lecture 17 3/21 A bit of history C++ standardization.
More informationComputer Science II Lecture 2 Strings, Vectors and Recursion
1 Overview of Lecture 2 Computer Science II Lecture 2 Strings, Vectors and Recursion The following topics will be covered quickly strings vectors as smart arrays Basic recursion Mostly, these are assumed
More informationG52CPP C++ Programming Lecture 18. Dr Jason Atkin
G52CPP C++ Programming Lecture 18 Dr Jason Atkin 1 Last lecture Operator Overloading Strings and streams 2 Operator overloading - what to know Know that you can change the meaning of operators Know that
More informationCS11 Introduction to C++ Spring Lecture 8
CS11 Introduction to C++ Spring 2013-2014 Lecture 8 Local Variables string getusername() { string user; } cout user; return user;! What happens to user when function
More informationChapter 5. The Standard Template Library.
Object-oriented programming B, Lecture 11e. 1 Chapter 5. The Standard Template Library. 5.1. Overview of main STL components. The Standard Template Library (STL) has been developed by Alexander Stepanov,
More informationAssociative Containers and Iterators. Ali Malik
Associative Containers and Iterators Ali Malik malikali@stanford.edu Game Plan Recap Associative Containers Iterators Map Iterators The auto keyword (maybe) Range-Based for Loops (maybe) Recap Structs
More informationSpare Matrix Formats, and The Standard Template Library
Annotated slides CS319: Scientific Computing (with C++) Spare Matrix Formats, and The Standard Template Library Week 10: 9am and 4pm, 20 March 2019 1 Sparse Matrices 2 3 Compressed Column Storage 4 (Not)
More informationG52CPP C++ Programming Lecture 18
G52CPP C++ Programming Lecture 18 Dr Jason Atkin http://www.cs.nott.ac.uk/~jaa/cpp/ g52cpp.html 1 Welcome Back 2 Last lecture Operator Overloading Strings and streams 3 Operator overloading - what to know
More informationUnit 1: Preliminaries Part 4: Introduction to the Standard Template Library
Unit 1: Preliminaries Part 4: Introduction to the Standard Template Library Engineering 4892: Data Structures Faculty of Engineering & Applied Science Memorial University of Newfoundland May 6, 2010 ENGI
More informationAnnouncements. Lecture 04b Header Classes. Review (again) Comments on PA1 & PA2. Warning about Arrays. Arrays 9/15/17
Announcements Lecture 04b Sept. 14 th, 2017 Midterm #1: Sept. 26 th (week from Tuesday) Code distributed one week from today PA2 test cases & answers posted Quiz #4 next Tuesday (before class) PA3 due
More informationContainers in C++ and Java
Containers in C++ and Java 1 1. Which of the following statements is true? a) Equality on the basis of reference implies equality on the basis of content. b) Equality on the basis of content implies equality
More informationC++: Overview and Features
C++: Overview and Features Richard Newman r.newman@rdg.ac.uk Room CS127 2003-12-11 Programming & Design, 2003 1 Introduction You have: used streams seen how classes are used seen some C++ code Today: good
More informationGridKa School 2013: Effective Analysis C++ Standard Template Library
GridKa School 2013: Effective Analysis C++ Standard Template Library Introduction Jörg Meyer, Steinbuch Centre for Computing, Scientific Data Management KIT University of the State of Baden-Wuerttemberg
More informationName: Username: I. 20. Section: II. p p p III. p p p p Total 100. CMSC 202 Section 06 Fall 2015
CMSC 202 Section 06 Fall 2015 Computer Science II Midterm Exam I Name: Username: Score Max Section: (check one) 07 - Sushant Athley, Tuesday 11:30am 08 - Aishwarya Bhide, Thursday 11:30am 09 - Phanindra
More informationItem 3: Predicates, Part 2: Matters of State
ITEM1_11new.fm Page 1 Tuesday, November 27, 2001 12:41 PM Item 3: Predicates, Part 2: Matters of State ITEM 3: PREDICATES, PART 2: MATTERS OF STATE DIFFICULTY: 7 Following up from the introduction given
More informationCSCI-1200 Data Structures Fall 2018 Lecture 21 Hash Tables, part 1
Review from Lecture 20 CSCI-1200 Data Structures Fall 2018 Lecture 21 Hash Tables, part 1 Finishing binary search trees & the ds set class Operators as non-member functions, as member functions, and as
More informationChapter 17: Linked Lists
Chapter 17: Linked Lists Copyright 2009 Pearson Education, Inc. Copyright Publishing as Pearson 2009 Pearson Addison-Wesley Education, Inc. Publishing as Pearson Addison-Wesley 17.1 Introduction to the
More informationStructuur van Computerprogramma s 2
Structuur van Computerprogramma s 2 dr. Dirk Deridder Dirk.Deridder@vub.ac.be http://soft.vub.ac.be/ Vrije Universiteit Brussel - Faculty of Science and Bio-Engineering Sciences - Computer Science Department
More informationCSCI-1200 Data Structures Fall 2017 Lecture 23 Functors & Hash Tables, part II
CSCI-1200 Data Structures Fall 2017 Lecture 23 Functors & Hash Tables, part II Review from Lecture 22 A Heap as a Vector Building a Heap Heap Sort the single most important data structure known to mankind
More informationException Namespaces C Interoperability Templates. More C++ David Chisnall. March 17, 2011
More C++ David Chisnall March 17, 2011 Exceptions A more fashionable goto Provides a second way of sending an error condition up the stack until it can be handled Lets intervening stack frames ignore errors
More informationStarting to Program in C++ (Basics & I/O)
Copyright by Bruce A. Draper. 2017, All Rights Reserved. Starting to Program in C++ (Basics & I/O) On Tuesday of this week, we started learning C++ by example. We gave you both the Complex class code and
More informationLecture 2 Polymorphism, Traits, Policies, and Inheritance
Lecture 2 Polymorphism, Traits, Policies, and Inheritance Kenny Erleben Department of Computer Science University of Copenhagen c K. Erleben, May 4, 2006 p. 1/36 Polymorphism 1 Traditional, define abstract
More informationHomework 4. Any questions?
CSE333 SECTION 8 Homework 4 Any questions? STL Standard Template Library Has many pre-build container classes STL containers store by value, not by reference Should try to use this as much as possible
More informationCSCI-1200 Data Structures Fall 2016 Lecture 17 Associative Containers (Maps), Part 2
CSCI-1200 Data Structures Fall 2016 Lecture 17 Associative Containers (Maps), Part 2 Review of Lecture 16 Maps are associations between keys and values. Maps have fast insert, access and remove operations:
More information(8 1) Container Classes & Class Templates D & D Chapter 18. Instructor - Andrew S. O Fallon CptS 122 (October 8, 2018) Washington State University
(8 1) Container Classes & Class Templates D & D Chapter 18 Instructor - Andrew S. O Fallon CptS 122 (October 8, 2018) Washington State University Key Concepts Class and block scope Access and utility functions
More informationCSCI-1200 Data Structures Fall 2015 Lecture 24 Hash Tables
CSCI-1200 Data Structures Fall 2015 Lecture 24 Hash Tables Review from Lecture 22 & 23 STL Queues & Stacks Definition of a Prioriry Queue / Binary Heap percolate_up and percolate_down A Heap as a Vector,
More informationCS 32. Lecture 5: Templates
CS 32 Lecture 5: Templates Vectors Sort of like what you remember from Physics but sort of not Can have many components Usually called entries Like Python lists Array vs. Vector What s the difference?
More informationIntroduction to ADTs
Data Structure Introduction to ADTs A particular way of storing and organizing data in a computer so that it can be used efficiently *from Wikipedia A set of data values and associated operations that
More informationData Structures and Algorithms
Data Structures and Algorithms Alice E. Fischer Lecture 3 217 Alice E. Fischer Data Structures L3... 1/31 1 Arrays Growing Arrays vectors 2 3 Empty Lists Inserting Data - Unsorted Inserting Data - Sorted
More informationCSCI-1200 Data Structures Fall 2009 Lecture 20 Hash Tables, Part II
Review from Lecture 19 CSCI-1200 Data Structures Fall 2009 Lecture 20 Hash Tables, Part II Operators as non-member functions, as member functions, and as friend functions. A hash table is a table implementation
More informationCS106X Handout 26 Winter 2018 February 12 th, 2018 Section Handout
CS06X Handout 26 Winter 208 February 2 th, 208 Section Handout Problem : Searching Skip Lists Imagine the sorted, singly linked list drawn below: In spite of its being sorted, it still takes linear time
More informationImprove your C++! John Richardson. Lab Study Meeting 2013
Improve your C++! John Richardson Lab Study Meeting 2013 Objectives How do I use the standard library correctly? What is C++11? Should I use it? Skills for debugging...? What kind of profiling is possible
More informationCMSC 202 Final May 19, Name: UserID: (Circle your section) Section: 101 Tuesday 11: Thursday 11:30
CMSC 202 Final May 19, 2005 Name: UserID: (Circle your section) Section: 101 Tuesday 11:30 102 Thursday 11:30 Directions 103 Tuesday 12:30 104 Thursday 12:30 105 Tuesday 1:30 106 Thursday 1:30 This is
More informationTemplates and Vectors
Templates and Vectors 1 Generic Programming function templates class templates 2 the STL vector class a vector of strings enumerating elements with an iterator inserting and erasing 3 Writing our own vector
More informationSpring 2003 Instructor: Dr. Shahadat Hossain. Administrative Matters Course Information Introduction to Programming Techniques
1 CPSC2620 Advanced Programming Spring 2003 Instructor: Dr. Shahadat Hossain 2 Today s Agenda Administrative Matters Course Information Introduction to Programming Techniques 3 Course Assessment Lectures:
More informationThe Standard Template Library. An introduction
1 The Standard Template Library An introduction 2 Standard Template Library (STL) Objective: Reuse common code Common constructs: Generic containers and algorithms STL Part of the C++ Standard Library
More informationStandard Template Library
Standard Template Library The standard template library (STL) contains CONTAINERS ALGORITHMS ITERATORS A container is a way that stored data is organized in memory, for example an array of elements. Algorithms
More informationC++ Standard Template Library
C++ Standard Template Library CSE 333 Summer 2018 Instructor: Hal Perkins Teaching Assistants: Renshu Gu William Kim Soumya Vasisht C++ s Standard Library C++ s Standard Library consists of four major
More informationIntroducing C++ to Java Programmers
Introducing C++ to Java Programmers by Kip Irvine updated 2/27/2003 1 Philosophy of C++ Bjarne Stroustrup invented C++ in the early 1980's at Bell Laboratories First called "C with classes" Design Goals:
More informationCS11 Advanced C++ Fall Lecture 7
CS11 Advanced C++ Fall 2006-2007 Lecture 7 Today s Topics Explicit casting in C++ mutable keyword and const Template specialization Template subclassing Explicit Casts in C and C++ C has one explicit cast
More informationElevate your Code to Modern C++ with Automated Tooling. Peter Sommerlad
Elevate your Code to Modern C++ with Automated Tooling Peter Sommerlad Simple C++ Less Code == More Software Know your language and its (modern) idioms Don t be afraid of STL or templates Start small.
More informationCSCI-1200 Data Structures Fall 2017 Lecture 12 Advanced Recursion
CSCI-1200 Data Structures Fall 2017 Lecture 12 Advanced Recursion Review from Lecture 11 & Lab 6 Limitations of singly-linked lists Doubly-linked lists: Structure Insert Remove Our own version of the STL
More informationCSE 333. Lecture 11 - constructor insanity. Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington
CSE 333 Lecture 11 - constructor insanity Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington Administrivia Exercises: - New exercise out today, due Monday morning
More informationRecap: Pointers. int* int& *p &i &*&* ** * * * * IFMP 18, M. Schwerhoff
Recap: Pointers IFMP 18, M. Schwerhoff int* int& *p &i &*&* ** * * * * A 0 A 1 A 2 A 3 A 4 A 5 A 0 A 1 A 2 A 3 A 4 A 5 5 i int* p; A 0 A 1 A 2 A 3 A 4 A 5 5 i p int* p; p = &i; A 0 A 1 A 2 A 3 A 4 A 5
More informationCIS 190: C/C++ Programming. Lecture 12 Student Choice
CIS 190: C/C++ Programming Lecture 12 Student Choice Outline Hash Maps Collisions Using Open Addressing Collisions Chaining Collisions In C++ C++ STL Containers C++ GUI Resources Hash Maps (AKA Hash Tables)
More informationCSCI-1200 Data Structures Spring 2018 Lecture 14 Associative Containers (Maps), Part 1 (and Problem Solving Too)
CSCI-1200 Data Structures Spring 2018 Lecture 14 Associative Containers (Maps), Part 1 (and Problem Solving Too) HW6 NOTE: Do not use the STL map or STL pair for HW6. (It s okay to use them for the contest.)
More informationI m sure you have been annoyed at least once by having to type out types like this:
Type Inference The first thing I m going to talk about is type inference. C++11 provides mechanisms which make the compiler deduce the types of expressions. These features allow you to make your code more
More informationThe following is an excerpt from Scott Meyers new book, Effective C++, Third Edition: 55 Specific Ways to Improve Your Programs and Designs.
The following is an excerpt from Scott Meyers new book, Effective C++, Third Edition: 55 Specific Ways to Improve Your Programs and Designs. Item 47: Use traits classes for information about types. The
More informationComputational Physics
Computational Physics numerical methods with C++ (and UNIX) 2018-19 Fernando Barao Instituto Superior Tecnico, Dep. Fisica email: fernando.barao@tecnico.ulisboa.pt Computational Physics 2018-19 (Phys Dep
More informationProgramming C++ Lecture 2. Howest, Fall 2014 Instructor: Dr. Jennifer B. Sartor
Programming C++ Lecture 2 Howest, Fall 2014 Instructor: Dr. Jennifer B. Sartor Jennifer.sartor@elis.ugent.be S Arrays and Pointers void myprint(const char *); int main() { char *phrasey = C++Fun ; myprint(phrasey);
More informationCS32 Discussion Sec.on 1B Week 2. TA: Zhou Ren
CS32 Discussion Sec.on 1B Week 2 TA: Zhou Ren Agenda Copy Constructor Assignment Operator Overloading Linked Lists Copy Constructors - Motivation class School { public: }; School(const string &name); string
More informationLecture 8. Xiaoguang Wang. February 13th, 2014 STAT 598W. (STAT 598W) Lecture 8 1 / 47
Lecture 8 Xiaoguang Wang STAT 598W February 13th, 2014 (STAT 598W) Lecture 8 1 / 47 Outline 1 Introduction: C++ 2 Containers 3 Classes (STAT 598W) Lecture 8 2 / 47 Outline 1 Introduction: C++ 2 Containers
More informationCSE100. Advanced Data Structures. Lecture 4. (Based on Paul Kube course materials)
CSE100 Advanced Data Structures Lecture 4 (Based on Paul Kube course materials) Lecture 4 Binary search trees Toward a binary search tree implementation using C++ templates Reading: Weiss Ch 4, sections
More informationType Aliases. Examples: using newtype = existingtype; // C++11 typedef existingtype newtype; // equivalent, still works
Type Aliases A name may be defined as a synonym for an existing type name. Traditionally, typedef is used for this purpose. In the new standard, an alias declaration can also be used C++11.Thetwoformsareequivalent.
More informationC++ Mini-Course. Part 1: Mechanics Part 2: Basics Part 3: References Part 4: Const Part 5: Inheritance Part 6: Libraries Part 7: Conclusion. C Rulez!
C++ Mini-Course Part 1: Mechanics Part 2: Basics Part 3: References Part 4: Const Part 5: Inheritance Part 6: Libraries Part 7: Conclusion C Rulez! C++ Rulez! C++ Mini-Course Part 1: Mechanics C++ is a
More informationProgramming Assignment #4 Binary Trees in C++
Programming Assignment #4 Binary Trees in C++ Professor Hugh C. Lauer CS-2303, System Programming Concepts (Slides include materials from The C Programming Language, 2 nd edition, by Kernighan and Ritchie,
More informationW3101: Programming Languages C++ Ramana Isukapalli
Lecture-6 Operator overloading Namespaces Standard template library vector List Map Set Casting in C++ Operator Overloading Operator overloading On two objects of the same class, can we perform typical
More informationSets and MultiSets. Contents. Steven J. Zeil. July 19, Overview of Sets and Maps 4
Steven J. Zeil July 19, 2013 Contents 1 Overview of Sets and Maps 4 1 2 The Set ADT 6 2.1 The template header................................. 14 2.2 Internal type names.................................
More informationPurpose of Review. Review some basic C++ Familiarize us with Weiss s style Introduce specific constructs useful for implementing data structures
C++ Review 1 Purpose of Review Review some basic C++ Familiarize us with Weiss s style Introduce specific constructs useful for implementing data structures 2 Class The Class defines the data structure
More informationCOMP6771 Advanced C++ Programming
1. COMP6771 Advanced C++ Programming Week 6 Part Three: 2016 www.cse.unsw.edu.au/ cs6771 2. Why? In C++, class names cannot be overloaded. Thus: 1 class IntStack { 2 public: 3 void push(int&); 4 void pop();
More informationCS106X Handout 27 Winter 2015 February 18 th, 2015 Section Handout. list after call braid(list) 3 3 à 3
CS06X Handout 27 Winter 205 February 8 th, 205 Section Handout Discussion Problem : Braided Lists Write a function called braid that takes the leading address of a singly linked list, and weaves the reverse
More informationTHE STANDARD TEMPLATE LIBRARY (STL) Week 6 BITE 1513 Computer Game Programming
THE STANDARD TEMPLATE LIBRARY (STL) Week 6 BITE 1513 Computer Game Programming What the heck is STL???? Another hard to understand and lazy to implement stuff? Standard Template Library The standard template
More informationWinter 2018 March 12 th, 2018 CS106X Midterm Examination Solution
CS106X Handout 35S Winter 2018 March 12 th, 2018 CS106X Midterm Examination Solution Once again, your awesome course staff spent the week grading your exams, and I m happy to share that they re graded!
More informationC++ Mini-Course. Part 1: Mechanics Part 2: Basics Part 3: References Part 4: Const Part 5: Inheritance Part 6: Libraries Part 7: Conclusion. C Rulez!
C++ Mini-Course Part 1: Mechanics Part 2: Basics Part 3: References Part 4: Const Part 5: Inheritance Part 6: Libraries Part 7: Conclusion C Rulez! C++ Rulez! C++ Mini-Course Part 1: Mechanics C++ is a
More informationPraktikum: Entwicklung interaktiver eingebetteter Systeme
Praktikum: Entwicklung interaktiver eingebetteter Systeme C++-Labs (falk@cs.fau.de) 1 Agenda Writing a Vector Class Constructor, References, Overloading Templates, Virtual Functions Standard Template Library
More informationWhen we program, we have to deal with errors. Our most basic aim is correctness, but we must
Chapter 5 Errors When we program, we have to deal with errors. Our most basic aim is correctness, but we must deal with incomplete problem specifications, incomplete programs, and our own errors. When
More informationCSCI-1200 Computer Science II Fall 2008 Lecture 15 Associative Containers (Maps), Part 2
CSCI-1200 Computer Science II Fall 2008 Lecture 15 Associative Containers (Maps), Part 2 Review of Lecture 14 Maps are associations between keys and values. Maps have fast insert, access and remove operations:
More informationIntroduction to ADTs
Data Structure Introduction to ADTs A particular way of storing and organizing data in a computer so that it can be used efficiently *from Wikipedia A set of data values and associated operations that
More information6.096 Introduction to C++
MIT OpenCourseWare http://ocw.mit.edu 6.096 Introduction to C++ January (IAP) 2009 For information about citing these materials or our Terms of Use, visit: http://ocw.mit.edu/terms. Massachusetts Institute
More informationEE 355 Unit 10. C++ STL - Vectors and Deques. Mark Redekopp
1 EE 355 Unit 10 C++ STL - Vectors and Deques Mark Redekopp 2 Templates We ve built a list to store integers But what if we want a list of double s or char s or other objects We would have to define the
More informationComputer Science 50 Introduction to Computer Science I. Week 0
Computer Science 50 Introduction to Computer Science I Harvard College Week 0 David J. Malan malan@post.harvard.edu 0 Counting in Binary 128s 64s 32s 16s 8s 4s 2s 1s 1 Counting in Binary 128s 64s 32s 16s
More informationTemplate based set of collection classes STL collection types (container types)
STL Collection Types Template based set of collection classes STL collection types (container types) Sequences vector - collection of elements of type T list - doubly linked list, only sequential access
More informationCSCI-1200 Data Structures Spring 2018 Lecture 15 Associative Containers (Maps), Part 2
CSCI-1200 Data Structures Spring 2018 Lecture 15 Associative Containers (Maps), Part 2 Review of Lecture 14 Maps are associations between keys and values. Maps have fast insert, access and remove operations:
More informationcs Java: lecture #6
cs3101-003 Java: lecture #6 news: homework #5 due today little quiz today it s the last class! please return any textbooks you borrowed from me today s topics: interfaces recursion data structures threads
More informationFunction Templates. Consider the following function:
Function Templates Consider the following function: void swap (int& a, int& b) { int tmp = a; a = b; b = tmp; Swapping integers. This function let's you swap the contents of two integer variables. But
More information! An exception is a condition that occurs at execution time and makes normal continuation of the program impossible.
Exceptions! Exceptions are used to signal error or unexpected events that occur while a program is running.! An exception is a condition that occurs at execution time and makes normal continuation of the
More informationCSCI-1200 Data Structures Spring 2016 Lecture 22 Priority Queues, part II (& Functors)
CSCI-1200 Data Structures Spring 2016 Lecture 22 Priority Queues, part II (& Functors) Review from Lecture 21 What s a Priority Queue? Definition of a Binary Heap: A binary tree where: The value at each
More informationComputer Science 62. Bruce/Mawhorter Fall 16. Midterm Examination. October 5, Question Points Score TOTAL 52 SOLUTIONS. Your name (Please print)
Computer Science 62 Bruce/Mawhorter Fall 16 Midterm Examination October 5, 2016 Question Points Score 1 15 2 10 3 10 4 8 5 9 TOTAL 52 SOLUTIONS Your name (Please print) 1. Suppose you are given a singly-linked
More informationCSE 333 Lecture smart pointers
CSE 333 Lecture 14 -- smart pointers Hal Perkins Paul G. Allen School of Computer Science & Engineering University of Washington Administrivia New exercise out today, due Wednesday morning Exam Friday
More informationCSE030 Fall 2012 Final Exam Friday, December 14, PM
CSE030 Fall 2012 Final Exam Friday, December 14, 2012 3-6PM Write your name here and at the top of each page! Name: Select your lab session: Tuesdays Thursdays Paper. If you have any questions or need
More informationCOMP6771 Advanced C++ Programming
1........ COMP6771 Advanced C++ Programming Week 4 Part Three: Function Objects and 2016 www.cse.unsw.edu.au/ cs6771 2........ Converting Class Types to bool Convenient to use a class object as bool to
More informationPENN STATE UNIVERSITY Department of Economics
PENN STATE UNIVERSITY Department of Economics Econ 597D Sec 001 Computational Economics Gallant Sample Midterm Exam Questions Fall 2015 In class on Oct 20, 2015 1. Write a C++ program and a makefile to
More informationChapter 7 Constructors and Other Tools. GEDB030 Computer Programming for Engineers Fall 2017 Euiseong Seo
Chapter 7 Constructors and Other Tools 1 Learning Objectives Constructors Definitions Calling More Tools const parameter modifier Inline functions Static member data Vectors Introduction to vector class
More information