面試題 16 11 跳水板

2021-10-07 21:24:21 字數 618 閱讀 1677

題目描述:

你正在使用一堆木板建造跳水板。有兩種型別的木板,其中長度較短的木板長度為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...