链接列表不会打印? C
Linked list won't print? C
所以我的任务是接收文本文件的字母(每行 6 个),将其保存到链表中,然后打印出特定 "die"(在本例中)的信息 - 这是每组 6 个字母。
我已经在 readData
函数中正确读取了数据(我认为),但不确定该链表是否正确传递。当我尝试打印出 main
中的链接列表(~40-41 行)时,我什么也没得到。我是否将函数错误地传递给了 readData
?
这是我的代码:
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#define LENGTH 80
struct boggleDataNode {
char data[3];
struct boggleDataNode *nextData;
};
struct boggleDieSideNode{
char dieSideData[3];
struct boggleDieSideNode *nextSide;
};
void readData(struct boggleDataNode *temp);
void printData(struct boggleDataNode *temp);
int main() {
int counter = 0;
struct boggleDataNode *head;
struct boggleDieSideNode *head1;
struct boggleDataNode *temp;
head = NULL;
head1 = NULL;
temp = head;
printf("test\n\n");
readData(&temp);
// printData(temp);
while(counter = 0, counter<100, counter++)
printf("%s ", temp->data[counter]);
system("pause");
return 0;
}
void readData(struct boggleDataNode *temp) {
//initializing variables including
//opening the input file
FILE *input = fopen("BoggleData.txt","r");
char data[96] = {};
struct boggleDataNode *new;
int counter = 0;
temp = new;
//error checking that the file opened
if (input == NULL) {
fprintf(stderr, "Can't open input file!\n");
exit(1);
}
new = (struct boggleDataNode *)malloc(sizeof(struct boggleDataNode));
while (fscanf(input, "%s", data) != EOF) {
printf("%s ", data);
strcpy(temp->data, data);
printf("Data number %d %s \n",counter,temp->data);
temp->nextData = NULL;
counter++;
}
}
您将结构错误地传递给 readData
。你像这样声明你的变量:
struct boggleDataNode *temp;
您这样调用readData
:
readData(&temp);
您这样声明readData
:
void readData(struct boggleDataNode *temp){
因此,您将 temp
和 readData
的输入都声明为 struct boggleDataNode *
,但将 &temp
传递给 readData
。 &
意味着你正在发送后面的地址,所以 &temp
是一个指向 struct boggleDataNode
的指针,它是 struct boggleDataNode **
.
您的代码还有其他问题,但这超出了您的问题范围。我会指出你的输出循环是非常非常错误的。
所以我的任务是接收文本文件的字母(每行 6 个),将其保存到链表中,然后打印出特定 "die"(在本例中)的信息 - 这是每组 6 个字母。
我已经在 readData
函数中正确读取了数据(我认为),但不确定该链表是否正确传递。当我尝试打印出 main
中的链接列表(~40-41 行)时,我什么也没得到。我是否将函数错误地传递给了 readData
?
这是我的代码:
#include <string.h>
#include <stdlib.h>
#include <stdio.h>
#define LENGTH 80
struct boggleDataNode {
char data[3];
struct boggleDataNode *nextData;
};
struct boggleDieSideNode{
char dieSideData[3];
struct boggleDieSideNode *nextSide;
};
void readData(struct boggleDataNode *temp);
void printData(struct boggleDataNode *temp);
int main() {
int counter = 0;
struct boggleDataNode *head;
struct boggleDieSideNode *head1;
struct boggleDataNode *temp;
head = NULL;
head1 = NULL;
temp = head;
printf("test\n\n");
readData(&temp);
// printData(temp);
while(counter = 0, counter<100, counter++)
printf("%s ", temp->data[counter]);
system("pause");
return 0;
}
void readData(struct boggleDataNode *temp) {
//initializing variables including
//opening the input file
FILE *input = fopen("BoggleData.txt","r");
char data[96] = {};
struct boggleDataNode *new;
int counter = 0;
temp = new;
//error checking that the file opened
if (input == NULL) {
fprintf(stderr, "Can't open input file!\n");
exit(1);
}
new = (struct boggleDataNode *)malloc(sizeof(struct boggleDataNode));
while (fscanf(input, "%s", data) != EOF) {
printf("%s ", data);
strcpy(temp->data, data);
printf("Data number %d %s \n",counter,temp->data);
temp->nextData = NULL;
counter++;
}
}
您将结构错误地传递给 readData
。你像这样声明你的变量:
struct boggleDataNode *temp;
您这样调用readData
:
readData(&temp);
您这样声明readData
:
void readData(struct boggleDataNode *temp){
因此,您将 temp
和 readData
的输入都声明为 struct boggleDataNode *
,但将 &temp
传递给 readData
。 &
意味着你正在发送后面的地址,所以 &temp
是一个指向 struct boggleDataNode
的指针,它是 struct boggleDataNode **
.
您的代码还有其他问题,但这超出了您的问题范围。我会指出你的输出循环是非常非常错误的。