算法基础之单链表

单链表

  • 核心思想: 用数组模拟链表(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;
      }
相关推荐
郝学胜-神的一滴3 小时前
深入解析Python字典的继承关系:从abc模块看设计之美
网络·数据结构·python·程序人生
半桔3 小时前
【IO多路转接】高并发服务器实战:Reactor 框架与 Epoll 机制的封装与设计逻辑
linux·运维·服务器·c++·io
HABuo4 小时前
【linux文件系统】磁盘结构&文件系统详谈
linux·运维·服务器·c语言·c++·ubuntu·centos
我在人间贩卖青春5 小时前
C++之多重继承
c++·多重继承
颜酱5 小时前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
m0_736919105 小时前
C++代码风格检查工具
开发语言·c++·算法
yugi9878385 小时前
基于MATLAB强化学习的单智能体与多智能体路径规划算法
算法·matlab
DuHz5 小时前
超宽带脉冲无线电(Ultra Wideband Impulse Radio, UWB)简介
论文阅读·算法·汽车·信息与通信·信号处理
Polaris北极星少女6 小时前
TRSV优化2
算法
代码游侠6 小时前
C语言核心概念复习——网络协议与TCP/IP
linux·运维·服务器·网络·算法