一个算法上的问题,求指导
需要从文本文件中读取数据,根据读取的数据信息建立相对的派生类对象并用基类数组指针指向它,以下是我的程序及报错,希望有想法的人指导一下,非常感谢我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(10) : error C2512: “NotGate”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(11) : error C2512: “AndGate”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(12) : error C2512: “OrGate”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(13) : error C2512: “OrNotGate”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(14) : error C2512: “XorGate”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(15) : error C2512: “Dtri”: 没有合适的默认构造函数可用
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(34) : error C2064: 项不会计算为接受 2 个参数的函数
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(39) : error C2064: 项不会计算为接受 4 个参数的函数
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(44) : error C2064: 项不会计算为接受 4 个参数的函数
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(49) : error C2064: 项不会计算为接受 4 个参数的函数
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(54) : error C2064: 项不会计算为接受 4 个参数的函数
1>d:\我的文档\visual studio 2008\projects\bishe\bishe\init.cpp(59) : error C2064: 项不会计算为接受 4 个参数的函数
#include "stdafx.h"
#include<iostream>
#include<fstream>
using namespace std;
#include"tools.h"
int Init(Gate *arr[])
{
int GateSort,ioutNo,inNO1,inNO2,inNO3,sum;
int a,b,c,d,e,f;
NotGate notgate[10];
AndGate andgate[10];
OrGate orgate[10];
OrNotGate ornotgate[10];
XorGate xorgate[10];
Dtri dtri[10];
a=b=c=d=e=f=0;
ifstream infile;
infile.open("d:\\data.txt");
if(!infile)
{
cerr<<"打开文件失败!"<<endl;
return 1;
}
for(int i=0;!infile.eof();i++)
{
infile>>GateSort;
infile>>ioutNo;
infile>>inNO1;
infile>>inNO2;
infile>>inNO3;
switch(GateSort)
{
case 1:
notgate[a](inNO1,ioutNo);
arr[i]=¬gate[a];
a++;
break;
case 2:
andgate[b](inNO1,inNO2,inNO3,ioutNo);
arr[i]=&andgate[b];
b++;
break;
case 3:
orgate[c](inNO1,inNO2,inNO3,ioutNo);
arr[i]=&orgate[c];
c++;
break;
case 4:
ornotgate[d](inNO1,inNO2,inNO3,ioutNo);
arr[i]=&ornotgate[d];
d++;
break;
case 5:
xorgate[e](inNO1,inNO2,inNO3,ioutNo);
arr[i]=&xorgate[e];
e++;
break;
case 6:
dtri[f](inNO1,inNO2,inNO3,ioutNo);
arr[i]=&dtri[f];
f++;
break;
}
sum++;
}
infile.close();
return sum;
}
class Gate{
public:
Gate(int,int);
Gate(int,int,int);
Gate(int,int,int,int);
virtual void CcCal2()
{ }
virtual void CcCal3()
{ }
void ChangeNextIn( );
void Push(Queue &qu);
void min2(int &y,int x1,int x2);
void min3(int &y,int &x1,int &x2,int &x3);
void add2(int &y,int &x1,int &x2);
void add3(int &y,int &x1,int &x2,int &x3);
Gate *Pnext1,*Pnext2,*Pnext3;
int InStr1_No,InStr1_CC0,InStr1_CC1;
int InStr2_No,InStr2_CC0,InStr2_CC1;
int InStr3_No,InStr3_CC0,InStr3_CC1;
int OutNo,OutNewCCO,OutNewCC1,OutOldCCO,OutOldCC1;
};
class NotGate:public Gate
{
public:
void CcCal2()
{
OutNewCCO=InStr1_CC1+1;
OutNewCC1=InStr1_CC0+1;
}
};
class AndGate:public Gate
{
public:
void CcCal2()
{
min2(OutNewCCO,InStr1_CC0,InStr2_CC0);
add2(OutNewCC1,InStr1_CC1,InStr2_CC1);
}
void CcCal3()
{
min3(OutNewCCO,InStr1_CC0,InStr2_CC0,InStr3_CC0);
add3(OutNewCC1,InStr1_CC1,InStr2_CC1,InStr3_CC1);
}
};
class OrGate:public Gate
{
public:
void CcCal2()
{
add2(OutNewCCO,InStr1_CC0,InStr2_CC0);
min2(OutNewCC1,InStr1_CC1,InStr2_CC1);
}
void CcCal3()
{
add3(OutNewCCO,InStr1_CC0,InStr2_CC0,InStr3_CC0);
min3(OutNewCC1,InStr1_CC1,InStr2_CC1,InStr3_CC1);
}
};
class OrNotGate:public Gate
{
public:
void CcCal2()
{
min2(OutNewCCO,InStr1_CC0,InStr2_CC0);
add2(OutNewCC1,InStr1_CC1,InStr2_CC1);
}
void CcCal3()
{
min3(OutNewCCO,InStr1_CC0,InStr2_CC0,InStr3_CC0);
add3(OutNewCC1,InStr1_CC1,InStr2_CC1,InStr3_CC1);
}
};
class XorGate:public Gate
{
public:
void CcCal2()
{
min2(OutNewCCO,InStr1_CC0+InStr2_CC0,InStr1_CC1+InStr2_CC1);
min2(OutNewCC1,InStr1_CC0+InStr2_CC1,InStr1_CC1+InStr2_CC0);
}
};
class Dtri:public Gate
{
public:
virtual void CcCal2()
{
add3(OutNewCCO,InStr1_CC0,InStr1_CC1,InStr2_CC0);
add3(OutNewCC1,InStr1_CC0,InStr1_CC1,InStr2_CC1);
if(OutNewCCO<(1*10^7))
OutNewCCO=OutNewCCO-1;
if(OutNewCC1<(1*10^7))
OutNewCC1=OutNewCC1-1;
}
};