• 删除有序数组的重复项-------题解报告


    题目:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

    题解:

    个人的想法比较粗糙,因为是递增数组,所以如果有相同的数组,必然相邻,所以只需要判断相邻元素是否相等,相等则将数组从相等处整体前移,同时让r--,当i>=r-1时,就说判断结束的时刻。

    写完之后看了大佬的题解,发现用双指针,这题会更简单。

    首先让指针p都处在数组开头,q在p前面,然后让q++,再判断nums[p]和nums[q]是否相等,

    如果相等,q 后移 1 位 如果不相等,将 q 位置的元素复制到 p+1 位置上,p 后移一位,q 后移 1 位 重复上述过程,直到 q 等于数组长度。

    返回 p + 1,即为新数组长度。

    代码:

    本人

    1. public int removeDuplicates(int[] nums) {
    2. int l=0,r=nums.length;
    3. for(int i=0;i+1
    4. {
    5. if(nums[i]==nums[i+1])
    6. {
    7. int k=nums[i];
    8. for(int j=i+1;j+1< nums.length;j++)
    9. {
    10. nums[j]=nums[j+1];
    11. }
    12. nums[nums.length-1]=k;
    13. if(i>r-1||i==r-1)
    14. {
    15. // System.out.println(i);
    16. break;
    17. }
    18. i--;
    19. l++;
    20. r--;
    21. // System.out.println(l+" "+r+" "+i);
    22. // for(int p=0;p< nums.length;p++)
    23. // System.out.print(nums[p]+" ");
    24. // System.out.println();
    25. }
    26. }
    27. return nums.length-l;
    28. }

    大佬

    1. public int removeDuplicates(int[] nums) {
    2. if(nums == null || nums.length == 0) return 0;
    3. int p = 0;
    4. int q = 1;
    5. while(q < nums.length){
    6. if(nums[p] != nums[q]){
    7. nums[p + 1] = nums[q];
    8. p++;
    9. }
    10. q++;
    11. }
    12. return p + 1;
    13. }
    14. 作者:Max
    15. 链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-array/solutions/34033/shuang-zhi-zhen-shan-chu-zhong-fu-xiang-dai-you-hu/
    16. 来源:力扣(LeetCode)
    17. 著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 相关阅读:
    当创建一个ingress后,kubernetes会发什么?
    2022年全球6家最具技术实力的的智能合约审计公司盘点
    Echarts图表中formatter的用法
    JVM常用命令
    QT day1
    Nuxt.js Next.js Nest.js
    VSCode中值得推荐的常用的33个高效前端插件「效率篇」 (1)
    vue从0到1搭建项目
    STM32 SPI
    《网络是怎样连接的》学习总结-第三章上
  • 原文地址:https://blog.csdn.net/MogulNemenis/article/details/133870541