无法正确读取号码?

时间:2018-11-14 02:04:51

标签: c file

我正在尝试逐行读取文件。它使用该行的第一个数字,而其余则使用链接列表的char将其连接起来。但是,当我运行它时,我得到的连接为-38(这是错误的),并且它只打印一次,而没有经过其余的行。但它能完美读取第一个元素。

#include <stdio.h>
#include <stdlib.h>

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


int main(void)
{
    FILE * fp;
    char * line = NULL;
    char * storage;
    size_t len = 0;
    ssize_t read;
    struct node *G[1000];
    for (int i = 1; i < 1000; i++)
    {
        G[i]= malloc(sizeof(struct node));
        G[i]->data = i;
        G[i]->next = NULL;
    }

    fp = fopen("idk2.txt", "r");
    if (fp == NULL)
        exit(EXIT_FAILURE);

    while ((read = getline(&line, &len, fp)) != -1) {
        int vertexGettingConntected = line[0];
        struct node* newItem;
        printf("Retrieved line of length %zu :", read);
        int i = 0;
        while(line[i] != '\0'){
          if ( line[i] == ' '){
            i++;
          }
          else if (i == 0){
            newItem = malloc(sizeof(struct node));
            int itemStorage = line[0] - '0';
            newItem->next = NULL;
            newItem->data = itemStorage;
            G[itemStorage] = newItem;
            printf("This is first Number:%d\n", itemStorage);
          }
          else if (line[i] != ' '){
            struct node* addingItem = newItem;
            while(addingItem->next != NULL){
              addingItem = addingItem->next;
            }
            int itemStorage = line[i] - '0';
            struct node* newConnection = malloc(sizeof(struct node));
            addingItem->next = newConnection;
            newConnection->data = itemStorage;
            newConnection->next = NULL;
            printf("This is character:%c\n", line[i]);
            printf("This is connection:%i\n", itemStorage);
          }
          i++;
        }
    }

    fclose(fp);
    if (line)
        free(line);
    exit(EXIT_SUCCESS);
    for(int printer = 1; printer<20; printer++){
        printf("%d\n",G[printer]->data);
    }
  }

编辑: 只是想包括我要读取的文件:

1 3 4
2 4
3 1 4
4 2 1 3

2 个答案:

答案 0 :(得分:0)

当您按下空格键时,您将迭代i。在循环结束时,您将迭代i。

因此,当您击中一个空格字符时,您将迭代两次i,跳过该数字并着陆到下一个空格字符。

这就是为什么您得到第一个号码却错过其余号码的原因。

编辑:由于@swordfish的反馈,删除了getline()注释。当前的实现没有问题。

答案 1 :(得分:0)

我不确定为什么要有一个指向node的指针数组,而这些指针都在程序开始时就分配了内存,而又不知道需要多少node。然后,您在读取文件时再次分配内存。

鉴于不允许使用函数的限制,这就是我如何读取文件并建立列表的方法:

#include <stdlib.h>
#include <stdio.h>

typedef struct node_tag {
    int value;
    struct node_tag *next;
} node_t;

int main(void)
{
    char const *filename = "test.txt";
    FILE *input_file = fopen(filename, "r");
    if (!input_file) {
        fprintf(stderr, "Couldn't open \"%s\" for reading :(\n\n", filename);
        return EXIT_FAILURE;
    }

    // read from file and build a list:
    node_t *head = NULL;
    node_t *tail = NULL;
    int value;
    int result = EXIT_SUCCESS;

    while (fscanf(input_file, "%d", &value) == 1) {
        node_t *new_node = calloc(1, sizeof *new_node);
        if (!new_node) {
            fputs("Not enough memory :(\n\n", stderr);
            result = EXIT_FAILURE;
            goto glean_up;
        }

        new_node->value = value;

        if (!head) {  // there is no head yet so new_node becomes the head
            head = tail = new_node;  // which is also the lists tail
            continue;
        }

        tail->next = new_node;
        tail = new_node;
    }

    // print the list:
    for (node_t *current_node = head; current_node; current_node = current_node->next)
        printf("%d ", current_node->value);
    putchar('\n');


clean_up:
    fclose(input_file);

    for (node_t *current_node = head, *temp; current_node; current_node = temp) {
        temp = current_node->next;
        free(current_node);
    }

    return result;
}

理想情况下,您需要编写函数来管理列表:

#include <stdbool.h>
#include <stdlib.h>
#include <stdio.h>

typedef struct node_tag {
    int value;
    struct node_tag *next;
} node_t;

typedef struct list_tag {
    node_t *head;
    node_t *tail;
} list_t;

void list_create(list_t *list)
{
    list->head = list->tail = NULL;
}

bool list_push_back(list_t *list, int value)
{
    node_t *new_node = calloc(1, sizeof *new_node);
    if (!new_node)
        return false;

    new_node->value = value;

    if (!list->head) {
        list->head = list->tail = new_node;
        return true;
    }

    list->tail->next = new_node;
    list->tail = new_node;
    return true;
}

void list_print(list_t *list)
{
    for (node_t *current_node = list->head; current_node; current_node = current_node->next)
        printf("%d ", current_node->value);
}

void list_free(list_t *list)
{
    for (node_t *current_node = list->head, *temp; current_node; current_node = temp) {
        temp = current_node->next;
        free(current_node);
    }
}

bool read_int(FILE *input_file, int *value)
{
    return fscanf(input_file, "%d", value) == 1;
}

int main(void)
{
    char const *filename = "test.txt";
    FILE *input_file = fopen(filename, "r");
    if (!input_file) {
        fprintf(stderr, "Couldn't open \"%s\" for reading :(\n\n", filename);
        return EXIT_FAILURE;
    }

    // read from file and build a list:
    list_t list;
    list_create(&list);
    int value;

    while (read_int(input_file, &value)) {
        if (!list_push_back(&list, value)) {
            fputs("Not enough memory :(\n\n", stderr);
            // clean up:
            fclose(input_file);
            list_free(&list);
            return EXIT_FAILURE;
        }
    }

    // print the list:
    list_print(&list);
    putchar('\n');

    // clean up:
    fclose(input_file);
    list_free(&list);
}

输出:

1 3 4 2 4 3 1 4 4 2 1 3