c - C 中的 Kruskal 算法 - 无法保存到文件

标签 c algorithm kruskals-algorithm

我在将结果保存到输出文件时遇到问题。可能功能有问题,但我找不到它并修复它。有人知道出了什么问题吗?

程序代码:

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

int **str;
int *tab;

void read(){
    int n = 1;
    char help_sign;
    FILE *fp = fopen("In0303.txt", "r");
    if(fp == NULL){
        printf("Blad odczytu z pliku!");
    }

    while((help_sign = fgetc(fp)) != EOF){
        if (help_sign == '\n'){
            n++;
        }
    }
    fclose(fp);
}

void gen(){
    int i, n;
    int **str;

    str =(int**)malloc(n*sizeof(int*));

    for (i = 0; i < n; i++){
        str[i] = (int*)malloc(4*sizeof(int));
    }
}

void load_date(){
    int i, n;
    int **str;

    FILE *fp = fopen("In0303.txt", "r");

    for (i = 0; i < n; i++){
        fscanf(fp, "%d" , &str[i][0]);
        fscanf(fp, "%d" , &str[i][1]);
        fscanf(fp, "%d" , &str[i][2]);
        str[i][3]=0;
    }
    fclose(fp);
}

void gen_tab(){
    int i, n, k = 0;
    int **str;
    int *tab;

    for (i = 0; i < n; i++){
        if (str[i][0] > k) k = str[i][0];
        if (str[i][1] > k) k = str[i][1];
    }

    tab = (int*)malloc(k*sizeof(int));

    for (i = 0; i < k; i++){
        tab[i] = i + 1;
    }
}

void sort(){
    int i, n, j,tmp;
    int **str;

    for (i = 0; i < n-1; i++)
        for (j = i+1; j < n; j++){
            if (str[i][2] > str[j][2]){
                tmp = str[i][0];
                str[i][0] = str[j][0];
                str[j][0] = tmp;
                tmp = str[i][1];
                str[i][1] = str[j][1];
                str[j][1] = tmp;
                tmp = str[i][2];
                str[i][2] = str[j][2];
                str[j][2] = tmp;
            }
        }
}

int min(int x, int y){
    if (x > y) return y;
    else return x;
}

int max(int x, int y){
    if (x < y) return y;
    else return x;
}

void make(){
    int i, j, min1, max1, p, q, n, k;
    int *tab;
    int **str;
    for (i = 0; i < n; i++){
        if (tab[((str[i][0])-1)] != tab[((str[i][1])-1)]){
            str[i][3] = 1;
            min1 = min(tab[((str[i][0])-1)], tab[((str[i][1])-1)]);
            max1 = max(tab[((str[i][0])-1)], tab[((str[i][1])-1)]);

            for (j = 0; j < k; j++){
                if (tab[j] == max1)
                    tab[j] = min1;
            }
        }
    }
}

void save(){
    int i, n;
    int **str;
    int *tab;

    FILE *g = fopen("Out0303.txt","w");

    for (i = 0; i < n; i++){
        if (str[i][3] == 1){
            fprintf(g, "%d ", str[i][0]);
            fprintf(g, "%d ", str[i][1]);
            fprintf(g, "%d\n", str[i][2]);
        }
    }
    fclose(g);
}

int main(){
    read();
    gen();
    load_date();
    gen_tab();
    sort();
    make();
    save();

    printf("Wyniki zapisane do pliku!\n");
    free(str);
    free(tab);
    return 0;
}

这是输入文件(“In0303.txt”):

9 17
2 3 8 4 9 8
1 3 3 6 4 5 9 6
2 6 4 4 9 1
2 5 3 4 5 3 9 2
4 3 6 1 9 5
5 1 7 5 9 2
6 5 8 4 9 2
1 4 7 4 9 2
1 8 2 6 3 1 4 2 5 5 6 2 7 2 8 2

这是应该在输出文件中创建的内容:(“Out0303.txt”):

17
3 9 [1]
5 6 [1]
4 9 [2]
6 9 [2]
7 9 [2]
8 9 [2]
1 2 [3]
1 8 [4]

最佳答案

Offhand - 在你的保存函数中,你没有分配给“n”

有点膨胀。您似乎想将“n”用作全局变量,但您正在声明它的本地实例,因此该值不会在函数中保留。你可以让它成为全局性的或传递它。

关于c - C 中的 Kruskal 算法 - 无法保存到文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13617548/

相关文章:

c - GTK+-3.0-dev 编译时没有这样的文件或目录 (Linux Mint/gcc)

algorithm - 什么情况下 Kruskal 没有达到最小值?

c++ - 我的最小生成树实现中的错误

c - 如何实现Christofides算法中的shortcutting步骤?

c - 用 C 替换文本文件中的行

c - 如何判断哪些 libxml2 函数返回需要释放的对象?

arrays - 具有最大和最小端点的最长连续子序列

algorithm - 将 3D 矩阵中的数据与另一个矩阵聚类

python - 查找数组中缺失的元素

c - 以正弦波移动 Sprite