一个简单的C++数据结构问题

前面两个类要仔细看的,看最底下就行。然后问题是:底下这个Dijkstra这个函数要怎么才能调用?。我要在主函数怎么新建一个类?我主函数这样写,它提示调用错误。Graphm... 前面两个类要仔细看的,看最底下就行。然后问题是: 底下这个Dijkstra这个函数要怎么才能调用?。我要在主函数怎么新建一个类?
我主函数这样写,它提示调用错误。
Graphm M(5);
Dijkstra(M,D,0);

类函数:
class Graph {
private:
void operator = (const Graph&) {}
Graph( const Graph&) {}

public:
Graph() {}
virtual ~Graph() {}
virtual void Init(int n)=0;
virtual int n()=0;
virtual int e()=0;
virtual int first(int v)=0;
virtual int next(int v, int w)=0;
virtual void setEdge(int v1, int v2, int wght)=0;
virtual void delEdge(int v1, int v2)=0;
virtual bool isEdge(int i, int j)=0;
virtual int weight(int v1, int v2)=0;
virtual int getMark(int v)=0;
virtual void setMark(int v, int val)=0;
};

class Graphm: public Graph {
private:
int numVertex, numEdge;
int **matrix;
int *mark;
public:
Graphm(int numVert)
{ Init(numVert); }

~Graphm() {
delete[] mark;
for (int i=0;i<numVertex;i++)
delete [] matrix[i];
delete [] matrix;
}

void Init(int n) {
int i;
numVertex = n;
numEdge = 0;
mark = new int[n];
for (i=0; i<numVertex; i++)
mark[i] = -10;
matrix = (int**) new int * [numVertex];
for (i=0; i<numVertex; i++)
matrix[i] = new int[numVertex];
for (i=0; i<numVertex; i++)
for (int j=0; j<numVertex; j++)
matrix[i][j]=0;
}

int n() { return numVertex; }
int e() { return numEdge; }

int first(int v) {
for(int i=0;i<numVertex;i++)
if(matrix[v][i] !=0) return i;
return numVertex;
}

int next(int v, int w) {
for(int i=w+1;i<numVertex;i++)
if(matrix[v][i] !=0) return i;
return numVertex;
}
void setEdge(int v1, int v2, int wt) {
// Assert(wt>0, "illegal weight value");
if(matrix[v1][v2] ==0) numEdge++;
matrix[v1][v2] = wt;
}

void delEdge(int v1, int v2) {
if(matrix[v1][v2] !=0) numEdge--;
matrix[v1][v2] = 0;
}

bool isEdge(int v1, int v2)
{ return matrix[v1][v2] != 0; }

int weight(int v1, int v2) { return matrix[v1][v2]; }
int getMark(int v) {return mark[v]; }
void setMark(int v, int val) { mark[v] = val; }
};
展开
 我来答
porker2008
2014-05-29 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
Dijkstra(&M,D,0);

因为Dijstra函数第一个参数是指针,所以需要M的地址

更多追问追答
追问
嗯,我这样做编译通过了,但是我想问一下,我Graphm M(5);是不是正确的?,这样是新建了一个M的图的领接矩阵么?
追答
Graphm M(5); 是创建了一个5个节点的邻接矩阵
恋雪19861220
2014-05-29 · 超过27用户采纳过TA的回答
知道答主
回答量:73
采纳率:0%
帮助的人:56.6万
展开全部
Dijkstra你的这个函数的第一个参数类型是Graph,而你的调用是Graphm
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Jack5s
2014-05-29 · TA获得超过349个赞
知道小有建树答主
回答量:306
采纳率:0%
帮助的人:235万
展开全部
Dijkstra这个函数属于Graphm类,要用类的实例M.Dijkstra调用
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(1)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式