Enviado em 18/03/2018 - 09:07h
Já pesquisei e vi que esse erro do terminal aparece quando é acessado posições indevidas no vetor ou algo parecido. Meu código está abaixo, acredito que o erro esteja na função fatorial... Quem puder me ajudar, fico MUITO agradecido#include <stdio.h>
#include <stdlib.h>
#include <math.h>
//by Guilherme Giacomin (gz)
void exibir_vetor(int * v){
int i;
for(i=(40000-1) ; i>-1 ; i--){
if(v[i]!=-1)
printf("%d",v[i]);
}
}
int num_digitos(int num){
int i;
int cont=0;
for(i=1; num%i!=num ; i*=10){
cont++;
}
return cont;
}
void soma_vetorial(int * v, int * s){
int i,soma,resto=0;
for(i=0 ; i<40000 ; i++){
soma = v[i] + s[i];
v[i] = soma % 10 + resto;
resto = soma / 10;
if(v[i+1]==-1 || s[i+1]==-1){
if(v[i+1]==-1 && s[i+1]==-1){
if(resto==0)
i=40000; //"break"
else
v[i+1]=0; s[i+1]=0;
}
else if(v[i+1]==-1){
v[i+1]=0;
}
else if(s[i+1]==-1){
s[i+1]=0;
}
}
}
}
void igualar(int * r, int * s){
int i,i1;
for(i=0 ; i<40000 ; i++){
r[i] = s[i];
if(s[i+1]==-1 && r[i+1]==-1){
i=40000; //"break"
}
}
}
void preenche_vetor(int * h,int n){
//Preenche o Vetor 'h' com o valor de 'n'
//Todas as outras posições são preenchidas com -1
int i=0,div=1;
int num=n;
for(; (num%div)!=num ; i++){
h[i]=n%10;
n/=10;
div*=10;
}
for( ; i<40000 ; i++){
h[i]=-1;
}
}
void fatorial(int n,int * v){
int save[40000],fator[40000];
int i,i0,i1,produto,vai1=0;
int digitos,n_und; //n_und : numero na unidade desejada(dezena, centena, ...)
int num;
preenche_vetor(save,1);
preenche_vetor(fator,1);
for(n-=1 ; n>1 ; n--){
igualar(save,v);
num=n;
for(digitos=1 ; digitos<=num_digitos(n) ; digitos++ , num/=10 ){
igualar(fator,save);
n_und = num%10;
if(digitos>1){
for(i0=1 ; i0<digitos ; i0++){ //"arredar" para a esquerda todos os numeros
for(i1=39998 ; i1>=0 ; i1--){ // 'digitos' vezes
if(fator[i1]!=-1)
fator[i1+1]=fator[i1];
}
}
for(i1=0 ; i1<(digitos-1) ; i1++) //Colocar 0's para simular a multiplicação pela
fator[i1]=0; // unidade(centena,milhar,...) em questão
}
for(i=0 ; i<40000 ; i++){
produto = fator[i]*n_und;
fator[i] = (produto+ vai1) % 10 ;
vai1 = (produto+vai1) / 10;
if(fator[i+1]==-1){
if(vai1==0)
i=40000; //"break" no for mais interno
else
fator[i+1]=0; //valor -1 resultaria em erros no cálculo
}
}
if(digitos!=1){
soma_vetorial(v,fator);
}
else{
igualar(v,fator);
}
}
}
}
int main(){
int v[40000];
int n;
printf("Digite um numero inteiro: ");
scanf("%d",&n);
preenche_vetor(v,n);
fatorial(n,v);
printf("Resultado: ");
//exibir_vetor(v);
return 0;
}
Servidor de Backup com Ubuntu Server 24.04 LTS, RAID e Duplicati (Dell PowerEdge T420)
Visualizar câmeras IP ONVIF no Linux sem necessidade de instalar aplicativos
Atualizar Debian Online de uma Versão para outra
Dica para encontrar diversos jogos Indies criativos
Instalando Discord no Debian 13
Instalar driver Nvidia no Debian 13
Redimensionando, espelhando, convertendo e rotacionando imagens com script
Software livre - será que eu estou tão errado assim? (11)
Boot do PosRog so funciona em notebook (1)