安卓手機(jī)做網(wǎng)站seo建站平臺哪家好
給你一個下標(biāo)從 0 開始的整數(shù)數(shù)組 nums 和一個整數(shù) k 。你需要執(zhí)行以下操作 恰好 k 次,最大化你的得分:
從 nums 中選擇一個元素 m 。
將選中的元素 m 從數(shù)組中刪除。
將新元素 m + 1 添加到數(shù)組中。
你的得分增加 m 。
請你返回執(zhí)行以上操作恰好 k 次后的最大得分。
示例 1:
輸入:nums = [1,2,3,4,5], k = 3
輸出:18
解釋:我們需要從 nums 中恰好選擇 3 個元素并最大化得分。
第一次選擇 5 。和為 5 ,nums = [1,2,3,4,6] 。
第二次選擇 6 。和為 6 ,nums = [1,2,3,4,7] 。
第三次選擇 7 。和為 5 + 6 + 7 = 18 ,nums = [1,2,3,4,8] 。
所以我們返回 18 。
18 是可以得到的最大答案。
示例 2:
輸入:nums = [5,5,5], k = 2
輸出:11
解釋:我們需要從 nums 中恰好選擇 2 個元素并最大化得分。
第一次選擇 5 。和為 5 ,nums = [5,5,6] 。
第二次選擇 6 。和為 6 ,nums = [5,5,7] 。
所以我們返回 11 。
11 是可以得到的最大答案。
提示:
1 <= nums.length <= 100
1 <= nums[i] <= 100
1 <= k <= 100
直接找出數(shù)組中的最大值,然后重復(fù)k次題目操作即可:
class Solution {
public:int maximizeSum(vector<int>& nums, int k) {int maxNum = *max_element(nums.begin(), nums.end());return (maxNum + maxNum + k - 1) * k / 2;}
};