初学python记录:力扣2007. 从双倍数组中还原原数组

题目:

一个整数数组 original 可以转变成一个 双倍 数组 changed ,转变方式为将 original 中每个元素 值乘以 2 加入数组中,然后将所有元素 随机打乱

给你一个数组 changed ,如果 change双倍 数组,那么请你返回 original数组,否则请返回空数组。original 的元素可以以 任意 顺序返回。

提示:

  • 1 <= changed.length <= 10^5
  • 0 <= changed[i] <= 10^5

思考:

数组original中每个元素乘以2加入数组中,得到数组changed ---->

  1. 数组changed一定有偶数个元素

  2. 数组changed的元素从小到大遍历,设当前元素为x,那么 x*2 一定另外存在于数组changed中,每次判断完后将当前这两个元素从changed中删去,继续向下判断。

代码如下:

python 复制代码
class Solution(object):
    def findOriginalArray(self, changed):
        """
        :type changed: List[int]
        :rtype: List[int]
        """
        original = []
        n = len(changed)
        i = 0
        if n % 2 == 1:
            return[]

        changed.sort()
        while i < n:
            x = changed[i]
            original.append(x)
            changed.remove(x)
            i -= 1
            n -= 1
            if x * 2 not in changed:
                return []
            else:
                changed.remove(x * 2)
                n -= 1
            i += 1
        return original

提交后卡在例子 176 / 179 超时了:

可以看到这一句判断语句每判断一次都要遍历一次数组,大大增加了耗时:

python 复制代码
if x * 2 not in changed:
                return []

那么直接在最开始统计changed中每个元素的出现次数即可,代码如下:

python 复制代码
from collections import Counter

class Solution(object):
    def findOriginalArray(self, changed):
        """
        :type changed: List[int]
        :rtype: List[int]
        """
        original = []
        n = len(changed)
        i = 0
        if n % 2 == 1:
            return[]

        changed.sort()
        count = Counter(changed)
        for x in changed:
            if count[x] >= 1:
                y = x * 2
                original.append(x)
                count[x] -= 1
                if count[y] < 1:
                    return []
                else:
                    count[y] -= 1
        return original

提交通过:

相关推荐
用户27784491049931 小时前
借助DeepSeek智能生成测试用例:从提示词到Excel表格的全流程实践
人工智能·python
算AI3 小时前
人工智能+牙科:临床应用中的几个问题
人工智能·算法
JavaEdge在掘金3 小时前
ssl.SSLCertVerificationError报错解决方案
python
我不会编程5554 小时前
Python Cookbook-5.1 对字典排序
开发语言·数据结构·python
老歌老听老掉牙4 小时前
平面旋转与交线投影夹角计算
python·线性代数·平面·sympy
满怀10154 小时前
Python入门(7):模块
python
无名之逆4 小时前
Rust 开发提效神器:lombok-macros 宏库
服务器·开发语言·前端·数据库·后端·python·rust
你觉得2054 小时前
哈尔滨工业大学DeepSeek公开课:探索大模型原理、技术与应用从GPT到DeepSeek|附视频与讲义下载方法
大数据·人工智能·python·gpt·学习·机器学习·aigc
啊喜拔牙5 小时前
1. hadoop 集群的常用命令
java·大数据·开发语言·python·scala
hyshhhh5 小时前
【算法岗面试题】深度学习中如何防止过拟合?
网络·人工智能·深度学习·神经网络·算法·计算机视觉