2011-12-08 142 views
1

我已經通過其他問題進行了搜索,沒有一個看起來確切地應用 。 我正在寫一個程序,通過迷宮找到一條路線, 唯一真正有問題的是這一個編譯器錯誤。 它與一個函數我有返回一個節點(結構)。節點沒有命名類型錯誤

頭文件(我砍定義的東西關)

#include <iostream> 
    #include <string> 
    using namespace std; 


    class Graph { 

    private: 

     struct Node { 
      int id; //int id 
      Node * north; //north path node 
      Node * south; //south path node 
      Node * east;  //east path node 
      Node * west;  //went path node 
      bool visited; // visited bool 
     }; 

     //this struct holds the path that is found. 
     struct Elem { 
      int id;   //The id of the node 
      string last; //the door that it passed through 
      Elem * back;  //back one path   
      Elem * next; //forward one path 
     }; 

     //This is a graph with a very smart struct 

     //This is the main node that makes up the graph. 


     Node * start; 

     Node ** initArr; 
     int arrLen; 

     Elem * head; 
     Elem * tail; 

     int path; 

    public: 

     Graph(); 
      //Constructs empty graph 

     Graph(const Graph &v); 
      //copy constructor 

     ~Graph(); 
      //destructor 

     Graph & operator = (const Graph &v); 
      //assignment operator 

     void output(ostream & s) const; 
      //Prints the graph 

     void input(istream & s); 
      //input and creates the graph 

     Node * find(int id); 
      //finds the node in the graph 

     void makePath();  
      //makes a path through the maze 

     bool findPath(Node* cur, string room); 
      //worker function for recursion 

     void pathOut(ostream & s) const; 
      //Outputs the found path 

     void removeTail(); 
      //Removes the last element 

     void addTail(Node* n, string door); 
      //Adds the element to the tail 

     //Mutators 
     void setId(Node* n ,int x); 
     void setVisited(Node* n, bool v); 



     //Elem Mutator 
     void seteId(Elem* e, int x); 

     //Elem Accessor 
     int geteId(Elem* e); 

     //Accessors 
     int getId(Node* n); 
     bool getVisited(Node* n); 




    }; 

而我實際的代碼文件。

#include <iostream> 
    #include "graph.h" 
    using namespace std; 

     //Constructs empty graph 
     Graph::Graph() 
     { 
      start = 0; 
      head = tail = 0; 
      path = 0; 
     } 

     //copy constructor 
     Graph::Graph(const Graph &v) 
     { 
      //not implemented 
     } 

     //destructor  
     Graph::~Graph() 
     { 
      for(int i = 0; i < arrLen + 1; i++) 
      { 
       delete initArr[i]; 
      } 


      while(head != 0) 
      { 
      Elem* p = head; 
      head = head->next; 
      delete p; 
      } 

      delete[] initArr; 
     } 

     //assignment operator 
     Graph & Graph::operator = (const Graph &v) 
     { 
      //not implemented 
     } 

     //Prints the graph 
     void Graph::output(ostream & s) const 
     { 
      s<<"Node"<<'\t'<<"North"<<'\t'<<"East"<<'\t'<<"South"<<'\t'<<"West"<<'\n'; 
      for(int i = 1; i < arrLen + 1; i++) 
      { 
       Node* temp = initArr[i]; 
       s<<temp->id<<'\t'; 

       if(temp->north != 0) 
        s<<temp->north->id<<'\t'; 
       else 
        s<<"--"<<'\n'; 

       if(temp->east != 0) 
        s<<temp->east->id<<'\t'; 
       else 
        s<<"--"<<'\n'; 

       if(temp->south != 0) 
        s<<temp->south->id<<'\t'; 
       else 
        s<<"--"<<'\n'; 

       if(temp->west != 0) 
        s<<temp->west->id<<'\t'; 
       else 
        s<<"--"<<'\n'; 

       s<<'\n'; 


      } 

     } 

     //input and creates the graph 
     void Graph::input(istream & s) 
     { 
      int length = 0; 
      s>>length; 
      arrLen = length; 
      if(s) 
      { 

       //define array 
       initArr = new Node*[length + 1]; 
       int temp = 0; 
       for(int i = 1; i < length + 1; i++) 
       { 
        //Create node     
        s>>temp; 
        Node* n = new Node; 
        n->id = temp; 
        n->visited = false; 
        //Add to array 
        initArr[i] = n; 
       } 

       //Make Exit Node 
       Node *x = new Node; 
       x->id = 0; 
       x->visited = false; 
       initArr[0] = x; 

       //Loop through all of the node input 
       int tn = 0; 
       for(int f = 0; f < length; f++) 
       { 
        //Set Pointers 
        s>>tn; 
        Node* curNode = find(tn); 
        int n = 0; 
        int e = 0; 
        int st = 0; 
        int w = 0; 
        s>>n>>e>>st>>w; 
        curNode->north = find(n); 
        curNode->east = find(e); 
        curNode->south = find(st); 
        curNode->west = find(w); 
       } 
       //set Entry point to graph 
       int last = 0; 
       s>>last; 
       start = find(last); 

      } 
     } 

     //finds the node in the array 
     Node* Graph::find(int id) 
     { 
      if(id == 0) 
      { 
       return initArr[0]; 
      } 
      if(id == -1) 
      { 
       return 0; 
      } 
      else 
      { 
       for(int i = 1; i < arrLen + 1; i++) 
       { 
        if(initArr[i]->id == id) 
        { 
         return initArr[i]; 
        } 

       } 
       cerr<<"NOT FOUND IN GRAPH"; 
       return 0; 
      } 
     } 

     //makes a path through the maze 
     void Graph::makePath() 
     { 
      if(findPath(start->north, "north") == true) 
      { 
       path = 1; 
       return; 
      } 
      else if(findPath(start->east, "east") == true) 
      { 
       path = 1; 
       return; 
      } 
      else if(findPath(start->south, "south") == true) 
      { 
       path = 1; 
       return; 
      } 
      else if(findPath(start->west, "west") == true) 
      { 
       path = 1; 
       return; 
      } 
      return; 
     } 


     //finds a path to the outside 
     bool Graph::findPath(Node* cur, string room) 
     { 
      addTail(cur, room); 

      if(cur = initArr[0]) 
      { 
        return true; 
      } 

      if(cur->north != 0 && cur->north->visited == false) 
      { 
        cur->visited = true; 
        findPath(cur->north, "north"); 
      } 
      else if(cur->east != 0 && cur->east->visited == false) 
      { 
        cur->visited = true; 
        findPath(cur->north, "east"); 
      } 
      else if(cur->south !=0 && cur->south->visited == false) 
      { 
        cur->visited = true; 
        findPath(cur->north, "south"); 
      } 
      else if(cur->west != 0 && cur->west->visited == false) 
      { 
        cur->visited = true; 
        findPath(cur->north, "west"); 
      } 
      else 
      { 
       cur->visited = false; 
       removeTail(); 

      } 
     } 

     //Outputs the found path 
     void Graph::pathOut(ostream & s) const 
     { 
      if(path == 1) 
      { 
       Elem *p; 
       p = head->next; 

       while(p != 0) 
       { 
        s<<p->id<<"--> "<<p->last; 
        p= p->next; 
       } 
      } 
      else if(path == 0) 
      { 

      } 

     } 

     //Removes the last element in the chain   
     void Graph::removeTail() 
     { 
      Elem* temp = 0; 
      temp = tail; 
      tail = tail->back; 
      delete temp; 
     } 

     //Adds the element to the tail 
     void Graph::addTail(Node* n, string door) 
     { 
      if(head != 0) 
      { 
       Elem* temp = new Elem; 
       temp->id = n->id; 
       tail->next = temp; 
       tail->last = door; 
       temp->back = tail; 
       temp->next = 0; 
       tail = 0; 
      } 
      else 
      { 
       Elem *p = new Elem; 
       p->last = ""; 
       p->back = 0; 
       p->next = 0; 
       head = p; 
       tail = p; 
      } 

     } 


     //Mutators 
     void Graph::setId(Node *n ,int x) 
     { 
      n->id = x; 
     } 
     void Graph::setVisited(Node *n, bool v) 
     { 
      n->visited = v; 
     } 

     //Elem Mutator 
     void Graph::seteId(Elem *e, int x) 
     { 
      e->id = x; 
     } 

     //Elem Accessor 
     int Graph::geteId(Elem *e) 
     { 
      return e->id; 
     } 

     //Accessors 
     int Graph::getId(Node *n) 
     { 
      return n-> id; 
     } 
     bool Graph::getVisited(Node *n) 
     { 
      return n->visited; 
     } 


    /* 
     //This is a graph with a very smart struct 

     //This is the main node that makes up the graph. 
     struct Node { 
      int id; //int id 
      Node *north; //north path node 
      Node *south; //south path node 
      Node *east;  //east path node 
      Node *west;  //went path node 
      bool visited; // visited bool 
     }; 

     //this struct holds the path that is found. 
     struct Elem { 
      int id;   //The id of the node 
      string last; //the door that it passed through 
      Elem* back;  //back one path   
      Elem* next;  //forward one path 
     }; 

     Node* Start; 

     Node ** initArr; 

     Elem* head; 
     Elem* tail; 
     */ 

//outputs using named operation 
ostream & operator << (ostream &s, const Graph & v) 
{ 
    v.output(s); 
    return s; 
} 

查找功能發生錯誤。

+0

「查找函數發生錯誤」 - 爲什麼在這裏有*任何*除了'Node'和'find'函數的定義? – Xeo

+1

你介意告訴我們錯誤嗎? –

回答

2

在cpp文件中,Node不在全局範圍內。它嵌套在Graph因爲如此,你需要限定它的返回類型:

Graph::Node* Graph::find(int id){ 
// ... 
} 

在函數內部,你在Graph範圍是再次,因此你不必限定它。

+0

+1如果你發現沒有編譯器的錯誤,我印象非常深刻 –

1

您將Node和Element都定義爲類Graph中的結構。在類Graph之外定義它們會更好。您可以定義一個單獨的Node類,並將元素struct存儲爲其私有成員。發生錯誤是因爲Node是Graph的私有成員,可以作爲Graph :: Node訪問。例如。 Graph :: Node * find(...)。