2562. 找出数组的串联值

难度: 简单
来源: 每日一题 2023.10.12

给你一个下标从 0 开始的整数数组 nums

现定义两个数字的 串联 是由这两个数值串联起来形成的新数字。

例如,1549 的串联是 1549
nums串联值 最初等于 0 。执行下述操作直到 nums 变为空:

如果 nums 中存在不止一个数字,分别选中 nums 中的第一个元素和最后一个元素,将二者串联得到的值加到 nums串联值 上,然后从 nums 中删除第一个和最后一个元素。
如果仅存在一个元素,则将该元素的值加到 nums 的串联值上,然后删除这个元素。
返回执行完所有操作后 nums 的串联值。

示例 1:

输入:nums = [7,52,2,4]
输出:596
解释:在执行任一步操作前,nums 为 [7,52,2,4] ,串联值为 0 。
 - 在第一步操作中:
我们选中第一个元素 7 和最后一个元素 4 。
二者的串联是 74 ,将其加到串联值上,所以串联值等于 74 。
接着我们从 nums 中移除这两个元素,所以 nums 变为 [52,2] 。
 - 在第二步操作中: 
我们选中第一个元素 52 和最后一个元素 2 。 
二者的串联是 522 ,将其加到串联值上,所以串联值等于 596 。
接着我们从 nums 中移除这两个元素,所以 nums 变为空。
由于串联值等于 596 ,所以答案就是 596 。

示例 2:

输入:nums = [5,14,13,8,12]
输出:673
解释:在执行任一步操作前,nums 为 [5,14,13,8,12] ,串联值为 0 。 
- 在第一步操作中: 
我们选中第一个元素 5 和最后一个元素 12 。 
二者的串联是 512 ,将其加到串联值上,所以串联值等于 512 。 
接着我们从 nums 中移除这两个元素,所以 nums 变为 [14,13,8] 。
- 在第二步操作中:
我们选中第一个元素 14 和最后一个元素 8 。
二者的串联是 148 ,将其加到串联值上,所以串联值等于 660 。
接着我们从 nums 中移除这两个元素,所以 nums 变为 [13] 。 
- 在第三步操作中:
nums 只有一个元素,所以我们选中 13 并将其加到串联值上,所以串联值等于 673 。
接着我们从 nums 中移除这个元素,所以 nums 变为空。 
由于串联值等于 673 ,所以答案就是 673 。

提示:

  • 1 <= nums.length <= 1000
  • 1 <= nums[i] <= 10^4
class Solution {
    public long findTheArrayConcVal(int[] nums) {

    }
}

分析与题解


  • 双指针移动 + 模拟法

    定义一个双指针, 然后从数组的左右两边往中间移动, 一共会有三种情况.

    • left < right 时, 进行串联操作.

      String numString = "" + nums[left] + nums[right];
      result += Integer.valueOf(numString);
      
    • left = right 时, 直接添加当前的元素.

      result += nums[left];
      
    • left > right 时, 停止遍历操作.

      while(left <= right) {
          ...
      }
      

    接下来, 我们一起看一下整体的实现逻辑, 具体代码如下所示.

    class Solution {
        public long findTheArrayConcVal(int[] nums) {
            int left = 0, right = nums.length - 1;
            long result = 0;
            while(left <= right) {
                if(left == right) {
                    result += nums[left];
                } else {
                    String numString = "" + nums[left] + nums[right];
                    result += Integer.valueOf(numString);
                }
                left++;
                right--;
            }
            return result;
        }
    }
    

    复杂度分析:

    • 时间复杂度: O(nlogU), 一次遍历循环, 时间复杂度与数组长度成线性相关. U表示每一个数字的位数, 转换成字符串的时间复杂度为logU
    • 空间复杂度: O(logU), 数字转字符串的时候需要的空间复杂度为logU.

    结果如下所示.


  • 双指针移动 + 模拟法 (优化)

    由于数字转字符串的时间消耗过长, 所以这里写一个函数, 计算 a , b 两者的 串联值 . 方法也很简单, 这里就不过多叙述了.

    public long twoNumsSumResult(int a, int b) {
        int times = 0;
        int end = b;
        while (end > 0) {
            end /= 10;
            times++;
        }
        return a * (long)Math.pow(10, times) + b;
    }
    

    接下来, 我们一起看一下整体的实现逻辑, 具体代码如下所示.

    class Solution {
        public long findTheArrayConcVal(int[] nums) {
            int left = 0, right = nums.length - 1;
            long result = 0;
            while(left <= right) {
                if(left == right) {
                    result += nums[left];
                } else {
                    result += twoNumsSumResult(nums[left], nums[right]);
                }
                left++;
                right--;
            }
            return result;
        }
        public long twoNumsSumResult(int a, int b) {
            int times = 0;
            int end = b;
            while (end > 0) {
                end /= 10;
                times++;
            }
            return a * (long)Math.pow(10, times) + b;
        }
    }
    

    复杂度分析:

    • 时间复杂度: O(nU), 一次遍历循环, 时间复杂度与数组长度成线性相关. U表示每一个数字的位数, 对于 b 来说, 需要遍历来确认 位数 .
    • 空间复杂度: O(n), 确认 b 的位数时, 需要创建临时变量.

    结果如下所示.


IT界无底坑洞栋主 欢迎加Q骚扰:676758285