Implementing the Customer Class We've partially defined the Customer class for you in "customer.h" and provided the member variables for you for a Customer name representing the name of the Customer, product_count_ representing the number of products in the Customer's shopping cart, and next_customer representing the next Customer in line, if there is one. You are tasked with defining the constructors, accessor functions, and recursive functions. 1. Create a non-default constructor which accepts 3 parameters: a const reference to a std::string for the customer's name, an int parameter for the product count, and a shared pointer to the next customer in line. 2. Create accessor functions GetName, GetProductCount, and GetNextCustomer, which each should return the corresponding member variable. 3. Define the recursive member function TotalCustomers InLine, which accepts no input, and returns an int representing the total number of customers waiting in line starting at the current customer and including all customers lined up behind them. 4. Define the recursive member function Total Products InLine, which accepts no input, and returns an int representing the total number of products held by customers waiting in line starting at the current customer and including all customers lined up behind them. 5. Define the recursive member function FirstAlphabeticalCustomer InLine, which accepts no input, and returns a std::string which is the name of the customer in line whose name comes first alphabetically, compared to all other customers lined up behind them. Hint: for this question, you can use < or > to strings. In main.cc, you will be asked to invoke each recursive function for a line of customers we've provided for you, starting with Adele at the front of the line. You are tasked with asking the customer at the front of the line how many customers are waiting in total, how many products are waiting to be purchased in the line, and the name of the customer in line that comes first alphabetically. After running main, your output should be: Total customers waiting: 5 Total products to be purchased: 34 First customer name alphabetically: Adele
main.cc file
#include <iostream>
#include <memory>
#include "customer.h"
int main() {
// Creates a line of customers with Adele at the front.
// LinkedList diagram:
// Adele -> Kehlani -> Giveon -> Drake -> Ruel
std::shared_ptr<Customer> ruel =
std::make_shared<Customer>("Ruel", 5, nullptr);
std::shared_ptr<Customer> drake =
std::make_shared<Customer>("Drake", 8, ruel);
std::shared_ptr<Customer> giveon =
std::make_shared<Customer>("Giveon", 2, drake);
std::shared_ptr<Customer> kehlani =
std::make_shared<Customer>("Kehlani", 15, giveon);
std::shared_ptr<Customer> adele =
std::make_shared<Customer>("Adele", 4, kehlani);
std::cout << "Total customers waiting: ";
// =================== YOUR CODE HERE ===================
// 1. Print out the total number of customers waiting
// in line by invoking TotalCustomersInLine.
// ======================================================
std::cout << std::endl;
std::cout << "Total products to be purchased: ";
// =================== YOUR CODE HERE ===================
// 2. Print out the total number of products held by
// customers in line by invoking TotalProductsInLine.
// ======================================================
std::cout << std::endl;
std::cout << "First customer name alphabetically: ";
// =================== YOUR CODE HERE ===================
// 3. Print out the name of the customer in line whose
// name comes first alphabetically by invoking
// FirstAlphabeticalCustomerInLine.
// ======================================================
std::cout << std::endl;
return 0;
}
customer.cc file
#include "customer.h"
// ========================= YOUR CODE HERE =========================
// This implementation file (customer.cc) is where you should implement
// the member functions declared in the header (customer.h), only
// if you didn't implement them inline within customer.h.
//
// Remember to specify the name of the class with :: in this format:
// <return type> MyClassName::MyFunction() {
// ...
// }
// to tell the compiler that each function belongs to the Customer class.
// ===================================================================
customer.h file
#include <memory>
#include <string>
class Customer {
public:
// ====================== YOUR CODE HERE ======================
// 1. Define a constructor using member initializer list syntax
// according to the README.
// 2. Define the accessor functions (i.e. the getter functions)
// `GetName`, `GetProductCount`, and `GetNextCustomer`.
// You do not need to create mutator functions (setters).
// 3. Define the recursive functions specified in the README.
// ============================================================
private:
std::string name_;
int product_count_;
std::shared_ptr<Customer> next_customer_;
};
Sample Output:
data:image/s3,"s3://crabby-images/33fe7/33fe7b4f675d2e01b8f8abd2224ca8a19330021c" alt="Implementing the Customer Class
We've partially defined the Customer class for you in "customer.h" and provided the member variables for you for a Customer : name_
representing the name of the Customer, product_count representing the number of products in the Customer's shopping cart, and
next_customer representing the next Customer in line, if there is one.
You are tasked with defining the constructors, accessor functions, and recursive functions.
1. Create a non-default constructor which accepts 3 parameters: a const reference to a std::string for the customer's name, an int
parameter for the product count, and a shared pointer to the next customer in line.
2. Create accessor functions GetName, GetProduct Count, and GetNextCustomer, which each should return the corresponding member
variable.
3. Define the recursive member function TotalCustomers InLine, which accepts no input, and returns an int representing the total number
of customers waiting in line starting at the current customer and including all customers lined up behind them.
4. Define the recursive member function Total Products InLine, which accepts no input, and returns an int representing the total number
of products held by customers waiting in line starting at the current customer and including all customers lined up behind them.
5. Define the recursive member function FirstAlphabetical Customer InLine, which accepts no input, and returns a std::string which is the
name of the customer in line whose name comes first alphabetically, compared to all other customers lined up behind them. Hint: for this
question, you can use < or > to compare strings.
In main.cc, you will be asked to invoke each recursive function for a line of customers we've provided for you, starting with Adele at the front of
the line.
You are tasked with asking the customer at the front of the line how many customers are waiting in total, how many products are waiting to
be purchased in the line, and the name of the customer in line that comes first alphabetically.
After running main, your output should be:
Total customers waiting: 5
Total products to be purchased: 34
First customer name alphabetically: Adele"
data:image/s3,"s3://crabby-images/a2e30/a2e3056883fb7b1005bdef85194dc24c7dbedcab" alt="Recursion
In this week's lab, you will practice writing recursive functions, and applying recursion to recursive structures.
Overview of Recursive Functions
Recursion is a technique for solving a large computational problem by repeatedly applying the same function(s) to simplify it to successively
smaller problems.
A recursive function has two components: one or more base cases and a recursive call.
Base Case
A base case is a predetermined solution for the simplest version of the problem: if the given problem is a base case, no further computation is
necessary to get the result.
In the case of recursive objects, the "simplest" version of the problem often involves a nullptr check.
Recursive Call
The recursive call is a set of rules that eventually reduces all versions of the problem to one of the base cases when applied repeatedly.
Infinite recursion occurs if there is no base case or the recursive call does not make progress towards the base case(s)."
data:image/s3,"s3://crabby-images/00039/00039eaf710a9765f6db01fc5b9812260bf5cade" alt=""
Trending now
This is a popular solution!
Step by step
Solved in 6 steps with 4 images
data:image/s3,"s3://crabby-images/e0cbe/e0cbe7c1cfa79a285a06530332b315bcf077d9a4" alt="Blurred answer"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/741da/741da0cea27bfc4afcecba2c359e4bfe1cd520b7" alt="Computer Networking: A Top-Down Approach (7th Edi…"
data:image/s3,"s3://crabby-images/aa558/aa558fb07235ab55e06fe3a3bc3f597042097447" alt="Computer Organization and Design MIPS Edition, Fi…"
data:image/s3,"s3://crabby-images/c6dd9/c6dd9e6795240236e2b28c31c737e700c2dd7df3" alt="Network+ Guide to Networks (MindTap Course List)"
data:image/s3,"s3://crabby-images/7daab/7daab2e89d2827b6568a3205a22fcec2da31a567" alt="Concepts of Database Management"
data:image/s3,"s3://crabby-images/cd999/cd999b5a0472541a1bb53dbdb5ada535ed799291" alt="Prelude to Programming"
data:image/s3,"s3://crabby-images/39e23/39e239a275aed535da3161bba64f5416fbed6c8c" alt="Sc Business Data Communications and Networking, T…"