c++ - 在 C++ 中调用链表函数

标签 c++ linked-list

我已经创建了 2 个名为 nodelist.h 和 nodelist.cpp 的文件,基本上它们里面的函数包含基本的链表函数,例如(例如 addNode,printNode ...等)之后我创建了另一个源文件像这样利用在该类中创建的函数:

#include "NodeList.h"

bool insertR(stringstream &lineStream)
{

    int node1,node2;
    lineStream>> node1 >> node2;
    nodelist *n1 = new nodelist; //EDIT: FIXED
    nodelist *n2 = new nodelist; // EDIT: FIXED
    n1->addNode(node1);
    n2->addNode(node2);
    n1->print();
    n2->print();
    return true;
}

请注意,此函数不在 main 中,它是 main 调用的另一个源文件。我的 nodelist.cpp 工作正常,虽然这个程序运行,但当我输入节点值时,我的程序崩溃了。有帮助吗?

这是我的节点列表文件:

#include <iostream>

#include "NodeList.h"

using namespace std;

nodelist::nodelist(){
                 head = NULL;
                 current = NULL;
                 temp = NULL;
}

void nodelist::addNode(int node_id_){
 nodePtr n = new Node;
 n->next = NULL;
 n->node_id = node_id_;
 if(head!=NULL)
 {
     current = head;
     while(current->next != NULL)
     {
         current = current ->next;                    
     }
     current->next = n;                    
 }
 else
 {
     head = n;    
 }
}

void nodelist::deleteNode(int del_node){
 nodePtr delPtr = NULL;
 temp = head;
 current = head;
 while(current!=NULL&&current->node_id!=del_node){
     temp = current;
     current = current->next;
     }
 if (current == NULL)
     {
         cout << del_node<<" does not exist"<<endl;   
         delete delPtr;         
     }
 else
     {
         delPtr = current;
         current  = current->next;
         temp->next= current;
         delete delPtr;
         cout << del_node<< " has been deleted"<<endl;      
     }
  }


 void nodelist::print(){
 current = head;
 while(current != NULL){
     cout << current->node_id<<endl;
     current = current ->next;       
 }

编辑:所以现在当我创建一个节点列表类型的新对象时它可以工作,但是当我传入 node1 和 node2 的值时,我得到一个不对应于任何一个节点的连续循环。但是,如果我在 main() 中执行此操作,则此方法有效。

最佳答案

声明指针是不够的,您需要使用 new 运算符来实例化它们指向的节点列表。

n1 和 n2 没有指向任何东西,这就是它崩溃的原因

nodelist *n1;
nodelist *n2;
n1->addNode(node1);
n2->addNode(node2);

关于c++ - 在 C++ 中调用链表函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19718640/

相关文章:

C++,如何使用所有类型的子集

c - C语言中如何删除单链表?

c - 我的链接列表正在打印文本文件中所有元素的最后一个单词

java - 删除链接列表中第一次出现的项目

c++ - undefined reference .. - mingw - winxp - eclipse juno

c++ - 如何正确销毁 vector 的c++ vector 并释放内存

c++ - if ('fstream object' ) 如何根据文件是否打开返回真值或假值?

C++ 分配节点指针

c++ - 如何引用 C++ 中所谓的函数?

java - 在java中删除LinkedList中的特定项目而不使用任何API