博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
[leetcode]Remove Duplicates from Sorted Array II @ Python
阅读量:6541 次
发布时间:2019-06-24

本文共 863 字,大约阅读时间需要 2 分钟。

原题地址:https://oj.leetcode.com/problems/remove-duplicates-from-sorted-array-ii/

题意:

Follow up for "Remove Duplicates":

What if duplicates are allowed at most twice?

For example,

Given sorted array A = [1,1,1,2,2,3],

Your function should return length = 5, and A is now [1,1,2,2,3].

解题思路:一种巧妙的解法。使用两个指针prev和curr,判断A[curr]是否和A[prev]、A[prev-1]相等,如果相等curr指针继续向后遍历,直到不相等时,将curr指针指向的值赋值给A[prev+1],这样多余的数就都被交换到后面去了。最后prev+1值就是数组的长度。

代码:

class Solution:    # @param A a list of integers    # @return an integer    # @it's a good solution!    def removeDuplicates(self, A):        if len(A) <= 2: return len(A)        prev = 1; curr = 2        while curr < len(A):            if A[curr] == A[prev] and  A[curr] == A[prev - 1]:                curr += 1            else:                prev += 1                A[prev] = A[curr]                curr += 1        return prev + 1

 

转载地址:http://idsdo.baihongyu.com/

你可能感兴趣的文章
linux 的网络设置
查看>>
首届“欧亚杯”象翻棋全国团体邀请赛圆满收评!
查看>>
编译tomcat
查看>>
oracle-xe手工创建数据库
查看>>
我的友情链接
查看>>
UG中卸载被占用的DLL
查看>>
eclipse 设置注释模板详解,与导入模板方法介绍总结
查看>>
Cocos2d-x3.2 文字显示
查看>>
mongodb group
查看>>
session_start()放置位置的不正确引发的ROOT常量 未定义的错误
查看>>
如何设定VDP同时备份的任务数?
查看>>
ipsec的***在企业网中的经典应用
查看>>
过来人谈《去360还是留在百度?》
查看>>
mysql备份工具innobackupex,xtrabackup-2.1安装,参数详解
查看>>
本地Office Project计划表同步到SharePoint2013任务列表的权限问题
查看>>
Windows2008 R2 GAC权限问题
查看>>
洛谷——P1469 找筷子
查看>>
springboot项目自定义注解实现的多数据源切换
查看>>
特此说明
查看>>
使用flume替代原有的scribe服务
查看>>