青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 0,  comments - 5,  trackbacks - 0
參考網(wǎng)上他人的經(jīng)驗(yàn),寫了一個(gè)基于鄰接表的有向圖類,實(shí)現(xiàn)了圖的基本操作和Dijkstra算法。
適合大數(shù)據(jù)量的圖。
代碼如下:
#ifndef __GRAPH_H__
#define __GRAPH_H__

#include 
<vector>

#define  IN
#define OUT
#define INOUT
using namespace std;

namespace graphspace
{
    template 
<typename weight>
    
struct Edge 
    {
        
int nDestVertex;
        weight edgeWeight;
        Edge
<weight> *pNextEdge;

        Edge(
int d, weight c, Edge<weight> *= NULL)
            :nDestVertex(d), edgeWeight(c), pNextEdge(p)
        {}
    };

    template 
<typename vertexNametype, typename weight>
    
struct Vertex
    {
        vertexNametype vertexName;
        Edge
<weight> *pAdjEdges;

        Vertex(vertexNametype x, Edge
<weight> *= NULL)
            :vertexName(x), pAdjEdges(p)
        {}
    };

    
//adjacency list based graph
    template <typename vertexNametype, typename weight>
    
class ALGraph
    {
    
public:
        
explicit ALGraph();
        
~ALGraph();
    
public:
        
        
bool insertAVertex(IN const vertexNametype vertexName);

        
bool insertAEdge(IN const vertexNametype vertexName1, IN const vertexNametype vertexName2, IN const weight edgeWeight);

        
bool removeAEdge(IN const vertexNametype vertexName1, IN const vertexNametype vertexName2, IN const weight edgeWeight);

        weight getMinWeight(IN 
const vertexNametype vertexName1, IN const vertexNametype vertexName2);

        
int getVertexIndex(IN const vertexNametype vertexName);

        
int getVertexNumber();

        vertexNametype getData(IN 
int index);

        
int Dijkstra(IN const vertexNametype vertexName1);

        
void DijkstraPrint(IN int index, IN int sourceIndex, IN vector<int> vecPreVertex);

        friend ostream
& operator<<(OUT ostream &out, IN const ALGraph<vertexNametype,weight> &graphInstance);   

    
public:
        
        weight getEdgeWeight(IN 
const Edge<weight> *pEdge);

        
void getVertexEdgeWeight(IN const int v1, OUT vector<weight> &DistanceArray);

        vector
< Vertex<vertexNametype, weight> > m_vertexArray;
    };

#include 
"graph_realize.h"

}

#endif

實(shí)現(xiàn)類頭文件:
#ifndef __GRAPH_REALIZE__H_
#define __GRAPH_REALIZE__H_

/*#define VERTEXARRAYITE (vector< Vertex<vertexNametype, weight> >::iterator) */

template
<typename vertexNametype, typename weight>
ALGraph
<vertexNametype, weight>::ALGraph()
{
    
if (!m_vertexArray.empty())
    {
        m_vertexArray.clear();
    }
    
}

template
<typename vertexNametype, typename weight>
ALGraph
<vertexNametype, weight>::~ALGraph()
{
    vector
< Vertex<vertexNametype, weight> >::iterator iter;
    
for(iter = m_vertexArray.begin(); iter != m_vertexArray.end(); iter++)
    {
        Edge
<weight> *= iter->pAdjEdges;
        
while(NULL != p)
        {
            iter
->pAdjEdges = p->pNextEdge;
            delete p;
            p 
= iter->pAdjEdges;
        }
    }
    
if (!m_vertexArray.empty())
    {
        m_vertexArray.clear();
    }
}

template
<typename vertexNametype, typename weight>
bool ALGraph<vertexNametype, weight>::insertAVertex(IN const vertexNametype vertexName)
{
    Vertex
<vertexNametype, weight> VertexInstance(vertexName, NULL);
    m_vertexArray.push_back(VertexInstance);

    
return true;
}

template
<typename vertexNametype, typename weight>
bool ALGraph<vertexNametype, weight>::insertAEdge(IN const vertexNametype vertexName1, 
                            IN 
const vertexNametype vertexName2, IN const weight edgeWeight)
{
    
int v1 = getVertexIndex(vertexName1);
    
if (-1 == v1)
    {
        cerr 
<< "There is no vertex 1" << endl;
        
return false;
    }

    
int v2 = getVertexIndex(vertexName2);
    
if (-1 == v2)
    {
        cerr 
<< "There is no vertex 2" << endl;
        
return false;
    }

    Edge
<weight> *= m_vertexArray.at(v1).pAdjEdges;
    
while(p != NULL && p->nDestVertex != v2)
    {
        p 
= p->pNextEdge;
    }

    
if (NULL == p)
    {
        p 
= new Edge<weight>(v2, edgeWeight, m_vertexArray.at(v1).pAdjEdges);
        m_vertexArray.at(v1).pAdjEdges 
= p;
        
return true;
    }
    
if (v2 == p->nDestVertex)
    {
        Edge
<weight> *= p;
        p 
= new Edge<weight>( v2, edgeWeight, q->pNextEdge );
        q
->pNextEdge = p;
        
return true;
    }
    
    
return false;
}

template
<typename vertexNametype, typename weight>
bool ALGraph<vertexNametype, weight>::removeAEdge(IN const vertexNametype vertexName1, 
                                          IN 
const vertexNametype vertexName2, IN const weight edgeWeight)
{
    
int v1 = getVertexIndex(vertexName1);
    
if (-1 == v1)
    {
        cerr 
<< "There is no vertex 1" << endl;
        
return false;
    }

    
int v2 = getVertexIndex(vertexName2);
    
if (-1 == v2)
    {
        cerr 
<< "There is no vertex 2" << endl;
        
return false;
    }

    Edge
<weight> *= m_vertexArray.at(v1).pAdjEdges;
    Edge
<weight> *= NULL;
    
while(p != NULL && p->nDestVertex != v2 )
    {
        q 
= p;
        p 
= p->pNextEdge;
    }
    
if (NULL == p)
    {
        cerr 
<< "Edge is not found" << endl;
        
return false;
    }
    
while( edgeWeight != p->edgeWeight && p->nDestVertex == v2)
    {
        q 
= p;
        p 
= p->pNextEdge;
    }
    
if (v2 != p->nDestVertex)
    {
        cerr 
<< "Edge is not found" << endl;
        
return false;
    }
    q
->pNextEdge = p->pNextEdge;
    delete p;

    
return true;
}

template
<typename vertexNametype, typename weight>
weight ALGraph
<vertexNametype, weight>::getEdgeWeight(IN const Edge<weight> *pEdge)
{
    
return pEdge->edgeWeight;
}

template
<typename vertexNametype, typename weight>
void ALGraph<vertexNametype, weight>::getVertexEdgeWeight(IN const int v1, OUT vector<weight> &DistanceArray)
{
    Edge
<weight> *= m_vertexArray.at(v1).pAdjEdges;
    
int prevIndex = -1;
    weight tmp;

    
while(NULL != p)
    {
        
//consider the same edges exist
        if (prevIndex == p->nDestVertex)
        {
            
if (tmp > p->edgeWeight)
            {
                DistanceArray[prevIndex] 
= p->edgeWeight;
            }
        }
        
else
        {
            DistanceArray[p
->nDestVertex] = p->edgeWeight;
            prevIndex 
= p->nDestVertex;
            tmp 
= p->edgeWeight;
        }
        
        p 
= p->pNextEdge;
    }
}

template
<typename vertexNametype, typename weight>
weight ALGraph
<vertexNametype, weight>::getMinWeight(IN const vertexNametype vertexName1, 
                                          IN 
const vertexNametype vertexName2)
{
    Edge
<weight> *pEdge = NULL;
    
int v1 = getVertexIndex(vertexName1);
    
if (-1 == v1)
    {
        cerr 
<< "There is no vertex 1" << endl;
        
return false;
    }

    
int v2 = getVertexIndex(vertexName2);
    
if (-1 == v2)
    {
        cerr 
<< "There is no vertex 2" << endl;
        
return false;
    }

    Edge
<weight> *= m_vertexArray.at(v1).pAdjEdges;
    
while (p != NULL && p->nDestVertex != v2)
    {
        p 
= p->pNextEdge;
    }
    
if (NULL == p)
    {
        pEdge 
= NULL;
        
return weight(0);
    }
    weight tmp 
= getEdgeWeight(p);
    pEdge 
= p;
    
while (NULL != p && v2 == p->nDestVertex)
    {
        
if (tmp > getEdgeWeight(p))
        {
            tmp 
= getEdgeWeight(p);
            pEdge 
= p;
        }
        p 
= p->pNextEdge;
    }
    
return tmp;
}

template
<typename vertexNametype, typename weight>
int ALGraph<vertexNametype, weight>::getVertexIndex(IN const vertexNametype vertexName)
{
    
for (int i = 0; i < m_vertexArray.size(); i++)
    {
        
if (vertexName == getData(i))
        {
            
return i;
        }
    }
    
return -1;
}

template
<typename vertexNametype, typename weight>
int ALGraph<vertexNametype, weight>::getVertexNumber()
{
    
return m_vertexArray.size();
}

template
<typename vertexNametype, typename weight>
vertexNametype ALGraph
<vertexNametype, weight>::getData(IN int index)
{
    
return m_vertexArray.at(index).vertexName;
}

template
<typename vertexNametype, typename weight>
int ALGraph<vertexNametype, weight>::Dijkstra(IN const vertexNametype vertexName1)
{
    
int sourceIndex = getVertexIndex(vertexName1);
    
if (-1 == sourceIndex)
    {
        cerr 
<< "There is no vertex " << endl;
        
return false;
    }
    
int nVertexNo = getVertexNumber();

    
//the array to record the points have been included, if included the value is true
    
//else is false
    vector<bool> vecIncludeArray;
    vecIncludeArray.assign(nVertexNo, 
false);
    vecIncludeArray[sourceIndex] 
= true;

    
//the array to record the distance from vertex1
    vector<weight> vecDistanceArray;
    vecDistanceArray.assign(nVertexNo, weight(INT_MAX));
    vecDistanceArray[sourceIndex] 
= weight(0);

    
//prev array to record the previous vertex
    vector<int> vecPrevVertex;
    vecPrevVertex.assign(nVertexNo, sourceIndex);

    getVertexEdgeWeight(sourceIndex, vecDistanceArray);

    
int vFrom, vTo;

    
while(1)
    {
        weight minWeight 
= weight(INT_MAX);
        vFrom 
= sourceIndex;
        vTo 
= -1;
        
for (int i = 0; i < nVertexNo; i++)
        {
            
if (!vecIncludeArray[i] && minWeight > vecDistanceArray[i])
            {
                minWeight 
= vecDistanceArray[i];
                vFrom 
= i;
            }
        }
        
if (weight(INT_MAX) == minWeight)
        {
            
break;
        }
        vecIncludeArray[vFrom] 
= true;

        Edge
<weight> *= m_vertexArray[vFrom].pAdjEdges;
        
while (NULL != p)
        {
            weight wFT 
= p->edgeWeight;
            vTo 
= p->nDestVertex;
            
if (!vecIncludeArray[vTo] && vecDistanceArray[vTo] > wFT + vecDistanceArray[vFrom])
            {
                vecDistanceArray[vTo] 
= wFT + vecDistanceArray[vFrom];
                vecPrevVertex[vTo] 
= vFrom;
            }
            p 
= p->pNextEdge;
        }
                
    }

    
//print the shortest route of all vertexes
    for (int i = 0; i < nVertexNo; i++)
    {
        
if (weight(INT_MAX) != vecDistanceArray[i])
        {
            cout 
<< getData(sourceIndex) << "->" << getData(i) << "";
            DijkstraPrint(i, sourceIndex, vecPrevVertex);
            cout 
<< "  " << vecDistanceArray[i];
            cout 
<< endl;
        }
    }

    
return 0;
}

template
<typename vertexNametype, typename weight>  
void ALGraph<vertexNametype, weight>::DijkstraPrint(IN int index, IN int sourceIndex, IN vector<int> vecPreVertex)
{
    
if (sourceIndex != index)
    {
        DijkstraPrint(vecPreVertex[index], sourceIndex, vecPreVertex);
    }
    cout 
<< getData(index) << " ";
}

template
<typename vertexNametype, typename weight>   
ostream
& operator<<(OUT ostream &out, IN  ALGraph<vertexNametype,weight> &graphInstance)
{
    
int vertexNo = graphInstance.getVertexNumber();
    
out << "This graph has " << vertexNo << "vertexes" << endl;

    
for(int i = 0; i < vertexNo; i++)
    {
        vertexNametype x1 
= graphInstance.getData(i);
        
out << x1 << ":    ";

        Edge
<weight> *= graphInstance.m_vertexArray.at(i).pAdjEdges;
        
while (NULL != p)
        {
            
out << "(" << x1 << "," << graphInstance.getData(p->nDestVertex) << "," << p->edgeWeight << ")  ";
            p 
= p->pNextEdge;
        }
        
out << endl;
    }
    
return out;
}

#endif

基本測(cè)試:
#include <iostream>
#include 
"graph.h"

using namespace std;
using namespace graphspace;

void main()
{
    ALGraph
<charint> g;   

    g.insertAVertex( 
'A' );   
    g.insertAVertex( 
'B' );   
    g.insertAVertex( 
'C' );   
    g.insertAVertex( 
'D' );
    g.insertAVertex(
'E');
    g.insertAVertex(
'F');
    cout 
<< g << endl << endl;   

    g.insertAEdge(
'A''B'6); 
    g.insertAEdge(
'A''C'3); 
    g.insertAEdge(
'B''C'2); 
    g.insertAEdge(
'B''D'5); 
    g.insertAEdge(
'C''D'3); 
    g.insertAEdge(
'C''E'4); 
    g.insertAEdge(
'D''E'2); 
    g.insertAEdge(
'D''F'3); 
    g.insertAEdge(
'E''F'5); 

    g.insertAEdge(
'B''A'6); 
    g.insertAEdge(
'C''A'3); 
    g.insertAEdge(
'C''B'2); 
    g.insertAEdge(
'D''B'5); 
    g.insertAEdge(
'D''C'3); 
    g.insertAEdge(
'E''C'4); 
    g.insertAEdge(
'E''D'2); 
    g.insertAEdge(
'F''D'3); 
    g.insertAEdge(
'F''E'5); 
       
    cout 
<< g << endl << endl; 
    g.Dijkstra(
'A');

    

    system(
"pause");
    
return;
}

測(cè)試結(jié)果:
posted on 2010-07-30 14:30 saha 閱讀(5503) 評(píng)論(1)  編輯 收藏 引用

FeedBack:
# re: 有向圖的C++實(shí)現(xiàn)
2015-05-18 10:30 | 葉剛
您好,在您的代碼第一部分結(jié)尾處的
#include "graph_realize.h"
是什么呢?
  回復(fù)  更多評(píng)論
  

只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理



<2025年11月>
2627282930311
2345678
9101112131415
16171819202122
23242526272829
30123456

常用鏈接

留言簿

文章分類

文章檔案

收藏夾

搜索

  •  

最新評(píng)論

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久久久欧美精品| 一本色道久久综合亚洲精品高清| 曰韩精品一区二区| 国产精品久久久久久av福利软件| 欧美日韩综合一区| 欧美午夜宅男影院| 国产在线日韩| 亚洲国产日韩在线一区模特| 亚洲高清不卡av| av成人天堂| 欧美在线国产| 欧美成人一区二区三区片免费| 亚洲大片精品永久免费| 亚洲黄色av| 亚洲在线视频| 欧美高清视频一区| 国产视频精品网| 亚洲精品美女在线观看播放| 亚洲视频视频在线| 久久婷婷一区| a4yy欧美一区二区三区| 久久经典综合| 欧美三级乱人伦电影| 国产一区二区三区黄视频| 99精品国产一区二区青青牛奶| 午夜精品久久久久久久久久久久久| 久久夜色撩人精品| 在线午夜精品| 欧美成人免费在线观看| 国产欧美日韩精品丝袜高跟鞋| 亚洲电影网站| 欧美在线一级va免费观看| 亚洲啪啪91| 久久久久久伊人| 国产精品一区二区视频 | 亚洲婷婷综合色高清在线| 欧美一级日韩一级| 国产精品激情av在线播放| 亚洲国产网站| 久久精品国产亚洲5555| 一本色道**综合亚洲精品蜜桃冫| 免费欧美网站| 伊人激情综合| 久久精品亚洲一区二区三区浴池| 一本色道久久综合亚洲91| 欧美刺激午夜性久久久久久久| 亚洲图片欧美日产| 欧美日韩国产在线| 亚洲人成亚洲人成在线观看图片| 久久久久成人网| 午夜久久久久久| 欧美日精品一区视频| 日韩视频在线永久播放| 亚洲国产精品久久久久久女王| 久久精品国产69国产精品亚洲| 国产精品无码永久免费888| 亚洲深夜影院| 99国产精品久久久久久久成人热| 蜜臀av国产精品久久久久| 亚洲电影免费在线| 亚洲国产成人高清精品| 开心色5月久久精品| 亚洲电影观看| 亚洲国产成人久久综合| 欧美国产亚洲视频| 夜夜爽av福利精品导航| 亚洲精品国精品久久99热一| 欧美高清在线一区| 在线视频精品一区| 亚洲视频www| 国产视频久久| 欧美激情视频在线免费观看 欧美视频免费一 | 一本色道久久综合亚洲精品不| 亚洲国产日韩欧美在线99| 欧美国产视频在线观看| 亚洲天堂男人| 亚洲欧美精品在线观看| 黑人巨大精品欧美一区二区小视频| 老司机免费视频久久| 欧美高清视频一区二区三区在线观看| 亚洲人体1000| 亚洲中字在线| 91久久久久久久久| 亚洲无线观看| 亚洲国产成人av在线| 99热精品在线观看| 黑人一区二区三区四区五区| 亚洲丶国产丶欧美一区二区三区| 欧美精品一区在线| 久久精品国产亚洲5555| 欧美成人午夜激情| 亚洲欧美日韩精品久久久| 久久精品视频免费播放| av成人黄色| 久久精品国产精品亚洲| 亚洲裸体在线观看| 欧美一激情一区二区三区| 亚洲欧洲精品一区二区三区 | 这里只有精品在线播放| 国产丝袜美腿一区二区三区| 免费成人黄色| 国产精品二区影院| 欧美激情一区二区久久久| 欧美中文日韩| 一本色道久久加勒比精品| 久久不射网站| 亚洲女同性videos| 欧美国产精品专区| 久久国产综合精品| 欧美三区美女| 亚洲成色777777在线观看影院| 国产精品日韩一区| 日韩视频在线你懂得| 亚洲国产经典视频| 欧美在线视频观看| 欧美亚洲一区| 欧美视频国产精品| 亚洲成色777777在线观看影院| 国产一区二区三区日韩| 亚洲一卡久久| 亚洲私拍自拍| 欧美成人午夜77777| 麻豆成人在线播放| 激情欧美一区二区三区| 亚洲欧美日韩国产中文| 亚洲午夜国产一区99re久久 | 欧美专区在线观看| 性色av一区二区三区| 欧美色另类天堂2015| 亚洲免费精品| 在线午夜精品| 欧美性猛交xxxx乱大交蜜桃| 日韩图片一区| 亚洲一级影院| 欧美性大战久久久久| 一区二区三区久久久| 亚洲视屏一区| 国产精品入口日韩视频大尺度 | 欧美成人精品h版在线观看| 久久一区免费| 一区二区在线不卡| 久久久久国产精品一区三寸| 久久婷婷久久| 亚洲高清资源| 欧美激情亚洲激情| 日韩亚洲欧美一区| 香蕉久久久久久久av网站| 国产日韩精品一区二区| 久久精品99无色码中文字幕| 久久久青草婷婷精品综合日韩| 国产午夜一区二区三区| 欧美一区成人| 欧美成人免费在线观看| 亚洲精品在线视频| 国产精品久久久久久av福利软件| 亚洲资源av| 男人天堂欧美日韩| 一本色道婷婷久久欧美| 国产精品亚洲第一区在线暖暖韩国| 羞羞漫画18久久大片| 米奇777超碰欧美日韩亚洲| 99精品福利视频| 国产日韩欧美在线播放不卡| 久久久99国产精品免费| 亚洲三级色网| 久久九九国产精品| 日韩一区二区精品在线观看| 国产精品久久久久天堂| 久久人人爽人人爽| 99亚洲视频| 亚洲精品视频在线观看网站 | 欧美精品videossex性护士| 日韩亚洲欧美成人| 久久综合色天天久久综合图片| 日韩视频二区| 国产亚洲精品久久久久久| 看欧美日韩国产| 亚洲欧美偷拍卡通变态| 亚洲高清免费在线| 久久久久久网址| 亚洲在线观看视频| 亚洲人成在线播放| 国内精品视频一区| 国产精品成人一区二区三区夜夜夜| 久久一区激情| 亚欧成人在线| 一本色道88久久加勒比精品| 免费观看成人| 久久精品亚洲国产奇米99| 亚洲特级毛片| 99国产一区| 日韩视频免费在线观看| 在线观看日韩| 海角社区69精品视频| 国产精品毛片a∨一区二区三区| 欧美大片在线看| 久久综合伊人77777| 久久精品二区| 性色av一区二区三区| 亚洲欧美影音先锋|