Um programa c funciona bem no Ubuntu, mas quando eu compilo e executo no Windows usando MinGW, o programa é executado, mas como resultado mostra algum valor de lixo

Um programa c funciona bem no Ubuntu, mas quando eu compilo e executo no Windows usando MinGW, o programa é executado, mas como resultado mostra algum valor de lixo

Eu escrevi um código C no Ubuntu 14.04.4 LTS e o compilei. Está funcionando conforme o esperado. Mas no Windows ele está rodando, mas finalmente no resultado está mostrando alguns valores inúteis.

O código que escrevi é

#include <stdio.h>
#include <stdlib.h>
struct poly{
    int coe[100];
    };
void mul(struct poly *pr, int a, struct poly *p){
    struct poly res;
    int i;
    for(i = 0; i < 100; i++){
        res.coe[i] = 0;
        int j;
        for(j = 0; j <= i; j++){
            res.coe[i] += ((*pr).coe[j])*((*(p + a)).coe[i - j]);
        }
    }
    *pr = res;

}
void main(){
    struct poly *p;
    p = (struct poly *)malloc(100*sizeof(struct poly));
    int n;
    printf("no. of poly :");
    scanf("%d", &n);
    int i; int max = 0;
    for(i = 0; i < n; i++){
        int de;
        printf("deg? of %d:", i+1);
        scanf("%d", &de); max += de;
        int j;
        for(j = 0; j <= de; j++){
            printf("co-eff of deg %d:", j);
            scanf("%d", &p[i].coe[j]);
        }
    }
    struct poly res;
    struct poly *pr;
    res = p[0];
    pr = &res;
    int fi;
    for(fi = 1; fi < n; fi++){
        mul(&res, fi, p);
    }
    for(i = 0; i < (max + 1); i++){
        printf("%d\n", res.coe[i]);
    }
}

e o resultado no Windows é

C:\Users\Sai\Documents\C++>gcc ac.c -o ac

C:\Users\Sai\Documents\C++>ac
no. of poly :3
deg? of 1:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
deg? of 2:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
deg? of 3:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
1
3
6
85067032
255201082
510403447
-1897503563

C:\Users\Sai\Documents\C++>

o resultado no Ubuntu é

sai@sai-Inspiron-7548:~$ gcc ac.c -o ac
sai@sai-Inspiron-7548:~$ ./ac
no. of poly :3
deg? of 1:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
deg? of 2:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
deg? of 3:2
co-eff of deg 0:1
co-eff of deg 1:1
co-eff of deg 2:1
1
3
6
7
6
3
1
sai@sai-Inspiron-7548:~$ 

Como fazer este programa funcionar corretamente no Windows 10.

Há algo errado no código que escrevi.

Obrigado.

Responder1

Embora isso devesse ter sido postado em outro lugar, esta é a solução:

Sempre inicialize!

Você não está inicializando o coe[100]array de todos os elementos do seu arquivo struct poly*.

Nos seus loops você define apenas algumas das entradas, porém sua função múltipla também acessa aquelas não inicializadas.

Presumo que o gcc no Linux de alguma forma cuide disso inicializando-os como 0 por padrão, porém o padrão define o valor de um número inteiro não inicializado como indefinido.

O MinGW não o inicializa para você, então o que quer que esteja na memória naquele momento atrapalha seus resultados.

Editar: é claro que você também deve liberar a memória alocada com free(p);!

Aqui está como você pode consertar:

#include <stdio.h>
#include <stdlib.h>
struct poly{
    int coe[100];
};
void mul(struct poly *pr, int a, struct poly *p){
    struct poly res;
    int i;
    for(i = 0; i < 100; i++){
        res.coe[i] = 0;
        int j;
        for(j = 0; j <= i; j++){
            res.coe[i] += ((*pr).coe[j])*((*(p + a)).coe[i - j]);
        }
    }
    *pr = res;

}
void main(){
    struct poly *p;
    p = (struct poly *)malloc(100*sizeof(struct poly));
    for(int k = 0; k < 100; k++)
        for(int l = 0; l < 100; l++)
            p[k].coe[l] = 0;
    int n;
    printf("no. of poly :");
    scanf("%d", &n);
    int i; int max = 0;
    for(i = 0; i < n; i++){
        int de;
        printf("deg? of %d:", i+1);
        scanf("%d", &de); max += de;
        int j;
        for(j = 0; j <= de; j++){
            printf("co-eff of deg %d:", j);
            scanf("%d", &p[i].coe[j]);
        }
    }
    struct poly res;
    struct poly *pr;
    res = p[0];
    pr = &res;
    int fi;
    for(fi = 1; fi < n; fi++){
        mul(&res, fi, p);
    }
    for(i = 0; i < (max + 1); i++){
        printf("%d\n", res.coe[i]);
    }
    free(p);
}

informação relacionada