Неразрешенный внешний символ с определенной функцией в c ++

0

Я получил сообщение об ошибке следующим образом:

Неразрешенная ошибка внешнего символа с кандидатом-кандидатом-победителем

Вот мой код:

#include <iostream>
#include <string>
#include <fstream>
#include <iomanip>
using namespace std;

void headerforelection();
void getNamecalculatetotal(ifstream& in, string candidates[], double Votes[], double percentvotes[]);
void getNamecalculatetotal2(ifstream& in, string fname[], double Votes[], double percentvotes[]);
void allvotes(double []);
void Votesrecievedpercentage(ifstream& in, char Candidate[], double Votes[], string fname[], double percentvotes[]);
void Votesrecievedpercentage2(double Votes[], string fname[], double percentvotes[]);
void calculatewinner(string fname[], double Votes[]);
void headerforelection();

int main()
{

    ifstream in = ifstream();
    in.open("Votes.txt");
    ofstream out = ofstream();
    out.open("outputs.txt");

    char winner();
    char Candidate();
    string fname[5];
    double Votes[5];
    double percentvotes[5];
    double total = double();
    headerforelection();
    while (!in.eof())
    {


    getNamecalculatetotal(in, fname, Votes, percentvotes);


    Votesrecievedpercentage2(Votes, fname, percentvotes);
    }
    allvotes(Votes);
    calculatewinner(fname, Votes);

}

void getNamecalculatetotal(ifstream& in, string fname[], double Votes[], double percent[])
{

    double total = double();
        for (int i = 0; i < 5; i++)

        {

            in >> fname[i] >> Votes[i];

            total = total + Votes[i];
        }
        for (int j = 0; j < 5; j++)
        {
            percent[j] = (Votes[j] / total) * 100;
        }
    }
    void headerforelection()
    {
        std::cout << fixed << setfill(' ') << left << setw(10) << "Candidate"
            << right << setw(20) << setprecision(0) << "votes Recieved"
            << right << setw(20) << setprecision(2) << "% of Total Votes" << std::endl;
        std::cout << endl;
    }

    void Votesrecievedpercentage2( double Votes[], string fname[], double percentvotes[])

    {
        for (int b = 0; b < 5; b++)
        {
            std::cout << fixed << setfill(' ') << left << setw(10) << fname[b]
                << right << setw(16) << setprecision(0) << Votes[b]
                << right << setw(16) << setprecision(2) << percentvotes << std::endl;


        }
    }
    void allvotes(double Votes[])

    {
        double total = double();
        for (int i = 0; i < 5; i++)
        {
            total = total + Votes[i];
        }
        std::cout << setfill(' ') << left << setw(22) << "Total" << setprecision(0) << total << std::endl;
    }
    void calculatewinner(string fname[], double Votes[])
    {
        {
            int winner = 0;
            for (int l = 0; l, 5; l++)
            {
                if (Votes[l] > Votes[winner])
                {
                    winner = l;//3

                }
            }
        }
        char winner();
        char Candidate();

        std::cout << std::endl;
        std::cout << Candidate << "Is The Winner" << fname << "." << std::endl;
    }
  • 1
    что вы пытаетесь сделать с этой строкой: char Candidate(); ?
  • 0
    ifstream in = ifstream(); такое назначение совершенно не правильно. Чтобы инициализировать ifstream in("Votes.txt"); , используйте ifstream in("Votes.txt"); и то же самое касается выходного потока.
Теги:
external
symbol

1 ответ

0

Сначала, чтобы ответить на ваш вопрос, измените эти строки

char winner();
char Candidate();

везде в вашем коде (как в main так и в calculatewinner):

char winner;
char Candidate;

Добавляя paranthesis, вы фактически объявляете прототип функции. Поскольку вы никогда не определяете функцию Candidate(void) компоновщик жалуется на недостающую реализацию. Это применимо и к char winner(), но поскольку вы никогда не используете эту "переменную", компоновщик не интересуется этим.

В противном случае ваш код очень сломан. Я уверен, что вы просто изучаете C++, но ваш код совершенно несовместим с соглашениями об именах, а также с некоторыми другими ошибками, которые следует решать перед тем, как делать что-то еще.

Ещё вопросы

Сообщество Overcoder
Наверх
Меню