亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > C# > 正文

C#中 城市線路圖的純算法以及附帶求極權值

2020-01-24 03:25:37
字體:
來源:轉載
供稿:網友

之前看了很多關于圖的遍歷的代碼

今天我用了常用的數據結構寫出來 純屬于算法 性方面還有待提高 時間復雜度最壞情況下O(2^n)  最優:O(n^2)

線路圖為雙向 帶有權值  比如A-B距離是5000km 那么B-A有可能不是5000km 所以我在LoadData方法時候沒做交換變量直接存放在集合里面

以起點遞歸查找下一連接點并返回當作起點節點查找      代碼雖然有些亂 本想調整 !

復制代碼 代碼如下:

  static List<string[]> maindata = null;
        static int isend = 1;
        static List<string> fresult = new List<string>();

        static void Main(string[] args)
        {
            string begin = "重慶";
            string end = "廈門";
            LoadData();
            Program pl = new Program();
            List<string> beginlist = new List<string>();
            beginlist.Add(begin);
            pl.GetF(beginlist);

            foreach (string a in fresult)
                Console.WriteLine(a);
            Console.WriteLine(fresult.Count);
            //main data end

            List<string> searchlist = new List<string>();
            string temp = "";
            foreach (string f in fresult)
            {
                if (f.IndexOf(end) > -1)
                {
                    temp = f.Substring(0, f.LastIndexOf(end) + end.Length);
                    if (searchlist.Contains(temp) == false)
                        searchlist.Add(temp);
                }
            }
            Console.WriteLine(begin + "------------->" + end + ":");
            foreach (string a in searchlist)
                Console.WriteLine(a);
            Console.WriteLine(searchlist.Count);
            //search data   A to B

            string a1 = "權最大為:" + GetMaxQuk(searchlist);
            Console.WriteLine(a1);
            a1 = "權最小為:" + GetMinQuk(searchlist);
            Console.WriteLine(a1);

            Console.ReadKey();
        }

  取最大的權值數據
        private static string GetMaxQuk(List<string> nage)
        {
            string resultsrt = "";

            string[] nagearry = null;
            int val, maxval = 0;
            for (int s = 0; s < nage.Count; s++)
            {
                nagearry = nage[s].Split('-');//s個數組
                val = GetVal(nagearry);
                if (val > maxval)
                {
                    maxval = val;
                    resultsrt = nage[s] + ":" + val;
                }
                nagearry = null;
            }
            return resultsrt;
        }

取最小的權值數據
        private static string GetMinQuk(List<string> nage)
        {
            string resultsrt = "";
            string[] nagearry = null;
            int val, minval = int.MaxValue;
            for (int s = 0; s < nage.Count; s++)
            {
                nagearry = nage[s].Split('-');//s個數組
                val = GetVal(nagearry);
                if (val < minval)
                {
                    minval = val;
                    resultsrt = nage[s] + ":" + val;
                }
                nagearry = null;
            }
            return resultsrt;
        }

  具體取權值的方法
        private static int GetVal(string[] findarry)
        {
            int val = 0;
            for (int ss = 0; ss < findarry.Length - 1; ss = ss + 1)
            {
                foreach (string[] aa in maindata)
                {
                    if (aa[0] == findarry[ss] && aa[1] == findarry[ss + 1])
                    {
                        val += Convert.ToInt32(aa[2]);
                        break;
                    }
                }
            }
            return val;
        }

        List<string> GetF(List<string> beginlist)
        {
           //此處省略幾十行代碼 需要完整代碼請聯系an
            if (isend == 0)
                return GetF(returnlist);
            else
                return null;
        }

加載綁定數據
       static void LoadData()
       {
            List<string[]> backlist = null;
            string[] arry = null;

            backlist = new List<string[]>();

            arry = new string[3];
            arry[0] = "重慶";
            arry[1] = "北京";
            arry[2] = "3000";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "重慶";
            arry[1] = "廣州";
            arry[2] = "2500";
            backlist.Add(arry);
            arry = null;

            arry = new string[3];
            arry[0] = "北京";
            arry[1] = "重慶";
            arry[2] = "3000";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "北京";
            arry[1] = "廣州";
            arry[2] = "3100";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "北京";
            arry[1] = "長沙";
            arry[2] = "2800";
            backlist.Add(arry);
            arry = null;

            arry = new string[3];
            arry[0] = "長沙";
            arry[1] = "北京";
            arry[2] = "2800";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "長沙";
            arry[1] = "廣州";
            arry[2] = "1500";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "長沙";
            arry[1] = "廈門";
            arry[2] = "800";
            backlist.Add(arry);
            arry = null;

            arry = new string[3];
            arry[0] = "廣州";
            arry[1] = "重慶";
            arry[2] = "2500";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "廣州";
            arry[1] = "北京";
            arry[2] = "3100";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "廣州";
            arry[1] = "長沙";
            arry[2] = "1500";
            backlist.Add(arry);
            arry = null;
            maindata = backlist;

 
            arry = new string[3];
            arry[0] = "廈門";
            arry[1] = "長沙";
            arry[2] = "800";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "廈門";
            arry[1] = "廣州";
            arry[2] = "500";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "廣州";
            arry[1] = "廈門";
            arry[2] = "500";
            backlist.Add(arry);
            arry = null;

 
            arry = new string[3];
            arry[0] = "廣州";
            arry[1] = "云南";
            arry[2] = "3200";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "云南";
            arry[1] = "廣州";
            arry[2] = "3200";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "云南";
            arry[1] = "長沙";
            arry[2] = "3500";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "長沙";
            arry[1] = "云南";
            arry[2] = "3500";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "云南";
            arry[1] = "廈門";
            arry[2] = "5400";
            backlist.Add(arry);
            arry = null;
            arry = new string[3];
            arry[0] = "廈門";
            arry[1] = "云南";
            arry[2] = "5400";
            backlist.Add(arry);
            arry = null;

        }
 


以下是測試結果:
復制代碼 代碼如下:

以重慶開始的所以可能路線

//全部線路圖 begin
重慶-北京
重慶-廣州
重慶-北京-廣州
重慶-北京-長沙
重慶-廣州-北京
重慶-廣州-長沙
重慶-廣州-廈門
重慶-廣州-云南
重慶-北京-廣州-長沙
重慶-北京-廣州-廈門
重慶-北京-廣州-云南
重慶-北京-長沙-廣州
重慶-北京-長沙-廈門
重慶-北京-長沙-云南
重慶-廣州-北京-長沙
重慶-廣州-長沙-北京
重慶-廣州-長沙-廈門
重慶-廣州-長沙-云南
重慶-廣州-廈門-長沙
重慶-廣州-廈門-云南
重慶-廣州-云南-長沙
重慶-廣州-云南-廈門
重慶-北京-廣州-長沙-廈門
重慶-北京-廣州-長沙-云南
重慶-北京-廣州-廈門-長沙
重慶-北京-廣州-廈門-云南
重慶-北京-廣州-云南-長沙
重慶-北京-廣州-云南-廈門
重慶-北京-長沙-廣州-廈門
重慶-北京-長沙-廣州-云南
重慶-北京-長沙-廈門-廣州
重慶-北京-長沙-廈門-云南
重慶-北京-長沙-云南-廣州
重慶-北京-長沙-云南-廈門
重慶-廣州-北京-長沙-廈門
重慶-廣州-北京-長沙-云南
重慶-廣州-長沙-廈門-云南
重慶-廣州-長沙-云南-廈門
重慶-廣州-廈門-長沙-北京
重慶-廣州-廈門-長沙-云南
重慶-廣州-廈門-云南-長沙
重慶-廣州-云南-長沙-北京
重慶-廣州-云南-長沙-廈門
重慶-廣州-云南-廈門-長沙
重慶-北京-廣州-長沙-廈門-云南
重慶-北京-廣州-長沙-云南-廈門
重慶-北京-廣州-廈門-長沙-云南
重慶-北京-廣州-廈門-云南-長沙
重慶-北京-廣州-云南-長沙-廈門
重慶-北京-廣州-云南-廈門-長沙
重慶-北京-長沙-廣州-廈門-云南
重慶-北京-長沙-廣州-云南-廈門
重慶-北京-長沙-廈門-廣州-云南
重慶-北京-長沙-廈門-云南-廣州
重慶-北京-長沙-云南-廣州-廈門
重慶-北京-長沙-云南-廈門-廣州
重慶-廣州-北京-長沙-廈門-云南
重慶-廣州-北京-長沙-云南-廈門
重慶-廣州-廈門-云南-長沙-北京
重慶-廣州-云南-廈門-長沙-北京
count:61
//全部線路圖 end

 
 搜索重慶到廈門的線路圖
//重慶到廈門begin
重慶-廣州-廈門
重慶-北京-廣州-廈門
重慶-北京-長沙-廈門
重慶-廣州-長沙-廈門
重慶-廣州-云南-廈門
重慶-北京-廣州-長沙-廈門
重慶-北京-廣州-云南-廈門
重慶-北京-長沙-廣州-廈門
重慶-北京-長沙-云南-廈門
重慶-廣州-北京-長沙-廈門
重慶-廣州-長沙-云南-廈門
重慶-廣州-云南-長沙-廈門
重慶-北京-廣州-長沙-云南-廈門
重慶-北京-廣州-云南-長沙-廈門
重慶-北京-長沙-廣州-云南-廈門
重慶-北京-長沙-云南-廣州-廈門
重慶-廣州-北京-長沙-云南-廈門
count:17
權最大為:重慶-廣州-北京-長沙-云南-廈門:17300
權最小為:重慶-廣州-廈門:3000
//重慶到廈門end


最后ps:雖然本人的方法有一些愚見,本人就拋磚引玉了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情视频一区二区| 欧洲成人在线观看| 久久激情视频免费观看| 欧美成人亚洲成人日韩成人| 日韩精品在线免费| 色偷偷av一区二区三区乱| 久久久亚洲成人| 国产日韩欧美影视| 伊人一区二区三区久久精品| 国产99久久精品一区二区 夜夜躁日日躁| 欧美一级视频在线观看| 57pao成人永久免费视频| 欧美巨猛xxxx猛交黑人97人| 91色p视频在线| 国产精品美女无圣光视频| 91久久精品国产91性色| 亚洲国产成人精品电影| 亚洲精品久久久久| 精品欧美激情精品一区| 91国自产精品中文字幕亚洲| 亚洲免费av网址| 国产精品自产拍高潮在线观看| 久久国产精品99国产精| 亚洲精品资源在线| 国产精品99久久久久久www| 亚洲国产精品99| 日韩欧美精品网址| 国产国语videosex另类| 疯狂做受xxxx高潮欧美日本| 91在线免费看网站| 欧美黑人国产人伦爽爽爽| 亚洲sss综合天堂久久| 热门国产精品亚洲第一区在线| 久久精品久久精品亚洲人| 国产日韩欧美日韩| 欧美激情喷水视频| 狠狠久久亚洲欧美专区| 亚洲欧美日本精品| 欧美精品一区二区三区国产精品| 成人国产亚洲精品a区天堂华泰| 这里精品视频免费| 日韩av在线最新| 精品国产自在精品国产浪潮| 国产精品户外野外| 欧美性猛交xxxxx水多| 精品动漫一区二区三区| 久久久在线免费观看| 欧美高清视频一区二区| 亚洲精品免费一区二区三区| 久久久久久久久国产| 国产乱人伦真实精品视频| 亚洲色图校园春色| 97在线精品视频| 国产精品美女免费| 国产中文欧美精品| 成人欧美一区二区三区黑人孕妇| 欧美激情精品久久久久久久变态| 亚洲一区二区三区成人在线视频精品| 亚洲精品v欧美精品v日韩精品| 日本成人精品在线| 亚洲成av人影院在线观看| 亚洲精品久久久久国产| 在线播放国产一区中文字幕剧情欧美| 久热精品视频在线| 欧美区二区三区| 91在线无精精品一区二区| 91精品久久久久久久久久久| 51久久精品夜色国产麻豆| 国产精品成人品| 日本精品一区二区三区在线| 久久夜色精品亚洲噜噜国产mv| 日本午夜精品理论片a级appf发布| 欧美一级淫片丝袜脚交| 欧美性极品xxxx做受| 国产精品小说在线| 91免费在线视频网站| 中文日韩电影网站| 国产免费一区二区三区在线能观看| 日本精品va在线观看| www欧美xxxx| 91视频九色网站| 91久热免费在线视频| 亚洲资源在线看| 97av在线视频| 精品呦交小u女在线| 欧美日韩综合视频| 欧美电影免费在线观看| 欧美性资源免费| 粉嫩老牛aⅴ一区二区三区| 91人人爽人人爽人人精88v| 2018日韩中文字幕| 91网站免费观看| 成人精品久久av网站| 国产在线精品成人一区二区三区| 亚洲成人a级网| 日韩大片免费观看视频播放| 欧美成人午夜剧场免费观看| 亚洲国产91精品在线观看| 国产精品视频免费观看www| 91免费的视频在线播放| 亚洲欧美制服中文字幕| 欧美性猛交xxxx乱大交蜜桃| 欧美电影免费播放| 国产精品极品在线| 国产精品久久久久久久久久久久久| 在线成人一区二区| 国产成人黄色av| 日韩中文在线视频| 色综合天天综合网国产成人网| 在线播放日韩欧美| 57pao国产精品一区| 亚洲精品国产精品国自产观看浪潮| 青青草国产精品一区二区| 久久夜色精品国产欧美乱| 疯狂做受xxxx欧美肥白少妇| 国产91免费看片| 欧美成人剧情片在线观看| 国产精品一二三视频| 欧美福利视频在线观看| 国产成人91久久精品| 欧美国产日韩一区二区| 国产免费久久av| 欧美超级乱淫片喷水| 亚洲综合第一页| 精品日韩美女的视频高清| 国产免费观看久久黄| 欧美综合国产精品久久丁香| 亚洲成年人在线播放| 国产精品稀缺呦系列在线| 97不卡在线视频| 中文字幕日韩综合av| 97福利一区二区| 尤物yw午夜国产精品视频明星| 亚洲午夜色婷婷在线| 欧美激情一区二区三区久久久| 亚洲深夜福利视频| 欧美一区二粉嫩精品国产一线天| 啊v视频在线一区二区三区| 久久久久久亚洲| 国产精品高清免费在线观看| 久久人体大胆视频| 亚洲国产日韩欧美在线99| 美女啪啪无遮挡免费久久网站| 日本亚洲精品在线观看| 国产精品高清免费在线观看| 播播国产欧美激情| 日本精品一区二区三区在线播放视频| 国产久一一精品| 2018日韩中文字幕| 国内精品久久久| 欧美精品久久久久久久免费观看| 亚洲第一视频网| 亚洲天堂av综合网| 亚洲a∨日韩av高清在线观看| 欧美国产日韩免费| 亚洲香蕉伊综合在人在线视看| 国产精品视频一区二区高潮| 精品视频久久久久久久| 日本亚洲精品在线观看| 国产啪精品视频| www.色综合| 日韩电视剧免费观看网站| 亚洲第一区中文字幕| 日韩视频免费观看|