算法知识点————双指针【删除重复元素】【反转链表】

删除重复元素

题目 ://给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数
思路:

快指针遍历数组

慢指针记录保留的

cpp 复制代码
int removedup(vector<int>& nums){
   int len = nums.size();
   int fast =1;//快指针遍历数组
   int slow =1; //慢指针记录保留的
    if(len ==0){//参数校验
      return 0;
    }
    while(fast < len){
     	if(nums[fast] != nums[fast-1]){
        nums[slow]=nums[fast];
        slow++;
      }
       fast++;
    }
   return slow;
}
反转链表

1、先用c记录b一会的位置,

2、然后b指向a节点

3、然后ab后往后移动一个,

循环此过程

cpp 复制代码
/翻转链表(迭代版本) 
struct ListNode{
  int val;
  ListNode *next;
  ListNode(int x): val(x),next(NULL){}
};
ListNode* ReverseList(ListNode* head){
  if(!head || !head->next) return head; //只有一个结点或者节点为空
  auto a = head;//自动匹配类型
  auto b = head->next;
  while(b){
    auto c = b->next;//记录一下b一会的位置
    b->next = a;
    a = b;b = c;
  }
  head->next = NULL;
  return a; 
}

///反转链表和上面一样效果
class Solution {
public:
    ListNode* reverseList(ListNode* head) {
        ListNode* prev = nullptr;
        while (head) {
            ListNode* next = head->next;
            head->next = prev;
            prev = head;
            head = next;
        }
        return prev;
    }
};
相关推荐
代码游侠18 分钟前
应用——MPlayer 媒体播放器系统代码详解
linux·运维·笔记·学习·算法
学编程就要猛30 分钟前
算法:3.快乐数
java·算法
AI科技星31 分钟前
统一场论框架下万有引力常数的量子几何涌现与光速关联
数据结构·人工智能·算法·机器学习·重构
仰泳的熊猫33 分钟前
1109 Group Photo
数据结构·c++·算法·pat考试
未来之窗软件服务36 分钟前
幽冥大陆(五十八)php1024位密码生成—东方仙盟筑基期
开发语言·算法·仙盟创梦ide·东方仙盟
不解风水43 分钟前
【教程笔记】KalmanFilter
笔记·学习·算法·矩阵·ekf
2401_841495641 小时前
【数据结构】最短路径的求解
数据结构·动态规划·贪心·ipython·最短路径·迪杰斯特拉算法·弗洛伊德算法
西安同步高经理1 小时前
秒表实现自动化测量助力时频测量行业发展、秒表检定仪、毫秒表测量仪
人工智能·算法
夏幻灵1 小时前
C++ 里 什么时候不用指针,而选择值拷贝/深拷贝 ?
开发语言·c++·算法
这猪好帅1 小时前
【算法】动态规划 - 数字三角形模型
算法·动态规划