struct node
{
char *IPArray[100];
struct node *ptr;
};
typedef struct node NODE;
NODE *head, *first, *temp = 0;
first = 0;
int numofIP;
这是我的结构,在链表中的每个节点都包含字符串。 numofIP 是我的链表中字符串或节点的最大数量。
for(int i=0; i<numofIP; i++)
{
head = (NODE *)malloc(sizeof(NODE));
printf("enter the IP addresses:\n");
scanf("%s",&head->IPArray[i]);
if(first != 0)
{
temp->ptr = head;
temp = head;
}
else
{
first = temp = head;
}
}
temp->ptr = 0;
temp = first;
这就是我接受输入并将其存储在每个节点中的方式。
while(temp != NULL)
{
printf("%d=> ",temp->IPArray);
temp = temp->ptr;
}
这就是我打印链接列表的方式。
但问题是我在输出中得到了地址。我无法弄清楚。如何在链表的每个节点中存储一个字符串?
最佳答案
1.更改
printf("%d=> ",temp->IPArray);
至
printf("%s=> ",temp->IPArray);
您为 printf
函数提供了不正确的格式说明符。
2.为IPArray
中的每个char*
分配内存。
但是,正如您所提到的,节点中只需要一个字符串,然后更改
char* IPArray[100]
到 char IPArray[100]
char* IPArray[100]
:将创建指向 100 个字符串的指针,稍后您需要为其分配内存。
char IPArray[100]
:将创建 100 个字符的数组,您可以在其中存储特定节点的 IP 地址,并且不需要为此分配单独的内存。
关于c - c 中包含字符串的链接列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35788734/