国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 學(xué)院 > 開發(fā)設(shè)計(jì) > 正文

一道算法題的一種O(n)解法

2019-11-17 03:49:27
字體:
供稿:網(wǎng)友
很早就有去做做的想法,可是一直沒動手

今天花了點(diǎn)時間搞搞

結(jié)果如下:

核心部分





代碼
1  public List<Result> GetResults(int[] arr)
2         {
3             //輸入有效性檢測
4             if (arr.Length==0)
5                 throw new NotEnoughInputException();
6
7             List<Result> rlist = new List<Result>();
8             
9             //實(shí)際運(yùn)算
10             
11             //初始化起始位置,將第一點(diǎn)當(dāng)作后續(xù)結(jié)果的起點(diǎn)
12             Position startP = new Position(Position.EmptyPosition, arr[0]);
13
14             //當(dāng)前點(diǎn)就當(dāng)作是最大結(jié)果值
15             Result curResult = new Result(Position.EmptyPosition, startP);
16
17             //向結(jié)果列表添加內(nèi)容
18             rlist.Add(curResult);
19
20             //有一個以上的數(shù)據(jù)
21             if (arr.Length > 1)
22             {
23                 Position curP,nextP;
24                 curP=startP;
25                 Result temp;//保存到目前點(diǎn)為止的結(jié)果數(shù)據(jù)
26                 //從第二個點(diǎn)開始逐個判斷
27                 for (int i = 1; i < arr.Length; i++)
28                 {
29                     //構(gòu)造對象
30                     nextP = new Position(curP,arr[i]);
31                     temp = new Result(startP, nextP);
32
33                     //判斷當(dāng)前的和是否大于現(xiàn)有結(jié)果列表中的數(shù)據(jù)
34                     if (temp.RelativeElevation > rlist[0].RelativeElevation)
35                     {//如果大于則清除結(jié)果列表,添加當(dāng)前結(jié)果
36                         rlist.Clear();
37                         rlist.Add(temp);
38                     }
39                     //判斷當(dāng)前的和是否等于現(xiàn)有結(jié)果列表中的數(shù)據(jù)
40                     else if (temp.RelativeElevation == rlist[0].RelativeElevation)
41                     {
42                         rlist.Add(temp);
43                     }
44                     //判斷當(dāng)前是否是一個新的低點(diǎn)
45                     else if(nextP.EndElevation<=startP.StartElevation)
46                     {
47                         startP = nextP;
48                     }
49                     curP = nextP;
50                 }
51             }           
52
53             return rlist;
54         }




代碼還有進(jìn)一步優(yōu)化的余地

主體思想就是模擬一個不斷爬山的人,爬完一遍后要回答那座山和山谷的相對落差最大

完整代碼在此

主要多用了些類,呵呵。

局部代碼有些不好理解,呵呵。比如里面關(guān)于全負(fù)數(shù)的處理。

歡迎拍磚  


發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 垫江县| 沁源县| 清苑县| 双流县| 东光县| 博乐市| 故城县| 苍梧县| 鲁甸县| 谷城县| 磐石市| 常德市| 错那县| 那曲县| 杭锦后旗| 定兴县| 丰城市| 平山县| 德阳市| 彝良县| 沂源县| 钟山县| 深泽县| 黄骅市| 太湖县| 阿克陶县| 沅陵县| 阿克| 西平县| 林甸县| 南溪县| 东兰县| 丰县| 津市市| 榆树市| 天水市| 读书| 庆阳市| 万载县| 肃宁县| 海口市|