我在singly linked list
中制作了C++
的程序,因此在课程中使用struct
。我知道typedef
与struct
一起使用,因此声明之后不需要使用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;
}
答案 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++?。