亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? urouting.cpp

?? 實現最短路徑算法。 實現最短路徑算法。
?? CPP
字號:
//---------------------------------------------------------------------------

#include <vcl.h>
#pragma hdrstop

#include "Urouting.h"

//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TRoutingForm *RoutingForm;
//---------------------------------------------------------------------------
__fastcall TRoutingForm::TRoutingForm(TComponent* Owner)
        : TForm(Owner)

{
    m_xSou=113.26818, m_ySou=23.17236 ,m_xDes=113.26739 ,m_yDes=23.12543;
    m_N=5;
}
//---------------------------------------------------------------------------
void __fastcall TRoutingForm::SpeedButton1Click(TObject *Sender)
{
       if(OpenDialog1->Execute())
       {
             NodeFile=OpenDialog1->FileName ;
             nodefile->Text=NodeFile;
       }
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::SpeedButton2Click(TObject *Sender)
{
      if(OpenDialog1->Execute())
       {
             ArcFile=OpenDialog1->FileName ;
             arcfile->Text=ArcFile;
       }
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::SpeedButton3Click(TObject *Sender)
{
       if(OpenDialog1->Execute())
       {
             AttrFile=OpenDialog1->FileName ;
             attrfile->Text=AttrFile;
       }
}
//---------------------------------------------------------------------------


void TRoutingForm::drawanarc(int arcNo,double minx,double maxx,double miny,double maxy,double dx,double dy)
{

        ArcNode  *currArc;
        double xx,yy;
        int sx,sy;
         Image1->Canvas->Pen->Color=clRed;
        currArc=arcGraph->nextArc;
     	while(currArc && currArc->arcNo != arcNo)currArc = currArc->nextArc;
        if(currArc)
        {
         xx= currArc->xd[0];
         yy= currArc->yd[0];
         sx= (int)((xx-minx)/dx);
         sy= Image1->Height-(int)((yy-miny)/dy);
         Image1->Canvas->MoveTo(sx,sy);
         for(int k=1;k<currArc->arcNum;k++)
              {
                     xx= currArc->xd[k];
                     yy=currArc->yd[k];
                     sx= (int)((xx-minx)/dx);
                     sy= Image1->Height-(int)((yy-miny)/dy);
                     Image1->Canvas->LineTo(sx,sy);

              }
       } 
}

void TRoutingForm::writearc(FILE *ooo,int arcNo)
{

        ArcNode  *currArc;
        double xx,yy;
        int sx,sy;

        currArc=arcGraph->nextArc;
     	while(currArc && currArc->arcNo != arcNo)currArc = currArc->nextArc;
        if(currArc)
        {
              fprintf(ooo,"%d\n", currArc->arcNum);
              for(int k=0;k<currArc->arcNum;k++)
              {
                     xx= currArc->xd[k];
                     yy=currArc->yd[k];
                     fprintf(ooo,"%lf %lf\n",xx,yy);
              }
       } 
}
void __fastcall TRoutingForm::Button1Click(TObject *Sender)
{
        FILE *fil,*arcf;
        fil = fopen("pathdata.dat","w");
        arcf=fopen("arcfile.dat","w");
  //////////
        int      vexNo,countArc,countVex,arcNum,arcNo,headNo,tailNo;
	char name[MAXNAME];
	double   x,y,v,d;

        ArcNode  *currArc,*nextArc;
        arcGraph = (ArcNode *)malloc(sizeof(ArcNode));
	if(arcGraph == 0)  ShowMessage("error");
	     //	return false;
        arcGraph->nextArc=0;
        currArc= arcGraph;
        FILE *lineFp;

	if(!(lineFp = fopen(ArcFile.c_str(),"r")))   ShowMessage("error");
	     //	return false;

        double minx=100000000.0,maxx=0,miny=1000000000.0,maxy=0;
        double dx,dy;

        while(!feof(lineFp))
	{
		if(fscanf(lineFp,"%d %d %d %s %lf %lf %d",&arcNo,&headNo,&tailNo,name,&v,&d,&arcNum) == 7)
		{

                        nextArc  = (ArcNode *)malloc(sizeof(ArcNode));
                        if(nextArc == 0)   ShowMessage("error");
                                  // return false;
                        nextArc->arcNo  = arcNo;

                        memset(nextArc->info.arcName,'\0',MAXNAME);
                        memcpy(nextArc->info.arcName,name,MAXNAME);
                        memset(nextArc->info.roadName,'\0',MAXNAME);
                        nextArc->info.distance = d;
                        nextArc->info.time =d/v;
                        nextArc->info.headVexNo = headNo;
                        nextArc->info.tailVexNo = tailNo;
                        nextArc->nextArc = 0;

                        nextArc->arcNum  = arcNum;
                        nextArc->xd=new double[arcNum];
                        nextArc->yd=new double[arcNum];
                        for(int j=0 ;j<arcNum;j++)
			{
				fscanf(lineFp,"%lf %lf ",&x,&y);
                                if(minx>x)minx=x;
                                if(maxx<x)maxx=x;
                                if(miny>y)miny=y;
                                if(maxy<y)maxy=y;
                                nextArc->xd[j]=x;
                                nextArc->yd[j]=y;
			}
                        currArc->nextArc=nextArc;
                        currArc=nextArc;
                }
        }

        fclose(lineFp);

 //////////////////
       dx=(maxx-minx)/Image1->Width;
       dy=(maxy-miny)/Image1->Height;
       Image1->Canvas->Pen->Color=clBlack;
       int sx,sy;
       double xx,yy;
       for(currArc= arcGraph->nextArc; currArc;  currArc=currArc->nextArc)
         {
              xx= currArc->xd[0];
              yy=currArc->yd[0];
              sx= (int)((xx-minx)/dx);
              sy= Image1->Height-(int)((yy-miny)/dy);
              Image1->Canvas->MoveTo(sx,sy);
              for(int k=1;k<currArc->arcNum;k++)
              {
                     xx= currArc->xd[k];
                     yy=currArc->yd[k];
                     sx= (int)((xx-minx)/dx);
                     sy= Image1->Height-(int)((yy-miny)/dy);
                     Image1->Canvas->LineTo(sx,sy);

              }

         }

 //////////////////////////////

        PathsNode *pathDis = (PathsNode*)malloc(sizeof(PathsNode));
	PathsNode *pathTim = (PathsNode*)malloc(sizeof(PathsNode));
      	bool shortFlag = routing_short(NodeFile.c_str(),ArcFile.c_str(),AttrFile.c_str(),m_xSou ,m_ySou ,m_xDes ,m_yDes,&pathDis,&pathTim,m_N);
        int kkk=0;
  	if(shortFlag)
	{
	     	if(pathDis>0)
             //   if(pathTim>0)
		{



		     PathsNode *currPaths = pathDis;
                    // PathsNode *currPaths = pathTim;
			PathNode  *currPath;
			while(currPaths)
			{
				currPath  = currPaths->path;
                                AnsiString pp;
                                char ppp[30];
                                sprintf(ppp,"%3d", currPath->vexNo);
                                fprintf(fil,"%3d", currPath->vexNo);
                                pp=pp+ ppp;
                                kkk++;
				while(currPath)
				{
                                     
                                     sprintf(ppp,"->%3d", currPath->arcNo);
                                     fprintf(fil,"->%3d", currPath->arcNo);
                                     if(kkk==1)drawanarc( currPath->arcNo, minx, maxx, miny, maxy, dx, dy);
                                     if(kkk==1)writearc(arcf, currPath->arcNo);
                                     pp=pp+ ppp;
                                     currPath = currPath->next;
                                }
                                Memo1->Lines->Add(pp);

                                fprintf(fil,"\n");
				currPaths = currPaths->next;
		         }
		}
	}
	path_destruct(pathDis);
	path_destruct(pathTim);
        fcloseall();
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::x1edExit(TObject *Sender)
{
      m_xSou=StrToFloat(x1ed->Text);
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::y1edExit(TObject *Sender)
{
        m_ySou=StrToFloat(y1ed->Text);
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::x2edChange(TObject *Sender)
{
          m_xDes=StrToFloat(x2ed->Text);
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::y2edExit(TObject *Sender)
{
        m_yDes=StrToFloat(y2ed->Text);
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::Button3Click(TObject *Sender)
{
        Close();
}
//---------------------------------------------------------------------------

void __fastcall TRoutingForm::lineedExit(TObject *Sender)
{
        m_N=StrToInt( lineed->Text);
}
//---------------------------------------------------------------------------

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美成人精品3d动漫h| 精品久久人人做人人爰| 欧美96一区二区免费视频| 国产亚洲婷婷免费| 欧美精品久久久久久久多人混战 | 亚洲综合无码一区二区| 欧美精品一区二区久久婷婷| 在线一区二区三区四区| 国产成人免费视频一区| 久久国产精品无码网站| 亚洲午夜免费电影| 亚洲品质自拍视频网站| 日本一区二区三区在线观看| 日韩一级大片在线观看| 911国产精品| 精品视频999| 色偷偷成人一区二区三区91| 国产福利一区二区三区视频在线| 看片网站欧美日韩| 日韩高清一区在线| 亚洲老妇xxxxxx| ●精品国产综合乱码久久久久| 久久久国产精品麻豆| 精品久久久久久久人人人人传媒| 欧美自拍丝袜亚洲| 91精品国模一区二区三区| 91色婷婷久久久久合中文| 国内精品免费**视频| 亚洲一级电影视频| 亚洲美女少妇撒尿| 亚洲视频精选在线| 国产精品家庭影院| 中文字幕一区二区三区在线不卡 | 欧美区在线观看| 精品精品国产高清一毛片一天堂| 国产蜜臀97一区二区三区| 亚洲精品成人少妇| 久久99精品国产麻豆婷婷洗澡| 在线免费不卡电影| 日韩欧美一区二区视频| 国产精品毛片高清在线完整版| 亚洲高清免费在线| 国产精品影视天天线| 色噜噜狠狠色综合中国| 精品国产三级电影在线观看| 国产精品免费av| 麻豆精品视频在线观看| 一本大道综合伊人精品热热 | 一区二区三区日韩精品视频| 麻豆精品蜜桃视频网站| 一本久久a久久精品亚洲| 日韩一区二区三区视频在线| 中文字幕在线不卡| 免费国产亚洲视频| 色av成人天堂桃色av| 久久午夜国产精品| 亚洲国产你懂的| 成人福利视频网站| 欧美一区二区三区四区在线观看 | 亚洲综合激情另类小说区| 国产在线不卡一区| 欧美日韩一级大片网址| 欧美激情艳妇裸体舞| 日韩在线一二三区| 91社区在线播放| 欧美韩国日本一区| 久久成人免费电影| 欧美日韩午夜在线| 亚洲免费观看高清| 成人教育av在线| 精品88久久久久88久久久 | 欧美中文字幕一区| 国产精品丝袜一区| 乱一区二区av| 欧美日韩精品一区二区三区| 亚洲免费观看高清完整版在线观看熊 | 国产精品色婷婷久久58| 久久电影国产免费久久电影| 欧美日本国产视频| 夜夜爽夜夜爽精品视频| 91麻豆国产自产在线观看| 国产欧美精品日韩区二区麻豆天美| 蜜臀久久99精品久久久久宅男| 欧美日韩国产综合视频在线观看| 亚洲欧洲日韩在线| 成人高清视频免费观看| 国产日韩精品一区二区三区| 久久99精品一区二区三区三区| 欧美精品一级二级三级| 亚洲亚洲人成综合网络| 在线精品亚洲一区二区不卡| 综合激情网...| 成人app在线观看| 亚洲国产精品成人综合 | 国产偷国产偷亚洲高清人白洁| 日韩不卡手机在线v区| 欧美麻豆精品久久久久久| 一区二区三区欧美激情| 色偷偷久久人人79超碰人人澡 | 国产老肥熟一区二区三区| 精品日韩99亚洲| 精品影视av免费| 日韩精品一区二区三区在线观看| 美女爽到高潮91| 欧美精品一区二区三区蜜桃视频| 精品一区二区三区久久久| 欧美mv日韩mv| 国产不卡视频一区| 国产精品久久久久久久久免费丝袜 | 日韩免费视频一区二区| 极品美女销魂一区二区三区免费| 日韩一区二区中文字幕| 精品一区二区三区免费观看| 久久综合色综合88| 成人免费看视频| 亚洲柠檬福利资源导航| 欧美亚洲国产bt| 日韩精品午夜视频| 精品国产乱码久久久久久浪潮| 国产乱对白刺激视频不卡| 国产精品美女久久久久久久久久久 | 中文字幕免费一区| 色婷婷一区二区三区四区| 亚洲成av人片在线| 日韩精品一区二区三区swag| 国产aⅴ综合色| 亚洲乱码一区二区三区在线观看| 精品视频在线免费| 美女尤物国产一区| 国产欧美一区二区精品久导航 | 久久一日本道色综合| 成人影视亚洲图片在线| 亚洲图片欧美一区| 精品国一区二区三区| 97se亚洲国产综合自在线不卡| 亚洲成人资源网| 久久久蜜桃精品| 91精品福利在线| 另类小说一区二区三区| 欧美国产精品劲爆| 欧美日韩免费视频| 国产精品小仙女| 亚洲成人免费在线观看| 久久综合狠狠综合久久综合88 | 国产精品国产三级国产| 欧美日本国产一区| 成人性生交大片| 亚洲成人av免费| 国产日韩欧美精品在线| 欧美日韩一卡二卡三卡| 国产麻豆91精品| 午夜激情久久久| 国产精品九色蝌蚪自拍| 日韩一区二区三区免费看| 成人网在线播放| 蜜桃免费网站一区二区三区 | 99久久久久免费精品国产| 午夜精品久久久久久久久久| 国产欧美日韩在线看| 欧美日韩一区在线| 懂色av中文一区二区三区| 日韩中文字幕91| 日韩理论片一区二区| 欧美不卡一区二区三区四区| 欧美性做爰猛烈叫床潮| 国产凹凸在线观看一区二区| 成人晚上爱看视频| 精品一区二区三区日韩| 午夜免费欧美电影| 亚洲丝袜制服诱惑| 久久男人中文字幕资源站| 欧美午夜精品理论片a级按摩| 精品无人区卡一卡二卡三乱码免费卡| 一二三四社区欧美黄| 国产精品黄色在线观看| 久久夜色精品一区| 欧美一区二区啪啪| 91久久国产最好的精华液| 成人国产在线观看| 国模一区二区三区白浆| 日韩国产一二三区| 亚洲一区二区三区四区在线观看 | av资源网一区| 国产在线精品免费| 美美哒免费高清在线观看视频一区二区| 国产人妖乱国产精品人妖| 国产乱对白刺激视频不卡| 一本色道久久综合精品竹菊| 日本aⅴ免费视频一区二区三区| 91麻豆国产香蕉久久精品| 欧美韩国日本不卡| 久久av资源站| 精品美女在线播放| 日本欧美一区二区在线观看| 成人少妇影院yyyy| 国产精品电影一区二区| 成人听书哪个软件好| 久久久久久99久久久精品网站| 日韩国产在线观看| 久久久一区二区三区捆绑**|