当前位置: 首页 > news >正文

代码随想录第三天

203 移除链表元素

了解链表申请节点,删除节点的基本操作。若不使用虚拟头结点,应该分头节点和中间节点两种情况。

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* removeElements(ListNode* head, int val) { ListNode* star = new ListNode(0); star->next = head; ListNode* cur = star; while (cur->next != NULL) { if(cur->next->val == val) { ListNode* tmp = cur->next; cur->next = cur->next->next; delete tmp; } else { cur = cur->next; } } head = star->next; delete star; return head; } };

707 设计链表

class MyLinkedList { public: struct ListNode { int val; // 节点存储的值 ListNode *next; // 指向下一个节点的指针 // 构造函数,方便创建节点 ListNode(int x) : val(x), next(nullptr) {} }; MyLinkedList() { star = new ListNode(0); size = 0; } int get(int index) { ListNode* flag = star->next; if(index < 0 || index >= size){ return -1; }else{ while(index){ flag = flag->next; index--; } return flag->val; } } void addAtHead(int val) { ListNode* newNode = new ListNode(val); newNode->next = star->next; star->next = newNode; size++; } void addAtTail(int val) { ListNode* newNode = new ListNode(val); ListNode* cur = star; while(cur->next != nullptr){ cur = cur->next; } cur->next = newNode; size++; } void addAtIndex(int index, int val) { ListNode* newNode = new ListNode(val); ListNode* flag = star; if(index >= 0 && index <= size){ while(index){ flag = flag->next; index--; } newNode->next = flag->next; flag->next = newNode; size++; } } void deleteAtIndex(int index) { ListNode* flag = star; if(index >= 0 && index < size){ while(index){ flag = flag->next; index--; } ListNode* cur = flag->next; flag->next = cur->next; delete cur; size--; } } private: int size; ListNode* star; }; /** * Your MyLinkedList object will be instantiated and called as such: * MyLinkedList* obj = new MyLinkedList(); * int param_1 = obj->get(index); * obj->addAtHead(val); * obj->addAtTail(val); * obj->addAtIndex(index,val); * obj->deleteAtIndex(index); */

206 反转链表

/** * Definition for singly-linked list. * struct ListNode { * int val; * ListNode *next; * ListNode() : val(0), next(nullptr) {} * ListNode(int x) : val(x), next(nullptr) {} * ListNode(int x, ListNode *next) : val(x), next(next) {} * }; */ class Solution { public: ListNode* reverseList(ListNode* head) { ListNode* pre = NULL; ListNode* cur = head; while(cur){ ListNode* temp = cur->next; cur->next = pre; pre = cur; cur = temp; } return pre; } };
http://www.jsqmd.com/news/659363/

相关文章:

  • NaViL-9B多模态模型应用:智能识别图片内容,轻松实现图文对话
  • 基于YOLOv5与Graphormer的跨模态应用:从分子图像到属性预测
  • “我们删掉了50%的Code Review会议”——某独角兽CTO亲述:如何用智能生成+轻量规则引擎构建零信任但高吞吐的敏捷交付闭环(限免下载:内部Code Trust Score仪表盘模板)
  • 行业词典融入:提升gte-base-zh在垂直领域的语义理解
  • 2026年,广东中青控股如何成为企业信赖的APP拉新首选渠道?
  • 山东大学项目实训二 2
  • 常见网络攻击
  • 不锈钢彩涂板哪家信誉好
  • 2026 最新 从零搭建本地大模型 RAG 知识库问答系统:基于 Llama 3.2 8B 量化版 + LangChain+Chroma,全流程代码实操 + 踩坑指南
  • 保姆级攻略投票平台
  • 用陶晶驰串口屏和STM32F407做个简易扫频仪:手把手教你绘制幅频特性曲线
  • NVIDIA Profile Inspector配置修复指南:3步解决设置保存失败问题
  • PowerQuery数据源实战:从入门到精通的连接艺术
  • 可持续编码实践:ESG开发标准
  • 批量归一化基础:让模型训练更稳定
  • 证券行业-股票行情指标模型的简单介绍
  • 杰理AC791N固件生成全解析:从编译到升级包的内部流程与工具链
  • GPT-SoVITS实战:如何用你的声音生成高质量有声书和视频配音
  • 快速部署通义千问1.5-1.8B-Chat模型:vllm部署与chainlit前端配置
  • Qwen3.5-9B-AWQ-4bit解析卷积神经网络(CNN):原理与代码实现
  • AI 净界作品集锦:RMBG-1.4 生成的高质量PNG素材展示
  • Flux开源免费挑战Midjourney:AI绘图迎来新霸主
  • 像素史诗·智识终端Android Studio项目开发与调试技巧
  • Alpamayo-R1-10B实际项目:高校自动驾驶实验室教学与科研平台
  • Flux Sea Studio 性能基准测试:不同GPU型号下的生成速度对比
  • 大疆M4系列+YOLOV8识别算法 如何训练无人机罂粟识别检测数据集 让非法种植无处可藏:无人机+AI罂粟识别数据集发布,覆盖花期/果期多阶段检测 无人机俯拍+AI识别罂粟
  • 从零到一:基于STM32与PID算法的两轮自平衡小车实战指南
  • 英超第三十二轮
  • 英飞凌TC377芯片选型指南:从300MHz主频到292引脚封装,工程师如何快速匹配项目需求?
  • 智能代码生成不是加个插件就完事:企业级IDE集成必须完成的6项合规性加固(含GDPR/等保2.0适配)