我无法弄清楚我搞砸了什么。我想我有一些问题搞砸了,我正在努力解决这个问题。我觉得这是一个包含我的代码的简单数组,但我正在尝试对此文件进行排序,我收到此错误。
1>ClCompile:
1> Main.cpp
1>Main.obj : error LNK2019: unresolved external symbol "void __cdecl sort(struct salesTran * const,int)" (?sort@@YAXQAUsalesTran@@H@Z) referenced in function _main
1>C:\Users\BranN3W\Documents\Visual Studio 2010\Projects\3-1Notes\Debug\3-1Notes.exe : fatal error LNK1120: 1 unresolved externals
1>
1>Build FAILED.
1>
1>Time Elapsed 00:00:01.96
==========构建:0成功,1失败,0最新,0跳过==========
#include <iostream>
#include <string>
#include <fstream>
using namespace std;
struct salesTran {
string name;
double quantity,price;
};
void swap(salesTran A[], int i, int j);
void sort(salesTran A[], int size);
ostream& operator << (ostream& os, salesTran A)
{os << A.name << "\t" << A.quantity << "\t" << A.price;
return os;}
istream& operator >> (istream& is, salesTran& A)
{is >> A.name >> A.quantity >> A.price;
return is;}
int main()
{
salesTran data[250];
ifstream fin;
fin.open("sales.txt");
ofstream fout;
fout.open("results.txt");
int index = 0;
fin >> data[index];
while(!fin.eof())
{
index++;
fin >> data[index];
}
sort(data, index);
for(int j=0; j < index; j++)
{
cout << data[j] << endl;
}
return 0;
}
void swap(int data[], int i, int j)
{
int temp;
temp = data[i];
data[i] = data[j];
data[j] = temp;
return;
}
void sort(int data[], int size)
{
for(int p=1; p<size; p++)
{
for(int c=0; c<size-p; c++)
{
if(data[c]>data[c+1]) swap(data,c,c+1);
}
}
return;
}
答案 0 :(得分:1)
这是因为您的sort
函数采用了int data[]
参数,但是当您使用它时,您将传递它salestran data[]
。您有void sort(salesTran A[], int size);
的原型,但它永远不会被定义。您还需要更改排序功能以正确使用结构。
答案 1 :(得分:0)
首先,您将声明排序和交换函数,如下所示:
void swap(salesTran A[], int i, int j);
void sort(salesTran A[], int size);
之后,您将函数定义为采用整数数组而不是salesTran
结构数组。
void swap(int data[], int i, int j);
void sort(int data[], int size);
您的声明和定义必须与您要链接的代码相匹配。