Program "wywala" się przy większych liczbach.

0

Mam program który wypisuje trójkąt pascala.

#include <stdio.h>
#include <stdlib.h>
int main()
{
int **t;
int i,j,a,n,k,x,y;
n=1;  //By nie mnozylo przez 0
printf("Podaj liczbe:");
scanf("%d",&a);
//Sprawdzanie czy liczba nie jest ujemna
if(a<0){
while(a<0){
printf("Podaj liczbe:");
scanf("%d",&a);}}
// Deklaracja
t=malloc(a*sizeof(int));
for(i=0;i<a;i++)
//Dla pierwszej 
{if(i!=0)
{n=n*i;}
k=1;
t[i]=malloc((i+1)*sizeof(int));
for(j=0;j<(i+1);j++)
{
if(j!=0)
{
k=k*j;
}
//Dla ostatniej
if(i==j)
{
t[i][j]=1;
}
else
{
if(j==0)
{
y=n;
}
else
{
y=y/(i-j+1);
}
t[i][j]=(n/(k*y));
}
printf("%d ",t[i][j]);
}
printf("\n");
}
return 0;
}

 

Działa normalnie przy mniejszych liczbach. Jednak gdy wpiszę liczbę większą od 13 program w pewnym miejscu przestaje działać. Ktoś może wie dlaczego tak się dzieje ?

0

Póki nie sformatujesz kodu nikt ci nie pomoże...

0

Faktycznie kod niezbyt czytelny przepraszam.
Mam nadzieję że ten będzie bardziej czytelny.

#include <stdio.h>
#include <stdlib.h>
int main()
{
int **t;
int i,j,a,n=1,k=1,x,y;

printf("Podaj liczbe:");
scanf("%d",&a);
//Sprawdzanie czy liczba nie jest ujemna
if(a<0){
   while(a<0){
    printf("Podaj liczbe:");
    scanf("%d",&a);}}
// Deklaracja
t=malloc(a*sizeof(int));
for(i=0;i<a;i++){
//Dla pierwszej 
if(i!=0){
    n=n*i;}
t[i]=malloc((i+1)*sizeof(int));

for(j=0;j<(i+1);j++){
   if(j!=0){
    k=k*j;}

//Dla ostatniej
if(i==j){
  t[i][j]=1;}
  
else{
  if(j==0){
   y=n;}

else{
   y=y/(i-j+1);}

t[i][j]=(n/(k*y));}
printf("%d ",t[i][j]);}
printf("\n");}
return 0;
}

 
1

13! nie wyliczysz na typie int. Jak masz wypisać (obliczyć) cały trójkąt Pascala, to lepsza będzie rekurencja, nie grozi Ci wtedy przekroczenie zakresu zmiennych w wynikach częściowych.

1 użytkowników online, w tym zalogowanych: 0, gości: 1