首页 > 其他 > 详细

1558. Minimum Numbers of Function Calls to Make Target Array

时间:2020-08-30 13:56:49      阅读:49      评论:0      收藏:0      [点我收藏+]

技术分享图片

Your task is to form an integer array nums from an initial array of zeros arr that is the same size as nums.

Return the minimum number of function calls to make nums from arr.

The answer is guaranteed to fit in a 32-bit signed integer.

 

Example 1:

Input: nums = [1,5]
Output: 5
Explanation: Increment by 1 (second element): [0, 0] to get [0, 1] (1 operation).
Double all the elements: [0, 1] -> [0, 2] -> [0, 4] (2 operations).
Increment by 1 (both elements)  [0, 4] -> [1, 4] -> [1, 5] (2 operations).
Total of operations: 1 + 2 + 2 = 5.

Example 2:

Input: nums = [2,2]
Output: 3
Explanation: Increment by 1 (both elements) [0, 0] -> [0, 1] -> [1, 1] (2 operations).
Double all the elements: [1, 1] -> [2, 2] (1 operation).
Total of operations: 2 + 1 = 3.

Example 3:

Input: nums = [4,2,5]
Output: 6
Explanation: (initial)[0,0,0] -> [1,0,0] -> [1,0,1] -> [2,0,2] -> [2,1,2] -> [4,2,4] -> [4,2,5](nums).

Example 4:

Input: nums = [3,2,2,4]
Output: 7

Example 5:

Input: nums = [2,4,8,16]
Output: 8

 

Constraints:

  • 1 <= nums.length <= 10^5
  • 0 <= nums[i] <= 10^9
class Solution {
    public int minOperations(int[] nums) {
        int res = 0, n = nums.length;
        while(!allzero(nums)) {
            if(!alleven(nums)) {
               for(int i = 0; i < n; i++) {
                    if(nums[i] % 2 != 0) {
                        nums[i]--;
                        res++;
                    }
                } 
            } 
            else {
                for(int i = 0; i < n; i++) {
                    nums[i] /= 2;
                }
                res++;
            }
        }
        return res;
    }
    public boolean allzero(int[] nums) {
        for(int i : nums) {
            if(i != 0) return false;
        }
        return true;
    }
    public boolean alleven(int[] nums) {
        for(int i : nums) {
            if((i & 1) == 1) return false;
        }
        return true;
    }
}

我不管,我就要brute force

只要不是allzero就循环,先判断是否alleven,再进行操作。

1558. Minimum Numbers of Function Calls to Make Target Array

原文:https://www.cnblogs.com/wentiliangkaihua/p/13584881.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!