#include "ece250.h" #include "Sorted_single_list.h" #include "Exception.h" template Sorted_single_list::Sorted_single_list(): list_head( nullptr ), list_tail( nullptr ), list_size( 0 ) { // empty constructor } template Sorted_single_list::Sorted_single_list( Sorted_single_list const &list ): list_head( nullptr ), list_tail( nullptr ), list_size( 0 ) { // enter your implementation here } template Sorted_single_list::~Sorted_single_list() { // enter your implementation here } template int Sorted_single_list::size() const { // enter your implementation here return 0; } template bool Sorted_single_list::empty() const { // enter your implementation here return true; } template Type Sorted_single_list::front() const { // enter your implementation here return Type(); } template Type Sorted_single_list::back() const { // enter your implementation here return Type(); } template Single_node *Sorted_single_list::head() const { // enter your implementation here return nullptr; } template Single_node *Sorted_single_list::tail() const { // enter your implementation here return nullptr; } template int Sorted_single_list::count( Type const &obj ) const { // enter your implementation here return 0; } template void Sorted_single_list::swap( Sorted_single_list &list ) { std::swap( list_head, list.list_head ); std::swap( list_tail, list.list_tail ); std::swap( list_size, list.list_size ); } template Sorted_single_list &Sorted_single_list::operator=( Sorted_single_list const &rhs ) { Sorted_single_list copy( rhs ); swap( copy ); return *this; } template void Sorted_single_list::insert( Type const &obj ) { // enter your implementation here } template Type Sorted_single_list::pop_front() { // enter your implementation here return Type(); } template int Sorted_single_list::erase( Type const &obj ) { // enter your implementation here return 0; } // You can modify this function however you want: it will not be tested template std::ostream &operator<<( std::ostream &out, Sorted_single_list const &list ) { for ( Single_node *ptr = list.head(); ptr != nullptr; ptr = ptr->next() ) { out << "->" << ptr->retrieve(); } out << "->0"; return out; } // Is an error showing up in ece250.h or elsewhere? // Did you forget a closing '}' ?