数据结构中图的建立及输出的课程设计

作者&投稿:廖傅 (若有异议请与网页底部的电邮联系)
数据结构课程设计 图的建立及输出 1)建立图的存储结构(有向图) 2)~

邻接表还是逆邻接表?如果是逆邻接表,每个顶点出发邻接表的链表中的结点个数就是入度如果是邻接表过程如下:有一个辅助数组,大小就是顶点数量,所有元素初值都为0从头到尾遍历每个顶点出发的邻接表的结点,只要当前结点的数据是几(也就是第几个结点被有向弧进入了),这个下标的辅助数组元素加1,等所有的邻接表的小链表遍历完了,这个辅助数组中各个下标的数字就是该顶点的入度

//图的遍历算法程序

//图的遍历是指按某条搜索路径访问图中每个结点,使得每个结点均被访问一次,而且仅被访问一次。图的遍历有深度遍历算法和广度遍历算法,程序如下:
#include
//#include
#define INFINITY 32767
#define MAX_VEX 20 //最大顶点个数
#define QUEUE_SIZE (MAX_VEX+1) //队列长度
using namespace std;
bool *visited; //访问标志数组
//图的邻接矩阵存储结构
typedef struct{
char *vexs; //顶点向量
int arcs[MAX_VEX][MAX_VEX]; //邻接矩阵
int vexnum,arcnum; //图的当前顶点数和弧数
}Graph;
//队列类
class Queue{
public:
void InitQueue(){
base=(int *)malloc(QUEUE_SIZE*sizeof(int));
front=rear=0;
}
void EnQueue(int e){
base[rear]=e;
rear=(rear+1)%QUEUE_SIZE;
}
void DeQueue(int &e){
e=base[front];
front=(front+1)%QUEUE_SIZE;
}
public:
int *base;
int front;
int rear;
};
//图G中查找元素c的位置
int Locate(Graph G,char c){
for(int i=0;i<G.vexnum;i++)
if(G.vexs[i]==c) return i;
return -1;
}
//创建无向网
void CreateUDN(Graph &G){
int i,j,w,s1,s2;
char a,b,temp;
printf("输入顶点数和弧数:");
scanf("%d%d",&G.vexnum,&G.arcnum);
temp=getchar(); //接收回车
G.vexs=(char *)malloc(G.vexnum*sizeof(char)); //分配顶点数目
printf("输入%d个顶点.
",G.vexnum);
for(i=0;i<G.vexnum;i++){ //初始化顶点
printf("输入顶点%d:",i);
scanf("%c",&G.vexs[i]);
temp=getchar(); //接收回车
}
for(i=0;i<G.vexnum;i++) //初始化邻接矩阵
for(j=0;j<G.vexnum;j++)
G.arcs[i][j]=INFINITY;
printf("输入%d条弧.
",G.arcnum);
for(i=0;i<G.arcnum;i++){ //初始化弧
printf("输入弧%d:",i);
scanf("%c %c %d",&a,&b,&w); //输入一条边依附的顶点和权值
temp=getchar(); //接收回车
s1=Locate(G,a);
s2=Locate(G,b);
G.arcs[s1][s2]=G.arcs[s2][s1]=w;
}
}
//图G中顶点k的第一个邻接顶点
int FirstVex(Graph G,int k){
if(k>=0 && k<G.vexnum){ //k合理
for(int i=0;i<G.vexnum;i++)
if(G.arcs[k][i]!=INFINITY) return i;
}
return -1;
}
//图G中顶点i的第j个邻接顶点的下一个邻接顶点
int NextVex(Graph G,int i,int j){
if(i>=0 && i=0 && j<G.vexnum){ //i,j合理
for(int k=j+1;k<G.vexnum;k++)
if(G.arcs[i][k]!=INFINITY) return k;
}
return -1;
}
//深度优先遍历
void DFS(Graph G,int k){
int i;
if(k==-1){ //第一次执行DFS时,k为-1
for(i=0;i<G.vexnum;i++)
if(!visited[i]) DFS(G,i); //对尚未访问的顶点调用DFS
}
else{
visited[k]=true;
printf("%c ",G.vexs[k]); //访问第k个顶点
for(i=FirstVex(G,k);i>=0;i=NextVex(G,k,i))
if(!visited[i]) DFS(G,i); //对k的尚未访问的邻接顶点i递归调用DFS
}
}
//广度优先遍历
void BFS(Graph G){
int k;
Queue Q; //辅助队列Q
Q.InitQueue();
for(int i=0;i<G.vexnum;i++)
if(!visited[i]){ //i尚未访问
visited[i]=true;
printf("%c ",G.vexs[i]);
Q.EnQueue(i); //i入列
while(Q.front!=Q.rear){
Q.DeQueue(k); //队头元素出列并置为k
for(int w=FirstVex(G,k);w>=0;w=NextVex(G,k,w))
if(!visited[w]){ //w为k的尚未访问的邻接顶点
visited[w]=true;
printf("%c ",G.vexs[w]);
Q.EnQueue(w);
}
}
}
}

//主函数
void main(){
int i;
Graph G;
CreateUDN(G);
visited=(bool *)malloc(G.vexnum*sizeof(bool));
printf("
广度优先遍历: ");
for(i=0;i<G.vexnum;i++)
visited[i]=false;
DFS(G,-1);
printf("
深度优先遍历: ");
for(i=0;i<G.vexnum;i++)
visited[i]=false;
BFS(G);
printf("
程序结束.
");
}
输出结果为(红色为键盘输入的数据,权值都置为1):
输入顶点数和弧数:8 9
输入8个顶点.
输入顶点0:a
输入顶点1:b
输入顶点2:c
输入顶点3:d
输入顶点4:e
输入顶点5:f
输入顶点6:g
输入顶点7:h
输入9条弧.
输入弧0:a b 1
输入弧1:b d 1
输入弧2:b e 1
输入弧3:d h 1
输入弧4:e h 1
输入弧5:a c 1
输入弧6:c f 1
输入弧7:c g 1
输入弧8:f g 1
广度优先遍历: a b d h e c f g
深度优先遍历: a b c d e f g h
程序结束.

1、一元稀疏多项式相加

详细设计

4.1 程序头的设计:
#include<stdio.h>
#include<malloc.h>
typedef struct pnode
{int coef;/*系数 */
int exp;/*指数 */
struct pnode *next;/*下一个指针*/
}pnode;

4.2 用头插法生成一个多项式,系数和指数输入0时退出输入
pnode * creat()
{int m,n; pnode *head,*rear,*s;
/*head为头指针,rear和s为临时指针*/

head=(pnode *)malloc(sizeof(pnode));
rear=head;
/*指向头*/
printf("input coef:");/*输入系数*/
scanf("%d",&n);
printf("input exp:");/*输入指数*/
scanf("%d",&m);
while(n!=0)/*输入0就退出*/
{s=(pnode *)malloc(sizeof(pnode));
s->coef=n;
s->exp=m;
s->next=NULL;
rear->next=s;/*头插法*/
rear=s;
printf("input coef:");/*输入系数*/
scanf("%d",&n);
printf("input exp:");/*输入指数*/
scanf("%d",&m);
}
head=head->next;/*第一个头没有用到*/
return head;
}
4.3 显示一个多项式
void display(pnode *head)
{pnode *p;int one_time=1; p=head;
while(p!=NULL)/*不为空的话*/
{
if(one_time==1)
{if(p->exp==0)/*如果指数为0的话,直接输出系数*/
printf("%d",p->coef); /*如果系数是正的话前面就要加+号*/
else if(p->coef==1||p->coef==-1)
printf("x^%d",p->exp);/*如果系数是1的话就直接输出+x*/
/*如果系数是-1的话就直接输出-x号*/
else if(p->coef>0)/*如果系数是大于0的话就输出+系数x^指数的形式*/
printf("%dx^%d",p->coef,p->exp);
else if(p->coef<0)/*如果系数是小于0的话就输出系数x^指数的形式*/
printf("%dx^%d",p->coef,p->exp);
one_time=0;
}
else{
if(p->exp==0)/*如果指数为0的话,直接输出系数*/
{if(p->coef>0)
printf("+%d",p->coef); /*如果系数是正的话前面就要加+号*/
}
else if(p->coef==1)
printf("+x^%d",p->exp);
else if(p->coef==-1)
printf("x^%d",p->exp);/*如果系数是1的话就直接输出+x号*/
else if(p->coef>0)/*如果系数是大于0的话就输出+系数x^指数的形式*/
printf("+%dx^%d",p->coef,p->exp);
else if(p->coef<0)/*如果系数是小于0的话就输出系数x^指数的形式*/
printf("%dx^%d",p->coef,p->exp);
}
p=p->next;/*指向下一个指针*/
}
printf("\n");

4.4 两个多项式的加法运算
pnode * add(pnode *heada,pnode *headb)
{pnode *headc,*p,*q,*s,*r;
/*headc为头指针,r,s为临时指针,p指向第1个多项式并向右移动,q指向第2个多项式并并向右移动*/
int x;
/*x为系数的求和*/
p=heada;
/*指向第一个多项式的头*/
q=headb;
/*指向第二个多项式的头*/
headc=(pnode *)malloc(sizeof(pnode));
r=headc;
/*开辟空间*/
while(p!=NULL&&q!=NULL)
/*2个多项式的某一项都不为空时*/
{if(p->exp==q->exp)/*指数相等的话*/
{x=p->coef+q->coef;/*系数就应该相加*/
if(x!=0)/*相加的和不为0的话*/
{s=(pnode *)malloc(sizeof(pnode));/*用头插法建立一个新的节点*/
s->coef=x;
s->exp=p->exp;
r->next=s;
r=s;
}
q=q->next;p=p->next;
/*2个多项式都向右移*/
}
else if(p->exp<q->exp)/*p的系数小于q的系数的话,就应该复制q接点到多项式中*/
{s=(pnode *)malloc(sizeof(pnode));
s->coef=q->coef;
s->exp=q->exp;
r->next=s;
r=s;
q=q->next;/*q向右移动*/
}
else/*p的系数大于q的系数的话,就应该复制p接点到多项式中*/
{s=(pnode *)malloc(sizeof(pnode));
s->coef=p->coef;
s->exp=p->exp;
r->next=s;
r=s;
p=p->next;/*p向右移动*/
}
}
当第2个多项式空,第1个数不为空时,将第一个数剩下的全用新节点产生
while(p!=NULL)
{s=(pnode *)malloc(sizeof(pnode));
s->coef=p->coef;
s->exp=p->exp;
r->next=s;
r=s;
p=p->next;
}
当第1个多项式空,第1个数不为空时,将第2个数剩下的全用新节点产生
while(q!=NULL)
{s=(pnode *)malloc(sizeof(pnode));
s->coef=q->coef;
s->exp=q->exp;
r->next=s;
r=s;
q=q->next;
}
r->next=NULL;
/*最后指向空*/
headc=headc->next;/*第一个头没有用到*/
return headc;/*返回头接点*/

4.5 两个多项式的减法运算,和加法类似,不同的地方已经注释
pnode * sub(pnode *heada,pnode *headb)
{pnode *headc,*p,*q,*s,*r;
int x;
p=heada;q=headb;
headc=(pnode *)malloc(sizeof(pnode));
r=headc;
while(p!=NULL&&q!=NULL)
{if(p->exp==q->exp)
{x=p->coef-q->coef;/*系数相减*/
if(x!=0)
{s=(pnode *)malloc(sizeof(pnode));
s->coef=x;
s->exp=p->exp;
r->next=s;
r=s;
}
q=q->next;p=p->next;
}
else if(p->exp<q->exp)/*p的系数小于q的系数的话*/
{s=(pnode *)malloc(sizeof(pnode));
s->coef=-q->coef;/*建立的接点的系数为原来的相反数*/
s->exp=q->exp;
r->next=s;
r=s;
q=q->next;
}
else
{s=(pnode *)malloc(sizeof(pnode));
s->coef=p->coef;
s->exp=p->exp;
r->next=s;
r=s;
p=p->next;
}
}
while(p!=NULL)
{s=(pnode *)malloc(sizeof(pnode));
s->coef=p->coef;
s->exp=p->exp;
r->next=s;
r=s;
p=p->next;
}
while(q!=NULL)
{s=(pnode *)malloc(sizeof(pnode));
s->coef=-q->coef;/*建立的接点的系数为原来的相反数*/
s->exp=q->exp;
r->next=s;
r=s;
q=q->next;
}
r->next=NULL;
headc=headc->next;
return headc;

4.6 界面设计:
printf("\n ****************************************\n");
printf("\n ************** 03 Computer *************\n");
printf("\n ******** Class:two **** Num:34 *********\n");
printf("\n *********** Name: xie pan **********\n");
printf("\n ****************************************\n");
printf("\n --------------1: add -------------\n");
printf("\n --------------2: sub -------------\n");
printf("\n --------------3: exit ------------\n");
printf("\n ****************************************\n");

4.7 连接程序:
case 1:add_main();break;/*加法*/
case 2:sub_main();break;/*减法*/
case 3:break;/*退出*/

#include <iostream>
#include <malloc.h>
using namespace std;
#define int_max 10000
#define inf 9999
#define max 20

//…………………………………………邻接矩阵定义……………………
typedef struct ArcCell
{
int adj;
char *info;
}ArcCell,AdjMatrix[20][20];

typedef struct
{
char vexs[20];
AdjMatrix arcs;
int vexnum,arcnum;
}MGraph_L;

//^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
int localvex(MGraph_L G,char v)//返回V的位置
{
int i=0;
while(G.vexs[i]!=v)
{
++i;
}
return i;
}

int creatMGraph_L(MGraph_L &G)//创建图用邻接矩阵表示
{
char v1,v2;
int i,j,w;
printf("\n§%c %c %c 创建无向图 %c %c %c§\n",6,6,6,6,6,6);
printf("请输入图G顶点和弧的个数(4 6)不包括'()':\n");
//cout<<"…………创建无向图…………"<<endl<<"请输入图G顶点和弧的个数:(4 6)不包括“()”"<<endl;
cin>>G.vexnum>>G.arcnum;
for(i=0;i!=G.vexnum;++i)
{
cout<<"输入顶点"<<i+1<<":"<<endl;
cin>>G.vexs[i];
}
for(i=0;i!=G.vexnum;++i)
for(j=0;j!=G.vexnum;++j)
{
G.arcs[i][j].adj=int_max;
G.arcs[i][j].info=NULL;
}
for(int k=0;k!=G.arcnum;++k)
{
cout<<"输入一条边依附的顶点和权:(a b 3)不包括“()”"<<endl;
cin>>v1>>v2>>w;//输入一条边依附的两点及权值
i=localvex(G,v1);//确定顶点V1和V2在图中的位置
j=localvex(G,v2);
G.arcs[i][j].adj=w;
G.arcs[j][i].adj=w;
}
cout<<"图G邻接矩阵创建成功!"<<endl;
return G.vexnum;
}

void ljjzprint(MGraph_L G)
{
int i,j;
for(i=0;i!=G.vexnum;++i)
{
for(j=0;j!=G.vexnum;++j)
cout<<G.arcs[i][j].adj<<" ";
cout<<endl;
}
}
int visited[max];//访问标记
int we;

typedef struct arcnode//弧结点
{
int adjvex;//该弧指向的顶点的位置
struct arcnode *nextarc;//弧尾相同的下一条弧
char *info;//该弧信息
}arcnode;

typedef struct vnode//邻接链表顶点头接点
{
char data;//结点信息
arcnode *firstarc;//指向第一条依附该结点的弧的指针
}vnode,adjlist;

typedef struct//图的定义
{
adjlist vertices[max];
int vexnum,arcnum;
int kind;
}algraph;

//…………………………………………队列定义……………………
typedef struct qnode
{
int data;
struct qnode *next;

}qnode,*queueptr;

typedef struct
{
queueptr front;
queueptr rear;

}linkqueue;

//………………………………………………………………………
typedef struct acr
{
int pre;//弧的一结点
int bak;//弧另一结点
int weight;//弧的权
}edg;

int creatadj(algraph &gra,MGraph_L G)//用邻接表存储图
{

int i=0,j=0;
arcnode *arc,*tem,*p;
for(i=0;i!=G.vexnum;++i)
{
gra.vertices[i].data=G.vexs[i];
gra.vertices[i].firstarc=NULL;
}
for(i=0;i!=G.vexnum;++i)
{
for(j=0;j!=G.vexnum;++j)
{
if(gra.vertices[i].firstarc==NULL)
{
if(G.arcs[i][j].adj!=int_max&&j!=G.vexnum)
{
arc=(arcnode *)malloc(sizeof(arcnode));
arc->adjvex=j;
gra.vertices[i].firstarc=arc;
arc->nextarc=NULL;
p=arc;
++j;
while(G.arcs[i][j].adj!=int_max&&j!=G.vexnum)
{
tem=(arcnode *)malloc(sizeof(arcnode));
tem->adjvex=j;
gra.vertices[i].firstarc=tem;
tem->nextarc=arc;
arc=tem;
++j;
}
--j;
}
}
else
{
if(G.arcs[i][j].adj!=int_max&&j!=G.vexnum)
{
arc=(arcnode *)malloc(sizeof(arcnode));
arc->adjvex=j;
p->nextarc=arc;
arc->nextarc=NULL;
p=arc;
}
}
}
}
gra.vexnum=G.vexnum;
gra.arcnum=G.arcnum;
cout<<"图G邻接表创建成功!"<<endl;
return 1;
}

void adjprint(algraph gra)
{
int i;
for(i=0;i!=gra.vexnum;++i)
{
arcnode *p;
cout<<i<<" ";
p=gra.vertices[i].firstarc;
while(p!=NULL)
{
cout<<p->adjvex;
p=p->nextarc;
}
cout<<endl;
}
}

int firstadjvex(algraph gra,vnode v)//返回依附顶点V的第一个点
//即以V为尾的第一个结点
{
if(v.firstarc!=NULL)
return v.firstarc->adjvex;

}

int nextadjvex(algraph gra,vnode v,int w)//返回依附顶点V的相对于W的下一个顶点
{
arcnode *p;
p=v.firstarc;
while(p!=NULL&&p->adjvex!=w)
{
p=p->nextarc;
}
if(p->adjvex==w&&p->nextarc!=NULL)
{
p=p->nextarc;
return p->adjvex;
}
if(p->adjvex==w&&p->nextarc==NULL)
return -10;
}

int initqueue(linkqueue &q)//初始化队列
{
q.rear=(queueptr)malloc(sizeof(qnode));
q.front=q.rear;
if(!q.front)
return 0;
q.front->next=NULL;
return 1;
}

int enqueue(linkqueue &q,int e)//入队
{
queueptr p;
p=(queueptr)malloc(sizeof(qnode));
if(!p)
return 0;
p->data=e;
p->next=NULL;
q.rear->next=p;
q.rear=p;
return 1;
}

int dequeue(linkqueue &q,int &e)//出队
{
queueptr p;
if(q.front==q.rear)
return 0;
p=q.front->next;
e=p->data;
q.front->next=p->next;
if(q.rear==p)
q.rear=q.front;
free(p);
return 1;
}

int queueempty(linkqueue q)//判断队为空
{
if(q.front==q.rear)
return 1;
return 0;
}

void bfstra(algraph gra)//广度优先遍历
{
int i,e;
linkqueue q;
for(i=0;i!=gra.vexnum;++i)
visited[i]=0;
initqueue(q);
for(i=0;i!=gra.vexnum;++i)

if(!visited[i])
{ visited[i]=1;
cout<<gra.vertices[i].data;
enqueue(q,i);
while(!queueempty(q))
{
dequeue(q,e);
// cout<<" "<<e<<" ";
for(we=firstadjvex(gra,gra.vertices[e]);we>=0;we=nextadjvex(gra,gra.vertices[e],we))
{
if(!visited[we])
{
visited[we]=1;
cout<<gra.vertices[we].data;
enqueue(q,we);
}
}
}
}
}

int dfs(algraph gra,int i);//声明DFS

int dfstra(algraph gra)
{
int i,j;
for(i=0;i!=gra.vexnum;++i)
{
visited[i]=0;
}
for(j=0;j!=gra.vexnum;++j)
{
if(visited[j]==0)
dfs(gra,j);
}
return 0;
}

int dfs(algraph gra,int i)
{
visited[i]=1;
int we1;
// cout<<i<<visited[i]<<endl;
cout<<gra.vertices[i].data;
// cout<<endl;
for(we=firstadjvex(gra,gra.vertices[i]);we>=0;we=nextadjvex(gra,gra.vertices[i],we))
{
// cout<<we<<visited[we]<<endl;
we1=we;
// cout<<nextadjvex(gra,gra.vertices[i],we)<<endl;
if(visited[we]==0)
// cout<<
dfs(gra,we);//<<endl;
// cout<<i<<we1<<endl;
we=we1;
// cout<<nextadjvex(gra,gra.vertices[i],we)<<endl;
}
return 12;
}

int bfstra_fen(algraph gra)//求连通分量
{
int i,j;
for(i=0;i!=gra.vexnum;++i)
{
visited[i]=0;
}
for(j=0;j!=gra.vexnum;++j)
{
if(visited[j]==0)
{
dfs(gra,j);
cout<<endl;
}
}
return 0;
}

typedef struct
{
int adjvex;
int lowcost;
}closedge;

int prim(int g[][max],int n) //最小生成树PRIM算法
{
int lowcost[max],prevex[max]; //LOWCOST[]存储当前集合U分别到剩余结点的最短路径
//prevex[]存储最短路径在U中的结点
int i,j,k,min;
for(i=2;i<=n;i++) //n个顶点,n-1条边
{
lowcost[i]=g[1][i]; //初始化
prevex[i]=1; //顶点未加入到最小生成树中
}
lowcost[1]=0; //标志顶点1加入U集合
for(i=2;i<=n;i++) //形成n-1条边的生成树
{
min=inf;
k=0;
for(j=2;j<=n;j++) //寻找满足边的一个顶点在U,另一个顶点在V的最小边
if((lowcost[j]<min)&&(lowcost[j]!=0))
{
min=lowcost[j];
k=j;
}
printf("(%d,%d)%d\t",prevex[k]-1,k-1,min);
lowcost[k]=0; //顶点k加入U
for(j=2;j<=n;j++) //修改由顶点k到其他顶点边的权值
if(g[k][j]<lowcost[j])
{
lowcost[j]=g[k][j];
prevex[j]=k;
}
printf("\n");
}
return 0;
}

int acrvisited[100];//kruscal弧标记数组

int find(int acrvisited[],int f)
{
while(acrvisited[f]>0)
f=acrvisited[f];
return f;
}

void kruscal_arc(MGraph_L G,algraph gra)
{

edg edgs[20];
int i,j,k=0;
for(i=0;i!=G.vexnum;++i)
for(j=i;j!=G.vexnum;++j)
{
if(G.arcs[i][j].adj!=10000)
{
edgs[k].pre=i;
edgs[k].bak=j;
edgs[k].weight=G.arcs[i][j].adj;
++k;
}
}
int x,y,m,n;
int buf,edf;
for(i=0;i!=gra.arcnum;++i)
acrvisited[i]=0;
for(j=0;j!=G.arcnum;++j)
{
m=10000;
for(i=0;i!=G.arcnum;++i)
{
if(edgs[i].weight<m)
{
m=edgs[i].weight;
x=edgs[i].pre;
y=edgs[i].bak;
n=i;
}

}
// cout<<x<<y<<m;
// cout<<endl;
buf=find(acrvisited,x);
edf=find(acrvisited,y);
// cout<<buf<<" "<<edf<<endl;
edgs[n].weight=10000;
if(buf!=edf)
{
acrvisited[buf]=edf;

cout<<"("<<x<<","<<y<<")"<<m;
cout<<endl;
}
}
}

void main()
{
algraph gra;
MGraph_L G;
int i,d,g[20][20];
char a='a';
d=creatMGraph_L(G);
creatadj(gra,G);
vnode v;
printf("\n\n");
printf("\t§%c %c %c %c 图的遍历和生成树求解实现 %c %c %c %c§\n",6,6,6,6,6,6,6,6,6,6);
printf("\t | %c1.显示该图的邻接矩阵 |\n",3);
printf("\t | %c2.显示该图的邻接表 |\n",3);
printf("\t | %c3.深度优先遍历 |\n",3);
printf("\t | %c4.广度优先遍历 |\n",3);
printf("\t | %c5.最小生成树PRIM算法 |\n",3);
printf("\t | %c6.最小生成树KRUSCAL算法 |\n",3);
printf("\t | %c0.该图的连通分量 |\n",3);
printf("\t | %c0.退出 |\n",3);
printf("\t§ (+﹏+) § (+﹏+) § (+﹏+) § \n");
int s;
char y='y';
while(y='y')
{
printf("请选择菜单:");
cin>>s;
switch(s)
{
case 1:
printf("邻接矩阵显示如下:");
ljjzprint(G);
break;
case 2:
printf("邻接表显示如下:");
adjprint(gra);
break;
case 3:
printf("广度优先遍历:");
bfstra(gra);
//cout<<endl;
break;
case 4:
for(i=0;i!=gra.vexnum;++i)
{
visited[i]=0;
}
printf("深度优先遍历:");
dfstra(gra);
//cout<<endl;
break;
case 5:
for(i=0;i!=G.vexnum;++i)
for(int j=0;j!=G.vexnum;++j)
g[i+1][j+1]=G.arcs[i][j].adj;
printf("prim:");
prim(g,d);
break;
case 6:
printf("kruscal:");
kruscal_arc(G,gra);
break;
case 7:
printf("连通分量:");
bfstra_fen(gra);
break;
case 0:exit(0);break;

}
printf("是否继续?y/n:");
//cin>>y;
if(y=='n')
break;
}
}


...请据图分析回答:(1)该生态系统的主要成分是图中的___,它是生态系...
(1)生产者(即农作物)是生态系统的主要成分,是生态系统的基石.(2)从生态系统的组成成分看,图中显示了生产者(农作物)、消费者(家禽、人)、分解者(沼气池中微生物),未标出的是非生物的物质和能量.(3)物质循环和能量流动是生态系统的主要功能,从生态学角度分析,图示的农业生态系统中...

如图是关节结构示意图,据图回答下列问题.(1)写出图中各结构的名称.①...
(1)图中的1关节头,4关节窝,两者构成关节面;2关节囊,3关节腔,5关节软骨.(2)若进行体育运动或从事体力劳动时,用力过猛或不慎摔倒,1关节头从4关节窝滑脱出来,叫脱臼.(3)关节面上覆盖一层表面光滑的5关节软骨,可减少运动时两骨间关节面的摩擦和缓冲运动时的震动.4关节囊由结缔组织...

下图是鸡蛋的结构示意图以及雏鸡图片,请据图回答下列问题(8分)(1)在...
① 卵白:卵白位于卵黄外面,它为胚胎提供了额外的营养和保护,同时帮助维持卵的形状。(3)受精:只有受精的鸡蛋才能孵化出小鸡。受精通常发生在公鸡和母鸡交配之后。(4)气室、卵黄系带:气室是鸡蛋内部的一个空间,可以为孵化后的雏鸡提供氧气。卵黄系带是连接卵黄和胚盘的结构,它在胚胎发育过程中起...

...内填图中标号)(1)图中A、B、C所示结构中共有的
可以得知浓度B发生质壁分离的细胞数是22个,大约占一半.(3)由于噬菌体只能寄生在活细胞内,所以要想标记噬菌体,首先在含有放射性同位素32P培养基中培养大肠杆菌,再用上述大肠杆菌培养噬菌体,得到DNA 含有32P标记的噬菌体.(4)有丝分裂的过程中核膜和核仁以及染色体会周期性的消失于重建;脱分化时...

...据图回答下列问题:(1)图中的a所示结构为___,有___和___的作用,_百...
含有各种有味道的物质,以及营养物质等,如西瓜的汁液中含有大量的营养物质,有甜味,就是位于液泡中.(5)与动物细胞相比,植物细胞除了和动物细胞一样含有细胞膜、细胞质、细胞核和线粒体以外,一般还具有细胞壁、液泡和叶绿体.故答案为:(1)细胞壁;支持;保护;细胞膜;保护,控制物质进出(2)d...

...据图回答下列问题.(1)图中在开花前保护内部结构的是[___]___和...
故传粉需有昆虫.如果用塑料袋罩起来,丙桃花处在封闭状态下不会自己授粉结实,甲无雌蕊、乙缺少雄蕊及花粉,就更不会结实了.故甲、乙、丙都不能结果实.(8)图中③指 花柱,⑨指 花丝(9)首先植物要想结出果实与种子首先必须进行的两个生理过程为:传粉与受精.而花粉来自于雄蕊的花药....

PKPM-钢结构-空间结构建模问题
初步从建筑图中获取信息,估算外圈梁高,柱截面尺寸,板厚,以及确定要建模型的标准层数。一般情况下边柱和中柱尺寸做成一样。结构高度是建筑标高减去面层的高度。梁的截面尺寸,宜符合下列要求:截面宽度不宜小于200mm;截面高宽比不宜大于4;净跨与截面高度之比不宜小于4(抗规6.3.1 第60页)。框架...

建筑施工图主要表达的内容是什么?基本图样有哪些?
(1)首页图:首页图列出了图纸目录,在图纸目录中有各专业图纸的图件名称、数量、所在位置,反映出了一套完整施工图纸的编排次序,便于查找。(2)设计总说明:①工程设计的依据:建筑面积、单位面积造价、有关地质、水文、气象等方面资料。②设计标准:建筑标准、结构荷载等级、抗震设防标准、采暖、通风...

如图是菜豆、玉米种子的结构图,请据图回答问题:(1)菜豆、玉米种子的结...
(1)在种子萌发的过程中,胚根发育成植物的根,胚芽发育成植物的茎和叶,胚轴伸长发育成连接茎和叶的部分,(2)菜豆属于双子叶植物,营养物质储存在子叶内,玉米属于单子叶植物,营养物质储存在胚乳内.菜豆种子和玉米种子的结构相同点是都有种皮和胚,不同点是菜豆种子的子叶有2片,而玉米种子的...

如图是鸡蛋的结构示意图以及雏鸡图片,请据图回答下列问题(1)在该鸡蛋...
由鸟卵的结构图可知各部分名称为:1是卵白,2是胚盘,3是卵壳,4是气室,5是卵黄系带,6是卵黄,7是卵黄膜(1)在鸡蛋的结构中将来发育成雏鸡的是胚盘,胚盘含有细胞核,是胚胎发育的场所.胚盘、卵黄、卵黄膜共同构成了卵细胞.(2)卵白能够保护卵细胞,还能为胚胎发育提供水分和养料;(3)精子和...

皇姑区17121824165: 数据结构中图的建立及输出的课程设计 -
家初必可: 1、一元稀疏多项式相加 详细设计4.1 程序头的设计: #include #include typedef struct pnode {int coef;/*系数 */ int exp;/*指数 */ struct pnode *next;/*下一个指针*/ }pnode;4.2 用头插法生成一个多项式,系数和指数输入0时退出输入 pnode * ...

皇姑区17121824165: 数据结构课程设计题目,图的建立以及遍历. -
家初必可: //图的遍历算法程序 //图的遍历是指按某条搜索路径访问图中每个结点,使得每个结点均被访问一次,而且仅被访问一次.图的遍历有深度遍历算法和广度遍历算法,程序如下: #include <iostream> //#include <malloc.h> #define INFINITY 32767 ...

皇姑区17121824165: 数据结构课程设计 迪结斯特拉算法问题描述:图的存储结构的建立、Dijkstra算法.实现要求:(1)将图的信息建立文件;(2)从文件读入图的信息,建立... -
家初必可:[答案] 额,我这个写的已经比较清楚了.是数组模拟邻接表的,addedge里面建立的是双向边.邻接矩阵的话.cin>>n>>m;//n point m edgefor(int i=1;i<=m;i++){cin>>from>>to>>value;g[from][to] = value;}memset(dis,20,sizeof(dis)); dis[1]=0; for(int i=1;i<=n;i++...

皇姑区17121824165: 数据结构课程设计:如何以邻接矩阵的方式确定一个图⑴建立并显示出它的邻接链表;⑵给出它的关键路径(要求:显示出VE,VL,E,L,L - E的结果).
家初必可: #include <stdio.h> #define INFI 9999 #define MAXNUM 8 typedef struct{ int arcs[MAXNUM+1][MAXNUM+1]; char vexs[MAXNUM+1]; int vexnum,arcnum; }MGraph; int Locate(MGraph &G1,char &u) { int l; G1.vexs[0]=u; for(l=G1.vexnum;l>=0 && (G1....

皇姑区17121824165: 数据结构设计
家初必可: 设计说明 1、 算法设计的思想 建立图类,建立相关成员函数.最后在主函数中实现.具体成员函数的实现请参看源程序. 2、 主要的数据结构设计说明 图邻接矩阵、邻接表的建立.图的深度优先遍历、拓扑排序、顶点之间的最短路径. 3、 程序的主要模板template <class Type> class Graph 4、 程序的主要函数 Graph、link()、DFTraverse()、TopologicalOrder()、 TopologicalOrder()、GetVertexPos()、ShortestPath

皇姑区17121824165: 数据结构中 图的建立及输出 -
家初必可: package graph; public class Graphm implements Graph{ private int[][]matrix; private int numEdge; public int[]Mark; public Graphm(int n){ Mark=new int[n]; matrix=new int[n][n]; numEdge=0; } public int n() public int e() public Edge first (int v){ for(int i=0...

皇姑区17121824165: 数据结构中图的建立及算法实现 -
家初必可: #include<stdio.h>#include<stdlib.h>#define MaxSize 20 struct ArcNode { int adjvex; struct ArcNode *nextarc; }; struct Vnode { int data; struct ArcNode *firstarc; }; struct Vnode AdjList[MaxSize]; int m,n,v,cord; void main() { void creatgraph(struct ...

皇姑区17121824165: 数据结构课程设计:稀疏矩阵操作任务:(1)完成一稀疏矩阵转置,(2)能够完成两个稀疏矩阵相加,(3)输出稀疏矩阵 最好能写明:存储结构、稀疏矩... -
家初必可:[答案] 一、需求分析 二、概要设计 三、详细设计:Cpp1.cpp 四、调试分析 五、用户手册及测试数据:执行Cpp1.exe 六、附录 [数据结构]数据结构稀疏矩阵加法实验报告 一、需求分析 假设稀疏矩阵M和N均以三元组表作为存储结构...

皇姑区17121824165: 数据结构课程设计,有向图,C语言高手进 -
家初必可: 写C程序,随机给出n*n的邻接矩阵,并打印输出邻接矩阵,以及有向图的边的个数,每个顶点的度,并判断该图中是否存在Euler回路: (1)如果为n阶,则随机产生一个n*n的邻接矩阵; (2)输出邻接矩阵,边的个数,每个顶点的度以及图中...

皇姑区17121824165: 数据结构课程设计报告 -
家初必可: 1、一元稀疏多项式相加详细设计4.1 程序头的设计: #include<stdio.h> #include<malloc.h> typedef struct pnode {int coef;/*系数 */ int exp;/*指数 */ struct pnode *next;/*下一个指针*/ }pnode;4.2 用头插法生成一个多项式,系数和...

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 星空见康网