struct中typedef的奇怪行为

时间:2016-03-22 05:22:28

标签: c++ struct

我在singly linked list中制作了C++的程序,因此在课程中使用struct。我知道typedefstruct一起使用,因此声明之后不需要使用struct关键字。但是,当我不使用typedef时,即使在将来的声明中没有使用struct关键字,代码也会成功编译,但是当我使用typedef时,它无法编译。 这是代码:

#include <iostream>
using namespace std;

struct node{        
    int data;
    node* next;
}*head; 

class single_list{
    public:
        struct node* create_node(int);
        void insert_begin();
        void insert_pos();
        void insert_last();
        void delete_pos();
        void sort();
        void display();
};

int main()
{
    int choice,nodes,element,position,i;
    single_list sl;
    node* head = NULL;
    while(1)
    {
        cout<<endl<<"List of operations"<<endl;
        cout<<"1: Insert node at the beginning"<<endl;
        cout<<"2: Insert node at a specific position"<<endl;
        cout<<"3: Insert node at the last"<<endl;
        cout<<"4: Delete a node at specific position"<<endl;
        cout<<"5: Sorting the linked list"<<endl;
        cout<<"6: Display the linked list"<<endl;
        cout<<"Enter your choice"<<endl;
        cin>>choice;

        switch(choice)
        {
            case 1:
                cout<<"Inserting node at the beninning"<<endl;
                sl.insert_begin();
                cout<<endl;
                break;

            case 2:
                cout<<"Inserting node at a specific position"<<endl;
                sl.insert_pos();
                cout<<endl;
                break;

            case 3:
                cout<<"Inserting node at the last place"<<endl;
                sl.insert_last();
                cout<<endl;
                break;

            case 4:
                cout<<"Deleting node at specific position"<<endl;
                sl.delete_pos();
                cout<<endl;
                break;

            case 5:
                cout<<"Sorting the linked list"<<endl;
                sl.sort();
                cout<<endl;
                break;

            case 6:
                cout<<"Displaying the linked list"<<endl;
                sl.display();
                cout<<endl;
                break;

            default:
                cout<<"Wrong Choice"<<endl;                     
        }
    }
}

node *single_list::create_node(int data)
{
    node* temp;
    temp = new node;
    temp->data = data;
    temp->next = NULL;
    return temp;
}

void single_list::insert_begin()
{
    cout<<"Enter value to be inserted"<<endl;
    int data;
    cin>>data;
    node* temp;
    node* p;
    temp = create_node(data);

    if (head == NULL)
    {
        head = temp;
        head->next = NULL;
    }
    else
    {
        p = head;
        head = temp;
        head->next = p;
    }
}

void single_list::insert_pos()
{
    cout<<"Enter the position at which you want to enter the number"<<endl;
    int pos;
    cin>>pos;
    cout<<"Enter the data of the node"<<endl;
    int data;
    node* t;
    t = head;
    node* temp1;
    temp1->data = data;
    for(int i=1;i<pos;i++)
    {
        t = t->next;
    }
    if(pos == 1)
    {
        if(head == NULL)
        {
            head = temp1;
            head->next = NULL;
        }
        else
        {
            temp1->next = t->next;
            t->next = temp1;    
        }
    }
    else
    {
        cout<<"Position out of range"<<endl;
    }

}

void single_list::insert_last()
{
    cout<<"Enter the data of the number"<<endl;
    int data;
    cin>>data;
    node* temp1;
    temp1->data = data;
    temp1->next = NULL;
    node* t;
    t = head;
    while(t != NULL)
   {
        t = t->next;
   }
    t->next = temp1;
}

4 个答案:

答案 0 :(得分:1)

定义struct

struct node{        
    int data;
    node* next;
}*head;

在C ++中没有node的情况下可以使用名称typedef。您必须考虑C,这需要typedef

在C ++中,可以使用:

struct node{        
    int data;
    node* next;
};

node* head;

在C中,您需要使用:

struct node{        
    int data;
    struct node* next;
};

struct node* head;

// Define the struct and a typedef in one statement.
typedef struct node{        
    int data;
    struct node* next;
} node;

node* head;

答案 1 :(得分:0)

在C ++中定义/声明对象时,不需要使用struct关键字。在C语言中就是这样,而不是在C ++中。

答案 2 :(得分:0)

以下代码声明head是指向node变量的指针。

struct node{        
    int data;
    node* next;
}*head; 

但是,以下内容将head定义为指向node的类型指针的别名。

typedef struct node{        
    int data;
    node* next;
}*head; 

答案 3 :(得分:0)

在C ++中,struct几乎与class相同,只是差别很小。见这里:What are the differences between struct and class in C++?