首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

如何在链表c++的开头插入数字?

在C++中,要在链表的开头插入一个数字,可以按照以下步骤进行操作:

  1. 定义一个链表节点的结构体,包含一个整数值和一个指向下一个节点的指针。
代码语言:txt
复制
struct ListNode {
    int val;
    ListNode* next;
};
  1. 创建一个新的节点,并为其分配内存。
代码语言:txt
复制
ListNode* newNode = new ListNode;
  1. 将要插入的数字赋值给新节点的值。
代码语言:txt
复制
newNode->val = 数字;
  1. 将新节点的指针指向当前链表的头节点。
代码语言:txt
复制
newNode->next = 头节点指针;
  1. 更新链表的头节点指针,使其指向新节点。
代码语言:txt
复制
头节点指针 = newNode;

完整的代码示例:

代码语言:txt
复制
#include <iostream>

struct ListNode {
    int val;
    ListNode* next;
};

void insertAtBeginning(ListNode*& head, int num) {
    ListNode* newNode = new ListNode;
    newNode->val = num;
    newNode->next = head;
    head = newNode;
}

int main() {
    ListNode* head = nullptr;  // 初始化链表头节点指针为空
    int num = 10;  // 要插入的数字
    insertAtBeginning(head, num);
    std::cout << "插入数字 " << num << " 后的链表:" << std::endl;
    ListNode* curr = head;
    while (curr != nullptr) {
        std::cout << curr->val << " ";
        curr = curr->next;
    }
    std::cout << std::endl;
    return 0;
}

这样就可以在链表的开头插入一个数字了。链表的开头插入操作的时间复杂度为O(1),适用于需要频繁在链表开头插入元素的场景。

腾讯云相关产品和产品介绍链接地址:

  • 腾讯云云服务器(CVM):https://cloud.tencent.com/product/cvm
  • 腾讯云云数据库 MySQL 版:https://cloud.tencent.com/product/cdb_mysql
  • 腾讯云云原生容器服务(TKE):https://cloud.tencent.com/product/tke
  • 腾讯云人工智能平台(AI Lab):https://cloud.tencent.com/product/ailab
  • 腾讯云物联网平台(IoT Hub):https://cloud.tencent.com/product/iothub
  • 腾讯云移动开发平台(MTP):https://cloud.tencent.com/product/mtp
  • 腾讯云对象存储(COS):https://cloud.tencent.com/product/cos
  • 腾讯云区块链服务(BCS):https://cloud.tencent.com/product/bcs
  • 腾讯云游戏多媒体引擎(GME):https://cloud.tencent.com/product/gme
  • 腾讯云音视频处理(MPS):https://cloud.tencent.com/product/mps
  • 腾讯云网络安全(NSA):https://cloud.tencent.com/product/nsa
  • 腾讯云CDN加速(CDN):https://cloud.tencent.com/product/cdn
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券