麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > 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:雖然本人的方法有一些愚見,本人就拋磚引玉了

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 成人在线高清视频 | 2021狠狠操 | 成人做爰高潮片免费视频韩国 | 蜜桃一本色道久久综合亚洲精品冫 | 草人人| 免费a级网站 | 免费观看视频91 | 国产精品久久久久久久久久久久久久久 | 精国品产一区二区三区有限公司 | 久久久久久91 | 国产成人av在线 | 亚洲九色 | 欧美一级美片在线观看免费 | 国产永久免费观看 | 逼片 | 少妇av片 | 久久色伦理资源站 | 欧美不卡 | 成人羞羞视频在线观看 | 中文字幕免费播放 | www.91成人| 国产91丝袜在线播放 | 国产亚洲精品久久久久久大师 | 久久超| 久久久久久久久成人 | 91精品国产乱码久 | 182tv成人福利视频免费看 | 欧美精品网址 | 久久人人爽人人爽人人片av高清 | 色婷婷av一区二区三区久久 | 久久久久国产成人免费精品免费 | 欧美黑大粗硬毛片视频 | 国产一区二区在线观看视频 | 羞羞电影网 | 久久国产秒 | 中文字幕 日本 | 精品久久久久久中文字幕 | 中文字幕线观看 | 性生活视频一级 | 91av日韩 | 久久最新网址 |