题解 | #牛牛的链表添加节点#

牛牛的链表添加节点

https://www.nowcoder.com/practice/e33b79c2e15a41f9b541e73cd256124a

#include <iostream>
using namespace std;
struct Node
{
    int val;
    Node* next;
    Node(): val(0), next(nullptr) {}
    Node(int val): val(val), next(nullptr) {}
    Node(int val, Node* next): val(val), next(next) {}
} ;

void createList(Node* dummy, int n)
{
    int i = 0;
    Node* node = dummy;
    while (i != n)
    {
        int d;
        cin >> d;
        node->next = new Node(d);
        node = node->next;
        i++;
    }
}
void addListNode(Node* dummy, int i)
{
    Node* node = dummy;
    int cnt = 0;
    while (node->next != nullptr)
    {   
        if (cnt == i)
        {
            Node* temp = new Node(i);
            temp->next = node->next;
            node->next = temp;
            break;
        }
        else
            cnt++;
        node = node->next;
    }
    if (node->next == nullptr && cnt == i)
        node->next = new Node(i);
}
void printList(Node* dummy)
{
    Node* node = dummy->next;
    while (node != nullptr)
    {
        cout << node->val << " ";
        node = node->next;
    }
}

int main() {
    int n, i;
    cin >> n >> i;
    Node* dummy = new Node();
    createList(dummy, n);
    addListNode(dummy, i);
    printList(dummy);
    return 0;

}
// 64 位输出请用 printf("%lld")

要考虑在末尾添加的情况

全部评论

相关推荐

白火同学:1、简历可以浓缩成一页,简历简历先要“简”方便HR快速过滤出有效信息,再要“历”用有效信息突出个人的含金量。 2、教育背景少了入学时间~毕业时间,HR判断不出你是否为应届生。 3、如果你的平台账号效果还不错,可以把账号超链接或者用户名贴到对应位置,一是方便HR知道你是具体做了什么内容的运营,看到账号一目了然,二是口说无凭,账号为证,这更有说服力。
面试被问期望薪资时该如何...
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务