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

首頁 > 編程 > .NET > 正文

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

2024-07-10 12:38:51
字體:
來源:轉載
供稿:網友
請將方法補充完整:
代碼如下:
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 – begin),但是只有第一種做法的空間復雜度是O(1),而后兩者也都是線性的空間復雜度。那么老趙眼里最好的做法是什么呢?
代碼如下:
public static void Reverse(int[] array, int begin, int end)
{
while (end > begin)
{
int temp = array[begin];
array[begin] = array[end];
array[end] = temp;

begin++;
end--;
}
}

end和begin兩個下標從初始值開始依次向中間逼近,每次都交換一下數組中的元素。最終,while在判斷的時候會發現end == begin(begin和end之間總共奇數個元素),或end < begin(begin和end之間總共偶數個元素)。無論哪種情況,都表示反序已經完成。
參數校驗
上面的做法應該說是最簡單的一種,不過實際在評判答案的時候,直接結果正確,老趙都認為是正確的。只可惜,幾乎沒有朋友在“參數校驗”這方面作對。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 孝义市| 兴仁县| 新巴尔虎左旗| 玛多县| 玉环县| 大悟县| 恭城| 汉阴县| 周宁县| 涪陵区| 石渠县| 大名县| 获嘉县| 三门县| 祁连县| 邯郸县| 恭城| 内乡县| 杨浦区| 东乌珠穆沁旗| 齐齐哈尔市| 阿拉善右旗| 临泉县| 石门县| 阿拉善盟| 鄢陵县| 富宁县| 鸡泽县| 梨树县| 张家口市| 吉安市| 富民县| 琼海市| 高青县| 青岛市| 孟连| 顺平县| 容城县| 库伦旗| 阿拉善右旗| 霸州市|