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

來源:互聯網
上載者:User

之前看了很多關於圖的遍曆的代碼

今天我用了常用的資料結構寫出來 純屬於演算法 性方面還有待提高 時間複雜度最壞情況下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:雖然本人的方法有一些愚見,本人就拋磚引玉了

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.