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

首頁 > 編程 > .NET > 正文

.net 反序題目的詳細解答第1/2頁

2020-01-18 01:14:54
字體:
來源:轉載
供稿:網友
請將方法補充完整:
復制代碼 代碼如下:

static void Reverse(int[] array, int begin, int end)
{
...
}

Reverse方法的作用是將array數組中,從begin下標到end下標之間的元素反序一下,如一個數組初始值是[1, 2, 3, 4, 5, 6],begin為1,end為4,那么當調用了Reverse之后,array數組中的元素便依次成為[1, 5, 4, 3, 2, 6],其中從array[1]到array[4]之前的元素被反序了。此外補充一點……其實本不用補充:這個方法需要對傳入參數的正確性進行校驗,如果用戶調用該方法時傳入了非法的參數,那么則需要拋出異常,并寫清原因。您可以使用您喜歡的語言來實現:C#,VB,Java,Ruby,Python……但是請不要使用內置庫中已經有的功能。:)

  很簡單,不是嗎?只可惜截止到目前,也只有1人給出了正確答案。如果您沒有做過這道題目,那么在查看下面的分析之前,不妨拿張紙拿支筆,寫下您的答案,然后再聽老趙慢慢講來…

主體邏輯
  這道題目的主題邏輯其實非常簡單。不就是把數組中的一部分反序嗎?不過從這一點上面來說,代碼的清晰程度也有較大差距。好的做法和普通的做法,從編程難度和理解上都有一定差距。例如:

1、許多朋友的做法是:既然是反轉數組的一部分元素,那么只要找到中間的位置,然后計算出和begin的偏移量,然后……怎么怎么一搞,就完成了――嗯,似乎還需要根據進行begin和end中間的元素個數是奇數還是偶數分別處理。

2、另一些朋友的做法是:開一個新數組(長度為end - begin + 1),將begin到end之間的元素放到新數組中去,然后反序,然后再復制回來。

3、還有一個朋友認為用棧:把begin到end之間的元素給push到棧中,再一個一個pop出來依次賦值給begin到end,這樣就反序了……唔!數據結構學的不錯!

  只可惜,這樣的做法都復雜了一些。3種做法的時間復雜度均為O(end 主站蜘蛛池模板: 保定市| 顺平县| 和田市| 晋中市| 大足县| 临澧县| 溆浦县| 福泉市| 西盟| 乾安县| 登封市| 宜宾市| 邛崃市| 泰宁县| 囊谦县| 洛宁县| 石渠县| 郯城县| 宁晋县| 襄樊市| 微博| 邵阳市| 中西区| 定南县| 华蓥市| 韶关市| 云南省| 宽甸| 游戏| 奎屯市| 育儿| 新源县| 嘉鱼县| 沈丘县| 陆良县| 凤山市| 滁州市| 元阳县| 大同县| 德清县| 阜南县|