如何使用链表设置显式值构造函数?

时间:2012-06-06 19:23:28

标签: c++ linked-list explicit-constructor

对于一个项目,我试图设置一个链表对象,以便可以使用显式值构造函数初始化它。我希望它看起来像这样:

WORD you("you");//where the object you's linked list now contains y o u;

但是当我打印出你的对象时,我看到的只是这个符号“=” 当我打印出你的长度时,我得到-858993459

这是我的显式值构造函数,有人可以告诉我我做错了吗?

WORD::WORD(string s)
{
front = 0;
int i = 0;
int len = s.length();

if(front == 0)
{   
    front = new alpha_numeric;
    alpha_numeric *p = front;

    while(s[i] <= len)
    {
        p -> symbol = s[i];
        p -> next = new alpha_numeric;
        p = p -> next;
        p -> symbol = s[i++];
    }
    p -> next = 0;
}
}

如果有帮助的话,这是类声明文件

#include <iostream>
#include <string>

using namespace std;
#pragma once

class alpha_numeric //node
{
public:
char symbol; //data in node
alpha_numeric *next;//points to next node
};

class WORD
{
public:
WORD(); //front of list initially set to Null
WORD(const WORD& other);
WORD(string s); //***EXPLICIT VALUE CONSTRUCTOR
bool IsEmpty(); //done
int Length();
void Add(char); //done
//void Insert(WORD bword, int position);
//void operator=(char *s);

friend ostream & operator<<(ostream & out, const WORD& w);//done

private:
alpha_numeric *front; //points to the front node of a list
int length;
};

4 个答案:

答案 0 :(得分:1)

您已将std::string sint i初始化为0。然后,您将int len初始化为s.length();,并且您希望迭代此字符串:

while(s[i] <= len) <----------------- THIS IS WRONG
{
    ...
    p -> symbol = s[i++];
}

另请注意,std::basic_string::length()的复杂性为O(1)。没有必要使用临时变量len。您还在做很多冗余的事情,例如将0分配给front,然后检查if (front == 0)。它看起来像这样:

WORD::WORD(std::string s)
{
    length = s.length();
    if (length == 0)
    {
        front = NULL
        return;
    }

    front = new alpha_numeric;
    alpha_numeric *p = front;

    int i = 0;
    while(i < length - 1)
    {
        p->symbol = s[i++];
        p->next = new alpha_numeric;
        p = p->next;
    }
    p->symbol = s[i];
    p->next = NULL;
}

答案 1 :(得分:1)

你永远不会设定长度,所以这就是为什么它是垃圾。正如luthien256 ahd LihO指出的那样,你的while循环也是错误的,if(front == 0)测试没有意义。

最后,不需要p -> symbol = s[i++];。只需增加i。

试试这个:

class alpha_numeric //node
{
public:
char symbol; //data in node
alpha_numeric *next;//points to next node
};

class WORD
{
public:
WORD(); //front of list initially set to Null
WORD(const WORD& other);
WORD(string s); //***EXPLICIT VALUE CONSTRUCTOR
bool IsEmpty(); //done
int Length() { return length; }
alpha_numeric *Front() { return front; }
void Add(char); //done
//void Insert(WORD bword, int position);
//void operator=(char *s);

friend ostream & operator<<(ostream & out, const WORD& w);//done

private:
alpha_numeric *front; //points to the front node of a list
int length;
};

WORD::WORD(string s)
{
  front = 0;
  int i = 0;
  int len = s.length();
  length = len;
  if (length == 0) {
    front = NULL;
    return;
  }
  front = new alpha_numeric;
  alpha_numeric *p = front;

  while(i < len)
  {
      p -> symbol = s[i];
      if (i != len - 1) {
        p -> next = new alpha_numeric;
        p = p -> next;
      }
      else
        p -> next = NULL;
      ++i;
  }
}


int main() {
  WORD you("you");
  alpha_numeric* front = you.Front();
  while(front != NULL) {
    cout<<(front->symbol)<<endl;
    front = front->next;
  }
  cout<<you.Length()<<endl;
  return 0;
}

答案 2 :(得分:0)

你的while循环不太可能正在执行。我相信:

while(s[i] <= len)

应该是

while(i < len)

答案 3 :(得分:0)

试试这个:

WORD::WORD(string s)
{
  int i;
  int len = s.length();

  front = new alpha_numeric;
  alpha_numeric *p = front;

  for(i = 0; i < len; i++)
  {
        p -> symbol = s[i];
        p -> next = (i == len - 1) ? 0 : new alpha_numeric;
        p = p -> next;
  }
}