Darrenfhd
Darrenfhd

Reputation: 21

I'm getting an error saying that only virtual functions can be marked as override

I keep getting this error that only virtual functions can be marked as override but the functions in question "norm()" and "string to_string()" are virtual. what could be causing this?

In my main function I am also getting the error no matching member function to call push back, did I make a mistake along the way somewhere and I am just not seeing it?

#include <iostream>
#include <cmath>
#include <vector>
using namespace std;

class Group
{
public:
   virtual string to_string() = 0;
   virtual int norm() = 0;
};

class Real 
{
   // add your code here
protected:
   int number;

public:
   Real(int num)
   {
      number = num;
   }
   int norm() override
   {
      return number;
   }

   string to_string() override 
   {
      return number;
   }

   int getNumber() const
   {
      return number;
   }

   void setNumber(int number)
   {
      Real::number = number;
   }
};

class Complex : public Real 
{
   // add your code here
protected:
   int imaginary;
public:
   Complex(int realNum, int imag) : Real(realNum)
   {}
   int norm() override
   {
      return sqrt(number * number + imaginary * imaginary) + 'i';
   }
   string to_string() override
   {
      return ::to_string(number) + '+' + ::to_string(imaginary) + 'i';
   }
};

class Trinomial : public Complex
{
   // add your code here
protected:
   int third;
public:
   Trinomial(int p1, int p2, int p3) : Complex(p1, p2) {
      third = p3;
   }
   int norm() override {
      return sqrt(number * number + imaginary * imaginary + third * third);
   }
   string to_string() override {
      return ::to_string(number) + "x^2+" + ::to_string(imaginary) + "x+" + ::to_string(third);
   }
};

class Vector : public Group
{
   // add your code here
protected:
   vector<int> v;
public:
   Vector(int num1, int num2, int num3)
   {
      v.push_back(num1);
      v.push_back(num2);
      v.push_back(num3);
   }
   int norm() override
   {
      int squared_sum = 0;
      for (int i = 0; i < v.size(); i++) {
         squared_sum += v[i] * v[i];
      }
      return sqrt(squared_sum);
   }
   string to_string() override
   {
      string str = "[";
      for (int i = 0; i < v.size() - 1; i++) {
         str += ::to_string(v[i]) + " ";
      }
      str += ::to_string(v[v.size() - 1]) + "]";
      return str;
   }
};


int main()
{
   vector<Group*> elements;

   elements.push_back(new Real{ 3 });
   elements.push_back(new Complex{ 3,4 });
   elements.push_back(new Trinomial{ 1,2,3 });
   elements.push_back(new Vector{ 1,2,3 });

   for (auto e : elements) 
   {
      cout << "|" << e->to_string() << "| = " << e->norm() << endl;
   }

   for (auto e : elements)
      delete e;

   return 0;
}

Upvotes: 2

Views: 1116

Answers (2)

JeJo
JeJo

Reputation: 32722

A couple of issues here:

  • The class Real must have inherited from Group so that you could override the functions. That is the reason for the error message.
  • Secondly the Real::to_string must return a string at the end. You might convert the integer using std::to_string.
  • Last but not least the Group must have a virtual destructor for defined behaviour. Read more here: When to use virtual destructors?

In short, you need

#include <string>

class Group
{
public:
   // other code
   virtual ~Group() = default;
};

class Real: public Group  // --> inherited from base
 {
   // other codes
public:
   std::string to_string() override {
      return std::to_string(number);
   }

};

As a side, please do not practice with using namespace std;

Upvotes: 2

Creepsy
Creepsy

Reputation: 321

your class real has no parent. so you cant override to_string()

Upvotes: 0

Related Questions