算法基础之单链表

单链表

  • 核心思想: 用数组模拟链表(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;
      }
相关推荐
leoufung10 分钟前
LeetCode 67. Add Binary:从面试思路到代码细节
算法·leetcode·面试
无限进步_19 分钟前
【C语言】循环队列的两种实现:数组与链表的对比分析
c语言·开发语言·数据结构·c++·leetcode·链表·visual studio
qq_3106585120 分钟前
webrtc源码走读(四)核心引擎层——视频引擎
服务器·c++·音视频·webrtc
wjykp24 分钟前
79~87逻辑回归f
算法·机器学习·逻辑回归
何包蛋H30 分钟前
数据结构深度解析:Java Map 家族完全指南
java·开发语言·数据结构
码界奇点34 分钟前
基于React与TypeScript的后台管理系统设计与实现
前端·c++·react.js·typescript·毕业设计·源代码管理
社会零时工35 分钟前
【ROS2】海康相机ROS2设备服务节点开发
linux·c++·相机·ros2
古译汉书36 分钟前
keil编译错误:Error: Flash Download failed
开发语言·数据结构·stm32·单片机·嵌入式硬件
Bruce_kaizy38 分钟前
2025年年度总结!!!!!!!!!!!!!!!!!!!!!!!!!!!
开发语言·c++
聆风吟º38 分钟前
【顺序表习题|图解|双指针】合并两个有序数组 + 训练计划 I
c语言·数据结构·c++·经验分享·算法