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

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

?? quanguojiaotong.txt.txt

?? 一、設計內容與設計要求 1.設計內容: 出于不同目的的旅客對交通工具有不同的要求。例如
?? TXT
?? 第 1 頁 / 共 2 頁
字號:

 

Status AddCity(City *C){//增加
    int i,j,flag = 1;
    char *tname[MAX_VERTEX_NUM];
    while(1){
        printf("input the city name[input_end to return]:  ");
        scanf("%s",&tname);
        if(strcmp(tname,"_end") == 0) break;
        for(i = 0;i < C->CityNum; i++)
            if(strcmp(C->name[i],tname) == 0){
                printf("the [%s] city is in dat:",C->name[i]);
                flag = 0;
                return;
            }
        if(flag == 1){
            C->CityNum = C->CityNum + 1;
            strcpy(C->name[C->CityNum - 1],tname);

            for(i = 0; i < C->CityNum; i++){
                C->arcs[i][C->CityNum - 1].TTime = INFINITY;
                C->arcs[i][C->CityNum - 1].TPrice = INFINITY;
                C->arcs[i][C->CityNum - 1].FTime = INFINITY;
                C->arcs[i][C->CityNum - 1].FPrice = INFINITY;
            }
            for(j = 0; j < C->CityNum - 1; j++){
                printf("input TTime,TPrice,FTime,FPrice[%s -> %s]:  ",C->name[C->CityNum - 1],C->name[j]);
                scanf("%d%d%d%d",&C->arcs[C->CityNum - 1][j].TTime,&C->arcs[C->CityNum - 1][j].TPrice,&C->arcs[C->CityNum - 1][j].FTime,&C->arcs[C->CityNum - 1][j].FPrice);
                if(C->arcs[C->CityNum - 1][j].TTime == 0){
                    C->arcs[C->CityNum - 1][j].TTime = INFINITY;
                    C->arcs[C->CityNum - 1][j].TPrice = INFINITY;
                    C->arcs[C->CityNum - 1][j].FTime = INFINITY;
                    C->arcs[C->CityNum - 1][j].FPrice = INFINITY;
                }
                C->arcs[j][C->CityNum - 1] = C->arcs[C->CityNum - 1][j];
            }
        }
      change = 1;
    }
}

Status DelCity(City *C){//刪除
    int i,j,k,n,error = 1;
    char *tname[MAX_VERTEX_NUM],*tname1[MAX_VERTEX_NUM];
    while(1){
        printf("del city or traffic way[ 1 or 2 ][ other num;return ]:  ");
        k = getchar();
        scanf("%d",&k);
        if(k == 1){
            printf("input the city name you want to del:  ");
            scanf("%s",&tname);
            for(i = 0;i < C->CityNum; i++)
                if(strcmp(C->name[i],tname) == 0){
                    for(j = i; j < C->CityNum; j++){
                        strcpy(C->name[j],C->name[j + 1]);
                        for(n = 0; n < C->CityNum; n++){
                            C->arcs[n][j] = C->arcs[n][j + 1];
                        }
                    }
                     for(j = i; j < C->CityNum; j++){
                        for(n = 0; n < C->CityNum; n++){
                            C->arcs[j][n] = C->arcs[j + 1][n];
                        }
                    }
                }
                C->CityNum = C->CityNum - 1;
                error = 0;
                change = 1;
            if(error == 1) ShowError(2);
         }
        else if(k == 2){
            printf("input two city name of the way:  ");
            scanf("%s%s",&tname,&tname1);

            for(i = 0;i < C->CityNum; i++)
                if(strcmp(C->name[i],tname) == 0)
                    for(j = 0;j < C->CityNum; j++)
                        if(strcmp(C->name[j],tname1) == 0){
                            C->arcs[i][j].TTime = INFINITY;
                            C->arcs[i][j].TPrice = INFINITY;
                            C->arcs[i][j].FTime = INFINITY;
                            C->arcs[i][j].FPrice = INFINITY;
                            C->arcs[j][i] = C->arcs[i][j];
                            error = 0;
                            change = 1;
                        }
            if(error == 1) ShowError(2);
        }
        else break;
    }
}

Status EditCity(City *C){//修改
    int i,j,k,error = 1;
    char *tname[MAX_VERTEX_NUM],*tname1[MAX_VERTEX_NUM];
    while(1){
        printf("change name or traffic[ 1 or 2 ][ other num;return ]:  ");
        scanf("%d",&k);
        if(k == 1){
            printf("input the city name you want to change:  ");
            scanf("%s",&tname);
            for(i = 0;i < C->CityNum; i++)
                if(strcmp(C->name[i],tname) == 0){
                    printf("input the new name[%s]:",C->name[i]);
                    scanf("%s",C->name[i]);
                    change = 1;
                    error = 0;
                }
            if(error == 1) ShowError(2);
        }
        else if(k == 2){
            printf("input two city name of the way you want del:  ");
            scanf("%s%s",&tname,&tname1);

            for(i = 0;i < C->CityNum; i++)
                if(strcmp(C->name[i],tname) == 0)
                    for(j = 0;j < C->CityNum; j++)
                        if(strcmp(C->name[j],tname1) == 0){
                            printf("input new TTime,TPrice,FTime,FPrice [%s->%s]: ",C->name[i],C->name[j]);
                            scanf("%d%d%d%d",&C->arcs[i][j].TTime,&C->arcs[i][j].TPrice,&C->arcs[i][j].FTime,&C->arcs[i][j].FPrice);
                            C->arcs[j][i] = C->arcs[i][j];
                            error = 0;
                            change = 1;
                        }
            if(error == 1) ShowError(2);
        }
        else break;
    }
}

Status ShortestPath(City *C){//最小路徑
    int i,k,error = 1;
    char *tname[MAX_VERTEX_NUM];
    printf("input the frist city name and type[1 by TTime,2 by TPrice,3 by FTime,4 by FPrice]: \n");
    printf("input as [name,0] to show city name!\n");
    scanf("%s%d",&tname,&k);
    if(k < 1 || k > 4) ShowCityName(C,k);
    else{
        for(i = 0;i < C->CityNum; i++)
            if(strcmp(C->name[i],tname) == 0){
                error = 0;
                ShortestPath_DIJ(C,i,k);
            }
        if(error == 1) ShowError(2);
    }
}

Status ShortestPath_DIJ(City *C,int v0,int k){// 求源點v0到各點的最短路徑 1火車時間最小,2火車金錢最小,3飛機時間最小,4飛機金錢最小,
    int D[MAX_VERTEX_NUM],final[MAX_VERTEX_NUM],i,w,v=0,min;
    LinkQueue Q[MAX_VERTEX_NUM];// 建立隊列數組,用以依次儲存最短的路徑
    for(i = 0; i < C->CityNum; ++i){// 初始化數組
        InitQueue(&Q[i]);
        if(k == 1)D[i] = C->arcs[v0][i].TTime;
        if(k == 2)D[i] = C->arcs[v0][i].TPrice;
        if(k == 3)D[i] = C->arcs[v0][i].FTime;
        if(k == 4)D[i] = C->arcs[v0][i].FPrice;
        final[i] = false;
    }
    final[v0] = true;

    for(i = 1;i < C->CityNum; ++i){// 一個一個循環找出最短距離(共CityNum-1個)
        min = INFINITY;
        for(w = 0;w < C->CityNum; ++w){// 掃描找出非final集中最小的D[]
            if(!final[w] && D[w] < min){
                v = w;
                min = D[w];
            }
        }
        final[v] = true;

        for(w = 0;w < C->CityNum; ++w){// 更新各D[]數據
            if(k == 1) if(!final[w] && C->arcs[v][w].TTime + min < D[w]){
                D[w] = C->arcs[v][w].TTime + min;
                CopyQueue(&Q[v],&Q[w]);
                EnQueue(&Q[w],v);
            }
            if(k == 2) if(!final[w] && C->arcs[v][w].TPrice + min < D[w]){
                D[w] = C->arcs[v][w].TPrice + min;
                CopyQueue(&Q[v],&Q[w]);
                EnQueue(&Q[w],v);
            }
            if(k == 3) if(!final[w] && C->arcs[v][w].FTime + min < D[w]){
                D[w] = C->arcs[v][w].FTime + min;
                CopyQueue(&Q[v],&Q[w]);
                EnQueue(&Q[w],v);
            }
            if(k == 4) if(!final[w] && C->arcs[v][w].FPrice + min < D[w]){
                D[w] = C->arcs[v][w].FPrice + min;
                CopyQueue(&Q[v],&Q[w]);
                EnQueue(&Q[w],v);
           }
        }
    }

  // 打印出結果
    printf("frist -> end \t last \t\tthe-way\n\n");
    for(i  =0;i < C->CityNum; i++){
        if(D[i] != INFINITY){
            printf("%5s -> %s\t%d \t\t%s",C->name[v0],C->name[i],D[i],C->name[v0]);
            while(!EmptyQueue(&Q[i])){
                DeQueue(&Q[i],v);
                printf(" -> %s",C->name[v]);
            }
            printf(" -> %s\n",C->name[i]);
        }
        else{
            printf("%5s -> %s\tNo path!\n",C->name[v0],C->name[i]);
        }
   }
}

Status LoadCity(City *C){// 載入數據
    FILE *fp; // 文件指針
    char jian;
    int flag = 1;
    fp = fopen("City.city","rb");
    if(fp == NULL){
        printf("\ndate file is not find,buding?(y/n)\n");
        scanf("%c",&jian);
        if(jian == 'y'||jian == 'Y') fp = fopen("City.city","wb");
        else ShowError(1);
    }
    printf("\n=====>file is find,opening...\n");
    if(fread(C,sizeof(City),1,fp) != 1) flag = 0;
    if(flag){
        printf("\n=====>finish.\n");
        change = 0;
        }
     fclose(fp); // 關閉文件  
}

Status SaveCity(City *C){//  保存數據
    FILE* fp;
    int flag = 1;
    fp=fopen("City.city","wb");
    if(fp == NULL) ShowError(1);
    if(fwrite(C,sizeof(City),1,fp) != 1) flag = 0;
    if(flag){
        printf("\n=====>finish.");
        change = 0;
        }
    fclose(fp);
}

Status ShowCityDat(City *C){//顯示圖
    int k;
    printf("input show dat type[ 1TTime,2TPrice,3FTime,4FPrice ]:");
    scanf("%d",&k);
    if(k > 0 && k < 5) ShowCityName(C,k);
    else ShowError(2);
}

Status ShowCityName(City *C,int k){//顯示城市名與相應矩陣
    int i,j;
    if(k < 1 || k > 4) for(i = 0;i < C->CityNum; i++) printf("%6s  ",C->name[i]);
    else{
        printf("      ");
        for(i = 0;i < C->CityNum; i++) printf("%6s  ",C->name[i]);
        printf("\n");
        for(i = 0;i < C->CityNum; i++){
            printf("%6s  ",C->name[i]);
            for(j = 0;j < C->CityNum; j++){
                if(C->arcs[i][j].TTime == INFINITY) printf("   -\t");
                else{
                    if(k == 1)printf("%4d\t",C->arcs[i][j].TTime );
                    if(k == 2)printf("%4d\t",C->arcs[i][j].TPrice );
                    if(k == 3)printf("%4d\t",C->arcs[i][j].FTime );
                    if(k == 4)printf("%4d\t",C->arcs[i][j].FPrice );
                }
            }
            printf("\n");
        }
    }
}

Status ShowError(int k){//顯示錯誤
    switch(k){
        case 0:printf("\nMemory Failure!\nplease any key exit!");getch();exit(0);break;
        case 1:printf("\nfile error!\nplease any key exit!");getch();exit(0);break;
        case 2:printf("\ninput city not find!\n");break;
        default:getchar();break;
    }
}

Status showmenu(){//顯示目錄
    printf("\n1:ShowCityDat");
    printf("\n2:AddCity");
    printf("\n3:CreateCity");
    printf("\n4:EditCity");
    printf("\n5:DelCity");
    printf("\n6:ShortestPath");
    printf("\n7:LoadCity");
    printf("\n8:SaveCity");
    printf("\n0:exit\n");
}

main(){
    City *C;
    int set;
    char ch;
    if(!(C = (City *)malloc(sizeof(City)))) ShowError(0);

    LoadCity(C);
    while(1){
        showmenu();
        printf("please input the menu:");
        scanf("%d",&set);
        if(set == 0){
            if(change == 1){
                getchar();
                printf("\n=====>the dat is changed,save?(y/n)?\n");
                scanf("%c",&ch);
                if(ch=='y'||ch=='Y')
                SaveCity(C);
            }
            break;
        }
        switch(set){
            case 1:ShowCityDat(C);break; // 增加
            case 2:AddCity(C);break; // 增加
            case 3:CreateCity(C);break;//重來
            case 4:EditCity(C);break;// 修改
            case 5:DelCity(C);break;//刪除
            case 6:ShortestPath(C);break;// 查看
            case 7:LoadCity(C);break;//載入文件
            case 8:SaveCity(C);break;// 保存
            default: getchar();break;
        }
    }
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲欧美日韩一区二区三区在线观看| 欧美va日韩va| 91久久精品一区二区三区| 精品国产乱码久久久久久1区2区| 一本大道久久a久久综合婷婷| 国产伦理精品不卡| 韩国v欧美v日本v亚洲v| 精品写真视频在线观看| 国产真实乱偷精品视频免| 美女视频一区二区| 久久99精品一区二区三区| 久久99久久99小草精品免视看| 美女视频免费一区| 国产精品一卡二卡| 成人爱爱电影网址| 99精品欧美一区二区三区小说 | 91麻豆6部合集magnet| 成人中文字幕电影| 色婷婷亚洲婷婷| 欧美另类久久久品| 精品久久久三级丝袜| 国产欧美日韩在线看| 日韩毛片视频在线看| 亚洲午夜精品在线| 激情综合色丁香一区二区| 国产suv精品一区二区三区| 92国产精品观看| 欧美艳星brazzers| 久久精品一区二区三区av| 亚洲人精品午夜| 人妖欧美一区二区| 国产91丝袜在线播放九色| 在线观看欧美黄色| 欧美精品一区二区三区久久久| 国产精品三级av| 性久久久久久久| 国产成人午夜高潮毛片| 欧美午夜精品免费| 国产亚洲欧美一区在线观看| 亚洲国产成人av网| 成熟亚洲日本毛茸茸凸凹| 欧美日韩国产一区| 国产欧美精品一区二区色综合朱莉| 中文字幕日韩一区二区| 久久国产综合精品| 91理论电影在线观看| 国产午夜精品一区二区三区视频| 亚洲人成网站色在线观看| 国产在线视视频有精品| 欧美日韩黄色一区二区| 最新国产の精品合集bt伙计| 麻豆91在线播放免费| 欧美日韩国产小视频在线观看| 精品久久久久久久久久久久包黑料| 亚洲黄色免费网站| 成人激情黄色小说| 国产亚洲自拍一区| 久久99精品久久久久久久久久久久| 欧美日韩夫妻久久| 亚洲国产成人tv| 欧美亚洲另类激情小说| 亚洲丝袜美腿综合| 丰满少妇久久久久久久| www国产精品av| 蜜臀av性久久久久蜜臀aⅴ流畅| 在线观看日韩av先锋影音电影院| 国产精品久久国产精麻豆99网站| 国产精品一区2区| 久久亚洲一区二区三区明星换脸| 美女网站色91| 欧美精品一区二区三区一线天视频| 日本sm残虐另类| 欧美一三区三区四区免费在线看 | 亚洲va韩国va欧美va精品| 91视频在线观看| 亚洲欧美日韩国产综合在线 | 91精品福利视频| 怡红院av一区二区三区| 色综合天天综合色综合av| 中文字幕av一区二区三区| 国产精品一二三| 中文字幕精品—区二区四季| 成人黄色777网| 亚洲美女在线国产| 欧美人与性动xxxx| 蜜臀久久99精品久久久久久9| 欧美mv日韩mv国产网站app| 精品一区二区在线视频| 国产欧美日本一区视频| 一本色道久久综合亚洲91| 亚洲自拍另类综合| 日韩欧美中文字幕一区| 国产精品一区二区在线观看网站| 久久久久久免费网| 99久久精品国产毛片| 亚洲妇熟xx妇色黄| 欧美成人免费网站| 国产成人aaa| 一区二区三区欧美视频| 欧美一区二区精品在线| 99国产精品久| 亚洲成人自拍一区| 久久亚洲精品小早川怜子| 91啪在线观看| 日本中文在线一区| 中文字幕巨乱亚洲| 欧美日韩不卡一区二区| 韩日欧美一区二区三区| 亚洲欧洲成人自拍| 欧美一级夜夜爽| av一区二区三区四区| 亚洲成av人片一区二区三区| 久久久久久夜精品精品免费| 欧美中文字幕不卡| 国产麻豆精品一区二区| 亚洲成人午夜电影| 亚洲国产高清aⅴ视频| 91精品欧美福利在线观看| 成人99免费视频| 激情伊人五月天久久综合| 亚洲欧美精品午睡沙发| 26uuu国产在线精品一区二区| 91蜜桃视频在线| 国产麻豆视频一区二区| 午夜精品福利一区二区三区av| 国产日韩成人精品| 日韩一二三区视频| 在线观看日韩av先锋影音电影院| 国产老妇另类xxxxx| 视频一区中文字幕| 亚洲综合一区二区精品导航| 国产精品你懂的在线欣赏| 欧美videos大乳护士334| 欧美三级欧美一级| 91免费版在线| 国产**成人网毛片九色 | 亚洲午夜在线视频| 亚洲国产成人自拍| 国产亚洲短视频| 精品少妇一区二区三区日产乱码 | 亚洲一区在线观看视频| 欧美激情一区二区三区| 日韩一区二区三区免费观看| 欧美日韩国产区一| 欧美视频一区二| 色吊一区二区三区| 91蜜桃在线观看| 一本色道久久综合亚洲aⅴ蜜桃 | 久久久青草青青国产亚洲免观| 欧美一区二视频| 制服丝袜国产精品| 日韩手机在线导航| 日韩一二三四区| 精品国产区一区| 精品国产91九色蝌蚪| 日韩欧美国产三级电影视频| 日韩午夜在线影院| 精品久久久久一区二区国产| 日韩欧美中文字幕制服| 精品日韩成人av| 久久久久免费观看| 国产精品无码永久免费888| 国产精品女同互慰在线看| 国产精品精品国产色婷婷| 国产精品的网站| 亚洲精品免费电影| 亚洲一区二区欧美| 美日韩一级片在线观看| 精品一区二区三区不卡| 国产高清无密码一区二区三区| 色婷婷av一区二区三区之一色屋| 91在线观看地址| 欧美日韩亚洲丝袜制服| 日韩一区二区精品葵司在线| 欧美tickling网站挠脚心| 日本一区二区三区国色天香 | 日韩不卡一区二区三区 | 99国产精品国产精品久久| 在线观看国产一区二区| 日韩一区二区三区四区 | 亚洲午夜视频在线观看| 蜜臀国产一区二区三区在线播放 | 香蕉加勒比综合久久| 欧美a级理论片| 成人美女在线视频| 欧美视频日韩视频| 亚洲精品一区在线观看| 最新久久zyz资源站| 日韩高清国产一区在线| 成人久久视频在线观看| 欧美日韩国产高清一区二区| 久久色在线视频| 亚洲一区二区三区中文字幕| 激情国产一区二区| 欧美午夜一区二区三区| 国产日产精品1区| 亚洲成av人影院| av电影在线观看完整版一区二区| 在线播放国产精品二区一二区四区| 久久久精品影视|