【发布时间】:2014-04-02 10:08:33
【问题描述】:
所以在这个项目中,我必须开发一个二叉表达式树,并使用该树将后缀表达式转换为中缀表达式。大部分看起来都还不错,(除了我尚未完成的一两个功能)。但是我在尝试编译它时遇到了错误。唯一的问题是它并没有真正告诉我问题是什么。这是我尝试编译时遇到的问题:
g++ -o bet.x bet.cpp /usr/lib/gcc/x86_64-redhat-linux6E/4.4.7/../../../../lib64/crt1.o:在函数“_start”中: (.text+0x20): 对 `main' 的未定义引用
collect2: ld 返回 1 个退出状态
make: *** [bet.x] 错误 1
我不知道这意味着什么。但只是以防万一这是我的 3 个文件。从我的 makefile 开始:
bet.x: bet.cpp
g++ -o bet.x bet.cpp
clean:
rm -f *.o *.x core.*
这是包含我的接口的 bet.h(头文件):
#include <string>
using namespace std;
struct BinaryNode
{
string element;
BinaryNode* leftNode;
BinaryNode* rightNode;
};
class BET
{
public:
BET();
BET(const string postfix);
BET(const BET&);
~BET();
bool buildFromPostfix(const string postfix);
const BET& operator= (const BET&);
void printInfixExpression();
void printPostfixExpression();
size_t size();
size_t leaf_nodes();
bool empty();
private:
void printInfixExpression(BinaryNode *n);
void makeEmpty(BinaryNode* &t);
BinaryNode* clone(BinaryNode* t) const;
BinaryNode* headNode;
void printPostfixExpression(BinaryNode *n);
size_t size(BinaryNode *t);
size_t leaf_nodes(BinaryNode *t);
};
向您展示包含我所有实现的整个 bet.cpp 文件可能太过分了。但这里有一些。如果需要更多,请发表评论:
BET::BET()
{
headNode = NULL;
}
BET::BET(const string postfix)
{
headNode = NULL;
buildFromPostfix(postfix);
}
BET::BET(const BET& t)
{
headNode = clone(t.headNode);
}
BET::~BET()
{
makeEmpty(headNode);
}
//2 functions i made myself for high/low precedence
bool isHighPrec(const string& op)
{
return op == "*" || op == "/";
}
bool isLowPrec(const string& op)
{
return op == "+" || op == "-";
}
//returns false for errors, returns true otherwise
bool BET::buildFromPostfix(const string postfix){
stack<BinaryNode*> opTree;
istringstream istr(postfix);
string op;
makeEmpty(headNode);
while(istr >> op)
{
if(isHighPrec(op) || isLowPrec(op))
{
if(opTree.size() < 2)
{
cout << "Error -- invalid postfix expression!\n";
while(opTree.size())
{
makeEmpty(opTree.top());
opTree.pop();
}
return false;
}
else
{
BinaryNode* bn = new BinaryNode();
bn->element = op;
bn->rightNode = opTree.top();
opTree.pop();
bn->leftNode = opTree.top();
opTree.pop();
opTree.push(bn);
}
}
else
{
BinaryNode* bn = new BinaryNode();
bn->element = op;
bn->rightNode = NULL;
bn->leftNode = NULL;
opTree.push(bn);
}
}
if(opTree.size() != 1)
{
cout << "Error -- invalid postfix expression!\n";
while(opTree.size())
{
makeEmpty(opTree.top());
opTree.pop();
}
return false;
}
else
{
headNode = opTree.top();
opTree.pop();
}
return true;
}
【问题讨论】:
-
你说唯一的问题是它并没有真正告诉我问题是什么。但那是无效的。您粘贴了确切的错误:
(.text+0x20): undefined reference to 'main' -
-1 这可以通过简单的网络搜索来轻松解决您的错误消息。
标签: c++ gcc makefile binary-tree