题解 | #数组中重复的数字#

数组中重复的数字

http://www.nowcoder.com/practice/6fe361ede7e54db1b84adc81d09d8524

class Solution:
    def duplicate(self , numbers ):
        # write code here
#         dic = {}                 # 方法1:使用dic字典,如果存在则返回,不存在则标记,空间复杂度o(n)
#         if not numbers:
#             return -1
#         for i in range(len(numbers)):
#             if numbers[i] in dic:
#                 return numbers[i]
#             else:
#                 dic[numbers[i]] =1

         if not numbers:          # 方法二:空间复杂度o(1),遍历原数组,将原数组的值作为数组的索引,如果大于0表示第一次访问,然后取反,如果小于0表示已经访问过了。
             return -1
         for i in range(len(numbers)):
            if numbers[abs(numbers[i])]<0:
                return abs(numbers[i])
            else:
                numbers[abs(numbers[i])] = -numbers[abs(numbers[i])]
全部评论

相关推荐

06-17 00:26
门头沟学院 Java
程序员小白条:建议换下项目,智能 AI 旅游推荐平台:https://github.com/luoye6/vue3_tourism_frontend 智能 AI 校园二手交易平台:https://github.com/luoye6/vue3_trade_frontend GPT 智能图书馆:https://github.com/luoye6/Vue_BookManageSystem 选项目要选自己能掌握的,然后最好能自己拓展的,分布式这种尽量别去写,不然你只能背八股文了,另外实习的话要多投,尤其是学历不利的情况下,多找几段实习,最好公司title大一点的
无实习如何秋招上岸
点赞 评论 收藏
分享
06-11 17:39
门头沟学院 Java
小呆呆的大鼻涕:卧槽,用户彻底怒了
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务