題目描述:
你正在使用一堆木板建造跳水板。有兩種型別的木板,其中長度較短的木板長度為shorter,長度較長的木板長度為longer。你必須正好使用k塊木板。編寫乙個方法,生成跳水板所有可能的長度。
返回的長度需要從小到大排列。
示例:
輸入:shorter = 1
longer = 2
k = 3
輸出:
0 < shorter <= longer
0 <= k <= 100000
方法1:
主要思路:
(1)這裡先說兩種特殊的情形,乙個是 k =0,則直接返回空結果即可,另乙個是長短板子相同,則只需返回一種組成情形即可;
(2)一般的情形,可以先計算出長短板子之差,然後將只使用短板子的組成情形壓入結果中,既sum=shorter*k; 隨後,只需逐個新增板子之差,知道新增 k 個即可,就相當於逐漸的從全部短板子過渡到全部的長板子,將每一種組合壓入結果即可;
class
solution
return res;}}
;
面試題 16 11 跳水板
你正在使用一堆木板建造跳水板。有兩種型別的木板,其中長度較短的木板長度為shorter,長度較長的木板長度為longer。你必須正好使用k塊木板。編寫乙個方法,生成跳水板所有可能的長度。返回的長度需要從小到大排列。示例 輸入 shorter 1 longer 2 k 3 輸出 1.遞迴超時 記憶化遞...
面試題 16 11 跳水板
思路比較簡單,但是自己寫的 沒有充分利用數學中的規律,後面自己還排序了,導致耗時比較久。第二份 是leetcode給出的答案,第乙份 是自己寫的,第一次使用assign 迭代器first,迭代器end 注意這裡不一定是vector的迭代器,其他結構的迭代器也是可以的 這個函式的作用是將 first,...
面試題 16 11 跳水板
你正在使用一堆木板建造跳水板。有兩種型別的木板,其中長度較短的木板長度為shorter,長度較長的木板長度為longer。你必須正好使用k塊木板。編寫乙個方法,生成跳水板所有可能的長度。返回的長度需要從小到大排列。示例 輸入 shorter 1 longer 2 k 3 輸出 0 shorter l...