算法基础之单链表

单链表

  • 核心思想: 用数组模拟链表(new节点非常慢 用数组模拟快)

    • e[N] 表示节点value ne[N]表示next指针指向 (空节点为-1)

    cpp 复制代码
      #include<iostream>
      using namespace std;
      const int N=100010;
      
      //head头结点的指针
      //e[N] 表示节点value ne[N]表示next指针指向 
      //idx为当前操作的节点下标
      int head, e[N],ne[N],idx;
      
      //初始化
      void init(){
          head=-1;
          idx=0;
      }
      
      //向头结点后面添加一个节点
      void add_to_head(int x) {
          e[idx] = x;
          ne[idx] = head; //head只是一个指针 不是节点(没有value) 插入节点 让新节点作为真正的头节点 指向-1(空)
          head = idx;
          idx++;
      }
      void add(int k,int x){
          e[idx] = x;
          ne[idx] = ne[k];
          ne[k] =idx;
          idx++;
      } 
      void remove(int k){
          ne[k] = ne[ne[k]]; //直接连下下个
      }
      int main(){
          int m;
          cin>>m;
          char c;
          init();
          while(m--){
              int k,x;
              cin>>c;
              if(c=='H') {
                  cin>>x;
                  add_to_head(x);
              }
              else if(c=='D'){
                  cin>>k;
                  //如果只有头节点 则删除头节点(第一个节点)
                  if(!k) head=ne[head];
                  remove(k-1);
              }
              else{
                  cin>>k>>x;
                  add(k-1,x);
              }
          }
          for(int i = head;i!=-1;i=ne[i]) cout<<e[i]<<' ';
          
          cout<<endl;
          return 0;
      }
相关推荐
小灰灰爱代码2 小时前
C++——求3*3矩阵对角元素之和。
数据结构·c++·算法
老K(郭云开)2 小时前
allWebPlugin中间件自定义alert、confirm及prompt使用
c++·chrome·中间件·prompt·html5·edge浏览器
liangbm33 小时前
MATLAB系列02:MATLAB基础
开发语言·数据结构·笔记·matlab·教程·工程基础·高级绘图
福鸦4 小时前
详解c++:new和delete
开发语言·c++
createcrystal5 小时前
《算法笔记》例题解析 第3章入门模拟--3图形输出(9题)2021-03-03
c++·笔记·算法
我要学编程(ಥ_ಥ)5 小时前
双指针算法专题(2)
数据结构·算法·leetcode
逸狼5 小时前
【JavaEE初阶】多线程6(线程池\定时器)
java·开发语言·算法
no_play_no_games6 小时前
[模板]树的最长路径
算法·深度优先·图论·树形结构
tan77º6 小时前
【C++】异常
c++·算法
ymchuangke6 小时前
数据清洗-缺失值处理-缺失值可视化图(竖线)
python·算法·数学建模