[Solved] CSCI3010 Homework2-Counter

$25

File Name: CSCI3010_Homework2_Counter.zip
File Size: 244.92 KB

SKU: [Solved] CSCI3010 Homework2-Counter Category: Tag:
5/5 - (1 vote)

Objectives:

  • Implement generalized c++ functions/classes
  • Use mini c++ topics that we have covered: const, overloading, unit testing Design and implement unit tests for a templated class

Turn in:

  • hpp, test.cpp, Makefile. You are not required to turn in main.cpp though you are highly encouraged to write a main as you test your Counter object! You do not need to turn in catch.hpp.

Instructions:

Your job is to implement a templated Counter class in C++. A Counter is a specialized type of map (dictionary) that counts the occurrences of hashable objects. You can think of it as a version of a std::map<T, int> with a fancy interface. For our Counter<T>, counts are allowed to be any positive integer value or 0. If you do not have experience working with c++ maps, see the end of this write-up for examples to get started.

If you find writing a main.cpp helpful, you may do so but this is not required.

Your Counter<T> class must provide the following interface:

Function SignaturesNote: it is your job to determine which parameters and methods should be const! Description of behavior
Counter(); Counter(std::vector<T> vals); initialize an empty Counter<T> initialize a Counter<T> appropriately from a vector or array that contains type T
int Count(); int Count(T key); int Count(T min, T max); access the total of all counts so far access the count associated with any object T, even for values of T that have not been counted access the total of all counts for objects T given a certain range (an inclusive minimum T and an exclusive maximum T element)
void Remove(T key) remove all counts of an object T from the Counter
void Increment(T key); void Increment(T key, int n); increment the count of an object T by one increment the count of an object T by n
void Decrement(T key); void Decrement(T key, int n); decrement the count of an object T by one decrement the count of an object T by n
T MostCommon(); std::vector<T> MostCommon(int n); get the most commonly occurring object of type T(the object with the highest count)If the Counter is empty, this method should throw a domain error get the n most commonly occurring objects of type T. If the Counter is empty, this method should return a vector of size 0. *clarification (2/19/2020)*When breaking ties, your Counter should return the first element in the Counter at the given place.Example:if your Counter contains {cat:2, dog: 2, kangaroo: 3, salamander:1}, thenMostCommon() -> returns kangarooMostCommon(2) -> returns kangaroo, cat (in any order)MostCommon(3) -> returns kangaroo, cat, dog(in any order)MostCommon(4) -> returns kangaroo, cat,dog, salamander (in any order)
T LeastCommon(); std::vector<T> LeastCommon(int n); get the least commonly occurring object of type T(the object with the highest count)If the Counter is empty, this method should throw a domain error get the n least commonly occurring objects of type Tget the n most commonly occurring objects of type T. If the Counter is empty, this method should return a vector of size 0. *clarification (2/19/2020)*When breaking ties, your Counter should return the first element in the Counter at the given place.
Example:if your Counter contains {cat:2, dog: 2, kangaroo: 3, salamander:1}, thenLeastCommon() -> returns salamanderLeastCommon(2) -> returns salamander, cat (in any order)LeastCommon(3) -> returns salamander, cat, dog (in any order)MostCommon(4) -> returns salamander, cat,dog, kangaroo (in any order)
std::map<T, double> Normalized(); access normalized weights for all objects of type T seen so far normalized weights means that each value of type T would be associated with the percentage of all items of type T that have been counted that are that value it essentially converts each T, int pair to a T, double pair where the double is the percentage rather than the raw count Say that you have a Counter<std::string> which contains the data: {cat: 8, dog: 4, hamster: 2,eagle: 6} a map of normalized weights wouldbe: {cat: 0.4, dog: 0.2, hamster:0.1, eagle: 0.3}
std::set<T> Keys(); access the set of all keys in the Counter
std::vector<int> Values(); access the collection of all values in the Counter
std::ostream& operator<<(std::ostream& os, const Counter<U> &b); overload the << operator for Counter<T> This should print out the contents of the Counter in the format: {T: count, T: count, T: count, , T:count}

Counter<T> and different types:

Your Counter<T> must work for types T that are new, custom types, such as programmer-defined structs and classes. Each method that you implement must be adequately tested. You do not need to test each method with a Counter<T> of every type that T could be (that would be impossible!), but your different TEST_CASEs should make use of Counters that hold a variety of different types.

See examples in the examples folde r on github for how to write templated classes and functions, as well as the resources linked to in the resources document .

We are happy to clarify any methods/requirements that youd like guidance on, so please, make sure to ask if you have any questions.

As always, your functions should be well documented. Since a main.cpp is not required, include your file comment with your name(s) and instructions for running your program in test.cpp.

Some thoughts on getting started:

Though you may have the inclination to start by writing a non-templated version of your Counter and then converting it, our experience has been that getting a templated class started in c++ can be difficult enough that this might make finding your compiler issues harder. Therefore, we recommend the following steps:

  • Define your Counter<T> class with just a constructor.
  • Make sure you can create a Counter<int> (or some other primitive/built in type).
  • Write unit tests for one of the Counter<T> methods
  • Implement the Counter<T> method
  • Run your tests
  • Go back to step 3 and repeat until complete

Reviews

There are no reviews yet.

Only logged in customers who have purchased this product may leave a review.

Shopping Cart
[Solved] CSCI3010 Homework2-Counter[Solved] CSCI3010 Homework2-Counter
$25