目录

力扣(LeetCode)2562. 找出数组的串联值(C++)

转化字符串

模拟,数字拼接的思路模糊,字符串拼接的思路清晰,于是有:数字转字符串,字符串拼接,字符串转数字(得到两个数字的串联)。

cpp 复制代码
class Solution {
public:
    long long findTheArrayConcVal(vector<int>& nums) {
        int i = 0, j = nums.size() - 1;
        long long ans = 0;
        while (i < j) {
            ans += stoi(to_string(nums[i ++]) + to_string(nums[j --]));
        }
        if (i == j) ans += nums[i];
        return ans;
    }
};

时间复杂度 O ( n l o g U ) O(nlogU) O(nlogU) : n n n是 n u m s nums nums的长度, U U U 是数组元素的最大值,遍历到每个数组元素一次,每个数组元素转换字符串,总体时间复杂度 O ( n l o g U ) O(nlogU) O(nlogU)。

空间复杂度 O ( l o g U ) O(logU) O(logU) : 字符串的空间复杂度 O ( l o g U ) O(logU) O(logU)。

数学+双指针

按照数学方法,直接串联两个数字:前者pre,后者back。算法流程:pre左移(10进制,左移定义为乘以10)back的位数;pre左移的结果+back原先的数值=pre和back的串联。

请看代码:

cpp 复制代码
class Solution {
public:
    long long findTheArrayConcVal(vector<int>& nums) {
        int i = 0, j = nums.size() - 1;
        long long ans = 0;
        int pre, back;
        while (i < j) {
            pre = nums[i ++], back = nums[j --];
            while (back) {
                pre *= 10;
                back /= 10;
            }
            ans += pre + nums[j + 1];
        }
        if (i == j) ans += nums[i];
        return ans;
    }
};

时间复杂度 O ( n l o g U ) O(nlogU) O(nlogU) : n n n是 n u m s nums nums的长度, U U U 是数组元素的最大值,遍历到每个数组元素一次,每个数组元素转换字符串,总体时间复杂度 O ( n l o g U ) O(nlogU) O(nlogU)。

空间复杂度 O ( 1 ) O(1) O(1) : 只使用常数级空间 O ( 1 ) O(1) O(1)。

AC
致语
  • 理解思路很重要。
  • 请读者放心留言,可以是疑惑的点,或者感谢/夸奖也可以!!墨染看到会回复的。
本文是转载文章,点击查看原文
如有侵权,请联系 xyy@jishuzhan.net 删除
相关推荐
whltaoin24 分钟前
Java实现N皇后问题的双路径探索:递归回溯与迭代回溯算法详解
java·算法
同勉共进1 小时前
虚函数表里有什么?(二)——普通单继承下的虚函数表
c++·单继承·虚函数表·dynamic_cast·rtii
梭七y2 小时前
【力扣hot100题】(032)排序链表
算法·leetcode·链表
SsummerC2 小时前
【leetcode100】数组中的第K个最大元素
python·算法·leetcode
编程绿豆侠2 小时前
力扣HOT100之链表:206. 反转链表
算法·leetcode·链表
永恒迷星.by3 小时前
文件操作(c语言)
c语言·c++·算法·文件操作
还有你Y3 小时前
MIMO预编码与检测算法的对比
算法·预编码算法
凯强同学4 小时前
第十四届蓝桥杯大赛软件赛省赛Python 大学 C 组:7.翻转
python·算法·蓝桥杯
记得早睡~5 小时前
leetcode51-N皇后
javascript·算法·leetcode·typescript
Zhichao_975 小时前
【UE5 C++课程系列笔记】32——读Json文件并解析
c++·ue5