Menú

Mostrar Mensajes

Esta sección te permite ver todos los mensajes escritos por este usuario. Ten en cuenta que sólo puedes ver los mensajes escritos en zonas a las que tienes acceso en este momento.

Mostrar Mensajes Menú

Mensajes - dfr2198

#1
Programación C/C++ / Re: Buscador (C)
23 Mayo 2017, 11:22 AM
Bueno, pues aquí estoy otra vez. La funcion sscanf a veces no me carga. El rpograma avees arroja resultadoserroneos y a veces no, pero siempre se cuelga. Y ya no sé que más intentar despues de 5 horas frente al ordenador. Cuando el sscanf no funciona utilizo atoi. Pero me devuelve 0 en los arrays pese a que los printf (ver programa) me devuelven valores.

#include <stdio.h>
#include <string.h>
#include <stdlib.h>   
#include <windows.h>
#include <math.h>
int main (int argc, char *argv[])
{
char field [5000];
int buscador=0;
char cargavacio[10];
char carganombres[3400];
char cargacodigo[1500];
char cargapower[1500];
char cargav[1200];
char cargaisp[1100];
char cargaempuje[1100];
char delim[3]=", ";
char *cadenaauxiliar1;
int contador=0;
int contador2=1;
int y=0;
int j=0;
int contador3=0;
int resultados[150];
int objetivo=0;
char objetivof[50];
int numero;

strcpy(field, argv[1]);
FILE *fent;//Apertura de archivo.
fent=fopen (field, "r");
fgets(cargavacio, 10, fent);
fgets(carganombres, 3400, fent);
printf("Inicio comprobaciones\n");
for( contador=0; carganombres[contador] != ';'; contador++)//Aquí se realiza la cuenta para saber los elementos de char.
{
if (carganombres[contador]==' ' && carganombres[contador-1]==',')
{
contador2++;
}
}

printf("contador 2 fijado a %d\n", contador2);
int i=0;
char **nombre = (char**) calloc(contador2, sizeof(char*));
for ( i = 0; i < contador2; i++ )
{
    nombre[i] = (char*) calloc(500, sizeof(char));
}
char **codigo = (char**)calloc(contador2, sizeof(char*));

for ( i = 0; i < contador2; i++ )
{
    codigo[i] = (char*) calloc(500, sizeof(char));
}

double * power = malloc(contador2 * sizeof(int));
int * v = malloc(contador2 * sizeof(int));
int * isp = malloc(contador2 * sizeof(int));
double * empuje = malloc(contador2 * sizeof(int));

printf("Asignacion de memoria lista\n");

fgets (cargacodigo, 1500, fent);
fgets (cargapower, 1500, fent);
fgets (cargav,1200, fent);
fgets (cargaisp, 1100, fent);
fgets (cargaempuje, 1100, fent);
puts(cargaempuje);
puts(cargapower);
printf("Carga de datos de fichero completada");
y=0;
cadenaauxiliar1 = strtok(carganombres, delim);
while(cadenaauxiliar1!= NULL )
   {
       nombre[y]=cadenaauxiliar1;
   printf( " %s\n",nombre[y]);
  y++;
cadenaauxiliar1 = strtok(NULL, delim);
   }
printf("Distribucion de nombres lista\n");
contador3=y;
   y=0;
cadenaauxiliar1 = strtok(cargacodigo, delim);
while(cadenaauxiliar1!= NULL )
   {
  codigo[y]=cadenaauxiliar1;
 
  printf( " %s\n",codigo[y]);
  y++;
cadenaauxiliar1 = strtok(NULL, delim);
   }
   printf("distribucion de codigos completa\n");
y=0;
   cadenaauxiliar1 = strtok(cargapower, delim);
while(y<contador2 )
   {

  power[y]=atoi(cadenaauxiliar1);
   printf("%d\n",atoi(cadenaauxiliar1));

  y++;
cadenaauxiliar1 = strtok(NULL, delim);
   }
   
   printf("Power listo\n");
   y=0;
  cadenaauxiliar1 = strtok(cargav, delim);
while(y<contador2)
   {
sscanf(cadenaauxiliar1, "%d", &numero);
  v[y]=numero;
printf("%d\n",v[y]);
y++;
cadenaauxiliar1 = strtok(NULL, delim);
   }
   
   printf("V cargada\n");
   y=0;
   cadenaauxiliar1 = strtok(cargaisp, delim);
while(y<contador2 )
   {
sscanf(cadenaauxiliar1, "%d", &numero);
  isp[y]=numero;
printf("%d\n",isp[y]);
  y++;
cadenaauxiliar1 = strtok(NULL, delim);
   }
   
   printf("ISP cargado\n");
   y=0;
   cadenaauxiliar1 = strtok(cargaempuje, delim);
while(y<contador2)
{
empuje[y]=atoi(cadenaauxiliar1);
   printf("%d\n",atoi(cadenaauxiliar1));
y++;

cadenaauxiliar1 = strtok(NULL, delim);
   }
   
   printf("Empuje listo\n");
   

printf("A continuacion, indique los criterios de busqueda\n");
printf("Introduzca 1 para buscar por el nombre del sistema\n");
printf("Introduzca 2 para buscar por el codigo del sistema de propulsion\n");
printf("Introduzca 3 para buscar segun la energia del sistema (en MW)\n");
printf("Introduzca 4 para buscar en terminos de velocidad de escape de la masa de reaccion/propelente\n");
printf("Introduca 5 para buscar segun el Impulso especifico (en segundos)\n");
printf("Pulse 6 para buscar segun el empuje (en Newtons)\n");
printf("Pulse 0 para salir\n");
scanf("%d", &buscador);
i=0;
   switch(buscador)
{

case 1:

printf("Ha pulsado el 1\n");
printf("Introduzca el contenido a buscar.\n");
scanf("%s", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if (strcmp(nombre[i], objetivof) == 0);
{
printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
}
break;

case 2:

printf("Ha pulsado el 2\n");
printf("Introduzca el contenido a buscar.\n");
scanf("%s", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if (strcmp(codigo[i], objetivof) == 0);
{
printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
}

break;


case 3:
printf("Ha pulsado el 3\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if((power[i])> objetivo)
{ printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
i++;
}

break;


case 4:
printf("Ha pulsado el 4\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if((v[i])>objetivo)
{
printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
i++;
}


break;



case 5:
printf("Ha pulsado el 5\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if((isp[i])>objetivo)
{
printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
i++;
}


break;


case 6:
printf("Ha pulsado el 6\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
for(i=0; i<contador2; i++)
{
if((empuje[i])>objetivo)
{
printf("Nombre: %s\n", *nombre[i]);
printf("Tipo: %s\n", *codigo[i]);
printf("Energia: %d\n", power[i]);
printf("velocidad de escape: %d\n", v[i]);
printf("ISP: %d\n", isp[i]);
printf("Empuje: %d\n", empuje[i]);
}
i++;
}

break;

case 0:
exit(0);

break;

default:
{
printf("Ha introducido un caracter no incluido en el menu\n");
}
break;

}

printf("Busqueda y comparacion completada\n");




if(j!=0){
int sino=0;
int comp=0;
printf("¿Desea iniciar la funcion calculadora? [1 si, 0 no]");
scanf("%d", &sino);
if(sino==1)
{
float mf=0;
float mi=0;
float comb=0;
float resultado=0;
int n=0;

printf("Introduzca el dato de velocidad de escape del propulsor sleccionado.\n");
scanf("%d",&comp);
printf("¿Cuanto pesa el vehiculo?(en kg)\n");
scanf("%d",&mi);
printf("¿Cuantos kilos de combustible lleva?\n");
scanf("%d", &comb);
mf=comb+mi;
resultado=comp*log(mi/mf);
printf("Delta-V estimada: %f m/s\n", resultado);
}
}
for ( i = 0; i < contador2; i++ )
{
    free(nombre[i]);
}

free(nombre);
for ( i = 0; i < contador2; i++ )
{
    free(codigo[i]);
}

free(codigo);
free(v);
free(isp);
free(power);

free(empuje);
}
Código (xml) [Seleccionar]

DAWN-mission-NSTAR, Resistojet, Radioisotope, ArcJet
ESTAT, ETHERM, NTR-SOLID, ETHERM,
5, 9, 7, 85,
4, 6, 7, 83,
5, 3, 9, 27,
9, 5, 8, 55,
#2
Programación C/C++ / Re: Buscador (C)
22 Mayo 2017, 21:51 PM
MAFUS, primero de todo muchisimas gracias por llevarme hasta aquí.
Por desgracia, aun me queda mucho más por aprender. y lacosa va para largo. Y esto debería de estar acabado para mañana a las 5. Y me queda bastante grande.

EN primer lugar, tengo que decir un poco lo que debería de hacer el programa.
Leer los datos del txt y guardarlos en arrays de caracteres bidimensionales (nombre y codigo[numero de elementos][50] ) y el resto en arrays normales. (potencia)
Las premisas son que el txt está divido:
en lineas, de forma que cada fgets consigue una linea de codigo. por este motivo introduzco el char contador0, ya que la primera linea está en blanco (para que la asignacion dinamica de memoria dependiente de contador 2 funcione).

EN cada linea, los elementos etán separados en con una coma y un espacio. Y creo que el error del programa está justamente ahí: en estas lineas. En identificar los datos a extraer.

Luego debe de comparar esos datos con los que le indica el usuario. No se si hay errores ahí porque nunca llega tan lejos.
EL caso es que decidi usar printf para establecer qué va mal. Y le ordené dvolverme todos lo datos introducidos en la secuencia
nombre
cadena
vector
etc.
Consigo dos lineas en blanco y 5 lineas de 0.
Así que el problema está en sacar los datos de la cadena que sale de fgets (la he imprimido y sale) a los vectores.

Agradecería si alguien puede decirme como puedo hacerlo para fijar los criterios y que el programa ejecute. No es elegante ni bonito. Pero debería funcionar. Adjunto mas abajo el txt (de nuevo) y el programa completo, por si acaso.


for( x=0; x<strlen(nnombre); x++)
{
if(nnombre[x]!=',' && nnombre[x+1]!=' ')
{
nombre[z][y]=nnombre[x];
y++;
}
else{

z++;
y=0;
}
z=0;
y=0;
j=0;
}
for( x=0; x<strlen(ccodigo); x++)
{
if(ccodigo[x]!=',' && ccodigo[x+1]!=' ')
{
codigo[z][y]=ccodigo[x];
y++;
}
else{

z++;
y=0;
}
z=0;
y=0;
j=0;
}
for(x=0; x<strlen(ppower); x++)

{
if (((ppower[x+1])!=' ') && ((ppower[x])!=','))
{

auxiliar[y]=ppower[x];
y++;
x++;
}
else
{
y=0;
}


power[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}

y=0;
for(x=0; x<strlen(vv); x++)

{
if (((vv[x+1])!=' ') && ((vv[x])!=','))
{

auxiliar[y]=vv[x];
y++;
x++;
}
else
{
y=0;
}


v[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}


y=0;
for(x=0; x<strlen(iisp); x++)

{
if (((iisp[x+1])!=' ') && ((iisp[x])!=','))
{

auxiliar[y]=iisp[x];
y++;
x++;
}
else
{
y=0;
}

isp[zz]=atoi(auxiliar);
zz++;

suma=0;
zz=0;
}

y=0;
for(x=0; x<strlen(eempuje); x++)

{
if (((eempuje[x+1])!=' ') && ((eempuje[x])!=','))
{

auxiliar[y]=eempuje[x];
y++;
x++;
}
else
{
y=0;
}

empuje[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}


y=0;
for(x=0; x<strlen(ppeso); x++)

{
if (((ppeso[x+1])!=' ') && ((ppeso[x])!=','))
{

auxiliar[y]=ppeso[x];
y++;
x++;
}
else
{
y=0;
}
peso[zz]=atoi(auxiliar);
zz++;
}
suma=0;
zz=0;




Código (xml) [Seleccionar]

DAWN mission NSTAR, Resistojet, Radioisotope, ArcJet, Magneto Inertial Fusion (low), VASIMR (low gear), VASIMR (high gear), VASIMR (med gear), Space Shuttle RCS, Mirror Steamer, Solar Moth, Umbrella Ship, ArcJet, Hall Effect, Pulsed Plasmoid Thruster, Ponderomotive VASIMR, Ablative Laser, Tungsten Resistojet, NASA space tug, Mass Driver, Ion Drive, NERVA (CO or N2), NERVA (CO2), NERVA (H2O), NERVA (NH3), D-D Fusion Inertial, NERVA (CH4), Dusty Plasma (550AU), Colloid Thruster, NERVA (H2), Laser Thermal, Mass Driver, LANTR (high gear), Magneto Inertial Fusion (high), Aluminum/LOX rocket, NERVA (H), Vortex Confined (H2), LH2/LOX rocket, LANTR (low gear), Dual-mode Fission (H2), Cermet NERVA (H2), Bimodal NTR Solid (NASA), Ion, D-T Fusion, NERVA Deriv (H2), Antimatter Bottle, n-6Li Microfission, Pebble Bed (H2), Vapor Core (H2), Tokamak MC, Antimatter Solid max, Dusty Plasma (0.5LY), Proton RD-253 x1, NTR Gas/Closed (H2), ORION Fission, THS Fusion Pulse high gear, THS Fusion Pulse low gear, ORION Fusion, saturn V F-1 (x1), Space Shuttle SSME x3, Solid rocket, Proton RD-253 x6, VISTA, Project Orion, Nuclear DC-X NERVA, APCP Space Shuttle SRB x2, ORION USAF 10m, NTR Solid MAX, Gasdynamic Mirror, Nuclear DC-X LANTR, NTR Liquid max, Saturn-V F-1 x5, NTR Gas/Open (H2), NTR Gas/Open 2nd Gen, Mini-Mag Orion, NTR Gas MAX, NTR Gas/Coaxial (H2), He3-D Fusion, MC-Fusion MAX, ORION battleship, ORION 10k ton adv, ORION MAX, Antimatter Beam MAX, IC-Fusion MAX;
ESTAT, ETHERM, NTR SOLID, ETHERM, EMAG, EMAG, EMAG, PULSE, EMAG, EMAG, EMAG,CHEM LIQUID, BEAM, BEAM, ESTAT, ETHERM, ESTAT, PULSE, EMAG, BEAM, ETHERM, CHEM LIQUID, OTHER, ESTAT, NTR SOLID, NTR SOLID, NTR SOLID, NTR SOLID, PULSE, NTR SOLID, NTR FRAG, ESTAT, NTR SOLID, BEAM, OTHER, NTR SOLID, PULSE, CHEM LIQUID, NTR SOLID, NTR GAS OP, CHEM LIQUID, NTR SOLID, NTR SOLID, NTR SOLID, NTR SOLID, ESTAT, FUSION, NTR SOLID, PULSE, PULSE, NTR SOLID, NTR VAPOR, FUSION, AM SOLID, NTR FRAG, CHEM LIQUI, NTR GAS CL, PULSE, PULSE, PULSE, PULSE, CHEM LIQUID, CHEM LIQUID, CHEM SOLID, CHEM LIQUID, PULSE, PULSE, NTR SOLID, CHEM SOLID,PULSE, NTR SOLID, FUSION, NTR SOLID, NTR GAS OP, CHEM LIQUID, NTR GAS OP, NTR GAS OP, PULSE, NTR GAS OP, NTR GAS OP, FUSION, FUSION, PULSE, PULSE, PULSE, AM BEAM, PULSE;
1.37e-06, 7.25e-04, 5.85e-03, 2.00e-02, 3, 6, 6, 6, 6, 13, 18, 20, 31, 32, 43, 44, 47, 49, 49, 51, 57, 65, 81, 99, 125, 126, 155, 165, 172, 198, 260, 300, 309, 348, 388, 392, 494, 540, 584, 612, 659, 898, 1,05, 1,188, 1,35, 1,362, 1,57, 1,59, 1,617, 2,231, 2,374, 2,58, 2,836, 4,54, 5,654, 6, 6, 10,658, 11,541, 12,115, 15, 16,228, 20,4, 21,731, 27,272, 31,2, 32,9, 42, 46,06, 49,206, 56, 58,054, 61,25, 125, 146,795, 147, 157,156, 192,08, 200, 1,560,000, 24,000,000, 39,200,000, 500,000,000, 500,000,000;
30,411, 2,9, 7,8, 20, 50,42, 29, 294, 147, 3,1 ,9,81, 9, 80,442, 19,62, 19,62, 78,48, 39,24, 39,24, 9,81, 4,4, 9,81, 78,48, 2,649, 3,306, 4,042, 5,101, 78,48, 6,318, 15,000,000, 43, 8,093, 40, 30, 9,221, 50,42, 2,649, 16, 19,62, 4,905, 6,347, 9,81, 9,81, 8,98, 210, 22, 8,085, 78,48, 156,96, 9,53 ,9,8, 66,8, 10,791, 15,000,000, 3,1, 20,405, 43, 300, 150, 73, 2,982, 4,444, 3, 3,1, 170, 19,62, 9,81, 2,6, 32,9, 12, 1,960,000, 5,9, 16, 3, 35, 50, 157, 98, 17,658, 7,840,000, 8,000,000, 39, 120, 9,800,000, 100,000,000, 10,000,000;
3,1, 296, 795, 2,039, 5,14, 2,956, 29,969, 14,985, 316, 1, 917, 8,2, 2, 2, 8, 4, 4, 1, 449, 1, 8, 270, 337, 412, 520, 8, 644, 1,529,052, 4,383, 825, 4,077, 3,058, 940, 5,14, 270, 1,631, 2, 500, 647, 1, 1, 915, 21,407, 2,243, 824, 8, 16, 971, 999, 6,809, 1,1, 1,529,052, 316, 2,08, 4,383, 30,581, 15,291, 7,441, 304, 453, 306, 316, 17,329, 2, 1, 265, 3,354, 1,223, 199,796, 601, 1,631, 306, 3,568, 5,097, 16,004, 9,99, 1,8, 799,185, 815,494, 3,976, 12,232, 998,981, 10,193,680, 1,019,368;
9.00e-05, 1, 2, 2, 103, 400, 40, 80, 3,87, 2,6, 4, 490, 3,2, 3,3, 1,1, 2,25, 2,4, 9,9, 22,4, 10,4, 1,444, 49, 49, 49, 49, 3,2, 49, 22, 8, 49, 13, 20, 67, 13,8, 292,6, 49, 50,4, 220, 184, 124,7, 134,4, 200, 10, 108, 334,061, 34,7, 20, 333,617, 330, 66,8, 440, 344, 1,830,000, 445, 263, 40, 80, 292, 7,740,500, 5,452,200, 10,000,000, 10,470,000, 240, 2,215,200, 5,560,000, 24,000,000, 2,000,000, 7,000,000, 47, 16,680,000, 7,000,000, 38,702,500, 3,500,000, 5,000,000, 1,870,000, 3,000,000, 17,800,000, 49, 50, 80,000,000, 400,000,000, 8,000,000, 10,000,000, 100,000,000;
26, N/A, N/A, N/A, N/A, 10, 10, 10, 4, 20,977, 100, N/A, 22,369, 85,469, 83,611, 43,796, 22,222, 42,601, 199,6, 163, 120,149, 10, 10, 10, 10, 243,333, 10, 9, 20, 10, 20, 150, N/A, N/A, 56, 10, 114,116, 26,667, N/A, 33, 32,546, 6,672, 400, 10, 10,1, 180, 106,667, 1,7, 6,83, 197, N/A, 9, 1,26, 56,8, 200, 4, 4, 200, 9,153, 9,531, N/A, 7,56, N/A, 203,68, 199,6, 1,180,000, 107,9, 15, N/A, 199,6, 70, 45,765, 200, 200, 199,6, 15, 127, 1,200,000, 600, 1,700,000, 3,250,000, 8, 10, 1,000,000;





#include <stdio.h>
#include <string.h>
#include <stdlib.h>   
#include <windows.h>
#include <math.h>
int main (int argc, char *argv[])
{
char field [5000];
int buscador=0;


printf("A continuacion, indique los criterios de busqueda\n");
printf("Introduzca 1 para buscar por el nombre del sistema\n");
printf("Introduzca 2 para buscar por el codigo del sistema de propulsion\n");
printf("Introduzca 3 para buscar segun la energia del sistema (en MW)\n");
printf("Introduzca 4 para buscar en terminos de velocidad de escape de la masa de reaccion/propelente\n");
printf("Introduca 5 para buscar segun el Impulso especifico (en segundos)\n");
printf("Pulse 6 para buscar segun el empuje (en Newtons)\n");
printf("Con el 7, buscara segun la masa del motor(se mostraran los valores iguales o mas pequenos)\n");
printf("Pulse 0 para salir\n");
scanf("%d", &buscador);
printf("Seleccione el contenido a buscar. tenga en cuenta que para valores numericos distintos del peso,\n se mostraran cantidades iguales o SUPERIORES\n");

int contador=0;
int contador2=2;
char contador0[10];
char contadorf[15000];
int j=0;
int objetivo;
strcpy(field, argv[1]);
FILE *fent;//Apertura de archivo.
fent=fopen (field, "r");

char auxilar[100];


if (fent==NULL)
{
printf("ERROR DE APERTURA DE %d\n",field);//Comprobación de errores en apertura.
exit(0);
}


printf("Se ha completado la carga del archivo\n");
fgets(contador0, 10, fent);
fgets(contadorf, 5000, fent);
for( contador=0; contadorf[contador] != ';'; contador++)//Aquí se realiza la cuenta para saber los elementos de char.
{
if (((contadorf[contador+1])==' ') && ((contadorf[contador])==','))
{
contador2++;
}
}

char nnombre[5000];
char ccodigo[5000];
char ppower[5000];
char vv[5000];
char iisp[5000];
char eempuje[5000];
char ppeso[5000];

printf("Se ha completado comprobacion de longitud\n");

int i=0;
char **nombre = (char**) calloc(contador2, sizeof(char*));
for ( i = 0; i < contador2; i++ )
{
    nombre[i] = (char*) calloc(500, sizeof(char));
}
char **codigo = (char**)calloc(contador2, sizeof(char*));

for ( i = 0; i < contador2; i++ )
{
    codigo[i] = (char*) calloc(500, sizeof(char));
}

float * power = malloc(contador2 * sizeof(float));
float * v = malloc(contador2 * sizeof(float));
float * isp = malloc(contador2 * sizeof(float));
float * empuje = malloc(contador2 * sizeof(float));
float * peso = malloc(contador2 * sizeof(float));
int x=0, y=0, z=0, xx=0, yy=0, zz=0;
char auxiliar[40];
float suma=0;

printf("%d\n",contador2);

printf("Asignacion de memoria completada\n");

fgets(contador0,10,fent);
fgets(nnombre, 5000, fent);
fgets(ccodigo,5000,fent);
fgets(ppower,5000,fent);
fgets(vv,5000,fent);
fgets(iisp,5000,fent);
fgets(eempuje,5000,fent);
fgets(ppeso,5000,fent);

puts(nnombre);
puts(ccodigo);
puts(ppower);
puts(vv);
puts(iisp);
puts(eempuje);
puts(ppeso);


for( x=0; x<strlen(nnombre); x++)
{
if(nnombre[x]!=',' && nnombre[x+1]!=' ')
{
nombre[z][y]=nnombre[x];
y++;
}
else{

z++;
y=0;
}
z=0;
y=0;
j=0;
}
for( x=0; x<strlen(ccodigo); x++)
{
if(ccodigo[x]!=',' && ccodigo[x+1]!=' ')
{
codigo[z][y]=ccodigo[x];
y++;
}
else{

z++;
y=0;
}
z=0;
y=0;
j=0;
}
for(x=0; x<strlen(ppower); x++)

{
if (((ppower[x+1])!=' ') && ((ppower[x])!=','))
{

auxiliar[y]=ppower[x];
y++;
x++;
}
else
{
y=0;
}


power[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}

y=0;
for(x=0; x<strlen(vv); x++)

{
if (((vv[x+1])!=' ') && ((vv[x])!=','))
{

auxiliar[y]=vv[x];
y++;
x++;
}
else
{
y=0;
}


v[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}


y=0;
for(x=0; x<strlen(iisp); x++)

{
if (((iisp[x+1])!=' ') && ((iisp[x])!=','))
{

auxiliar[y]=iisp[x];
y++;
x++;
}
else
{
y=0;
}

isp[zz]=atoi(auxiliar);
zz++;

suma=0;
zz=0;
}

y=0;
for(x=0; x<strlen(eempuje); x++)

{
if (((eempuje[x+1])!=' ') && ((eempuje[x])!=','))
{

auxiliar[y]=eempuje[x];
y++;
x++;
}
else
{
y=0;
}

empuje[zz]=atoi(auxiliar);
zz++;
suma=0;
zz=0;
}


y=0;
for(x=0; x<strlen(ppeso); x++)

{
if (((ppeso[x+1])!=' ') && ((ppeso[x])!=','))
{

auxiliar[y]=ppeso[x];
y++;
x++;
}
else
{
y=0;
}
peso[zz]=atoi(auxiliar);
zz++;
}
suma=0;
zz=0;



fclose (fent);

printf("Carga de datos a programa completada\n");
for(i=0; i<=contador2; i++)
{ printf("%c\n", *nombre[i]);
printf("%c\n",*codigo[i]);
printf("%f\n", power[i]);
printf("%f\n", v[i]);
printf("%f\n", isp[i]);
printf("%f\n", empuje[i]);
printf("%f\n", peso[i]);
}


int * resultados = malloc(contador2 * sizeof(int));
i=0;
j=0;
char objetivof[50];
switch(buscador)
{

case 1:

printf("Ha pulsado el 1\n");
printf("Introduzca el contenido a buscar.");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(nombre[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;

case 2:

printf("Ha pulsado el 2\n");
printf("Introduzca el contenido a buscar.\n");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(codigo[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 3:
printf("Ha pulsado el 3\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((power[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 4:
printf("Ha pulsado el 4\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((v[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}


break;


case 5:
printf("Ha pulsado el 5\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((isp[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 6:
printf("Ha pulsado el 6\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((empuje[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 7:
printf ("Ha pulsado el 7\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((peso[i])<=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;

case 0:
exit(0);


default:
{
printf("Ha introducido un caracter no incluido en el menu\n");
}
break;
}

printf("Busqueda y comparacion completada\n");

if(j != 0)
{
printf("Se han encontrado los siguientes resultados que concuerdan con el criterio:\n");
for(i=0; i!=j; i++)
{
printf("%c\n", *nombre[resultados[i]]);
printf("[%d]\n",i);
}
}
if (j != 0)
{
int sino=0;
int comp=1;
printf("¿Desea ver los datos de alguno de los sistemas presentados? [1 si, 0 no]\n");
scanf("%c", &sino);
if(sino==1)
{
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, insertelo a continuacion.\n");
printf("Para salir, presione el [0].\n");
while(comp!=0)
{ scanf("%d", &comp);
printf("Nombre: %c", *nombre[comp]);
printf("Tipo: %c", *codigo[comp]);
printf("Energia: %f", power[comp]);
printf("velocidad de escape: %f", v[comp]);
printf("ISP: %f", isp[comp]);
printf("Empuje: %f", empuje[comp]);
printf("Peso: %f", peso[comp]);
printf("Introduzca más datos, o pulse 0 para salir.\n");
}
}
}
if(j != 0)
{
int sino=0;
int comp=0;
printf("¿Desea iniciar la funcion calculadora? [1 si, 0 no]");
scanf("%c", &sino);
if(sino==1)
{
float mf=0;
float mi=0;
float comb=0;
float resultado=0;
int n=0;
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, inserte a continuacion el numero del motor a utilizar.\n");
scanf("%d",&comp);
printf("¿Cuantos motores va a llevar?\n");
scanf("%d",&n);
printf("¿Cuanto pesa el vehiculo?(en kg)\n");
scanf("%d",&mi);
printf("¿Cuantos kilos de combustible lleva?\n");
scanf("%d", &comb);
mf=comb+mi+peso[comp]*n;
resultado=v[comp]*log(mi/mf);
printf("Delta-V estimada: %f m/s\n");
if(mf*9,8>=empuje[comp]*n)
{
printf("¡ADVERTENCIA! No podrás despegar de la Tierra usando este vehículo.\n");
}
}
}
for ( i = 0; i < contador2; i++ )
{
    free(nombre[i]);
}

free(nombre);
for ( i = 0; i < contador2; i++ )
{
    free(codigo[i]);
}

free(codigo);
free(v);
free(isp);
free(power);
free(peso);
free(empuje);


}

#3
Programación C/C++ / Re: Buscador (C)
21 Mayo 2017, 18:48 PM
Finalmente, he resuelto todos los errores de compilación y tengo un codigo operativo al 90%. Salvo.... Que falla la parte más importante. No es capaz de cargar los datos que posee en la cadena resultado del fgets a los vectores y cadenas correspondientes para su análisis. Y ya no sé como solucionarlo.

SI a alguno se le ocurriera que puede estar mal, sería de gran ayuda.

#include <stdio.h>
#include <string.h>
#include <stdlib.h>   
#include <windows.h>
#include <math.h>
int main (int argc, char *argv[])
{
char field [5000];
int buscador=0;


printf("A continuacion, indique los criterios de busqueda\n");
printf("Introduzca 1 para buscar por el nombre del sistema\n");
printf("Introduzca 2 para buscar por el código del sistema de propulsion\n");
printf("Introduzca 3 para buscar según la energia del sistema (en MW)\n");
printf("Introduzca 4 para buscar en terminos de velocidad de escape de la masa de reaccion\n");
printf("Introduca 5 para buscar segun el Impulso especifico (en segundos)\n");
printf("Pulse 6 para buscar según el empuje (en Newtons)\n");
printf("Con el 7, buscará según la masa del motor(se mostraran los valores iguales o mas pequeños)\n");
printf("Pulse 0 para salir\n");
scanf("%d", &buscador);
printf("Seleccione el contenido a buscar. tenga en cuenta que para valores numericos distintos del peso,\n se mostraran cantidades iguales o SUPERIORES\n");

int contador=1;
int contador2=0;
char contadorf[500000];

int objetivo;
strcpy(field, argv[1]);
FILE *fent;//Apertura de archivo.
fent=fopen (field, "r");



if (fent==NULL)
{
printf("ERROR DE APERTURA DE %d\n",field);//Comprobación de errores en apertura.
exit(0);
}


printf("Se ha completado la carga del archivo\n");

fgets(contadorf, 5000, fent);
for(contadorf[contador] != ';'; contador=0; contador++)//Aquí se realiza la cuenta para saber los elementos de char.
{
if (((contadorf[contador])!=' ') && ((contadorf[contador-1])!=','))
{
contador2++;
}
}



printf("Se ha completado comprobación de longitud\n");

int i=0;
char **nombre = (char**) calloc(contador2, sizeof(char*));
for ( i = 0; i < contador2; i++ )
{
    nombre[i] = (char*) calloc(500, sizeof(char));
}
char **codigo = (char**)calloc(contador2, sizeof(char*));

for ( i = 0; i < contador2; i++ )
{
    codigo[i] = (char*) calloc(500, sizeof(char));
}

float * power = malloc(contador2 * sizeof(float));
float * v = malloc(contador2 * sizeof(float));
float * isp = malloc(contador2 * sizeof(float));
float * empuje = malloc(contador2 * sizeof(float));
float * peso = malloc(contador2 * sizeof(float));
int x=0, y=0, z=0, xx=0, yy=0, zz=0;
char auxiliar[40];
float suma=0;

printf("Asignacion de memoria completada\n");

fgets(contadorf, 7000, fent);

for(contadorf[x]!=';'; x=0; x++)

{
while (((contadorf[x])!=' ') && ((contadorf[x-1])!=','))
{
y=0;
nombre[x][y]=contadorf[x+y];
y++;
}
}
for(contadorf[x]!=';'; x; x++)
{

while (((contadorf[x])!=' ') && ((contadorf[x-1])!=','))
{
y=0;
codigo[z][y]=contadorf[x+y];
y++;
}
z++;
}
for(contadorf[x]!=';'; x; x++)
{
{

while (contadorf[xx]!=' ')
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{

(auxiliar[xx]=(int)auxiliar[xx]);
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=power[zz];
zz++;
}
suma=0;
zz=0;
for(contadorf[x]!=';'; x; x++)
{
{

while (contadorf[xx]!=' ')
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
(auxiliar[xx]=(int)auxiliar[xx]);
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=v[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=';'; x; x++)
{
{

while (contadorf[xx]!=' ')
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
(auxiliar[xx]=(int)auxiliar[xx]);
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=isp[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=';'; x; x++)
{
{

while (contadorf[xx]!=' ')
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
(auxiliar[xx]=(int)auxiliar[xx]);
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=empuje[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=';'; x; x++)
{
{

while (contadorf[xx]!=' ')
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
(auxiliar[xx]=(int)auxiliar[xx]);
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=peso[zz];
zz++;
}
}
}

fclose (fent);

printf("Carga de datos a programa completada\n");
for(i<=contador2; i=0;i++)
{ printf("%c\n", *nombre[i]);
printf("%c\n",*codigo[i]);
printf("%f\n", power[i]);
printf("%f\n", v[i]);
printf("%f\n", isp[i]);
printf("%f\n", empuje[i]);
printf("%f\n", peso[i]);
}


int * resultados = malloc(contador2 * sizeof(int));
i=0;
int j=0;
char objetivof[50];
switch(buscador)
{

case 1:

printf("Ha pulsado el 1\n");
printf("Introduzca el contenido a buscar.");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(nombre[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;

case 2:

printf("Ha pulsado el 2\n");
printf("Introduzca el contenido a buscar.\n");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(codigo[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 3:
printf("Ha pulsado el 3\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((power[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 4:
printf("Ha pulsado el 4\n");
printf("Introduzca el contenido a buscar.\n");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((v[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}


break;


case 5:
printf("Ha pulsado el 5\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((isp[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 6:
printf("Ha pulsado el 6\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((empuje[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 7:
printf ("Ha pulsado el 7\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((peso[i])<=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;

case 0:
exit(0);


default:
{
printf("Ha introducido un caracter no incluido en el menu\n");
}
break;
}

printf("Busqueda y comparacion completada\n");

if(j != 0)
{
printf("Se han encontrado los siguientes resultados que concuerdan con el criterio:\n");
for(i=0; i!=j; i++)
{
printf("%c\n", *nombre[resultados[i]]);
printf("[%d]\n",i);
}
}
if (j != 0)
{
int sino=0;
int comp=1;
printf("¿Desea ver los datos de alguno de los sistemas presentados? [1 si, 0 no]\n");
scanf("%c", &sino);
if(sino==1)
{
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, insertelo a continuacion.\n");
printf("Para salir, presione el [0].\n");
while(comp!=0)
{ scanf("%d", &comp);
printf("Nombre: %c", *nombre[comp]);
printf("Tipo: %c", *codigo[comp]);
printf("Energia: %f", power[comp]);
printf("velocidad de escape: %f", v[comp]);
printf("ISP: %f", isp[comp]);
printf("Empuje: %f", empuje[comp]);
printf("Peso: %f", peso[comp]);
printf("Introduzca más datos, o pulse 0 para salir.\n");
}
}
}
if(j != 0)
{
int sino=0;
int comp=0;
printf("¿Desea iniciar la funcion calculadora? [1 si, 0 no]");
scanf("%c", &sino);
if(sino==1)
{
int mf=0;
int mi=0;
int comb=0;
float resultado=0;
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, insertelo a continuacion.\n");
scanf("%d",&comp);
printf("¿Cuanto pesa el vehiculo?(en kg)\n");
scanf("%d",&mi);
printf("¿Cuantos kilos de combustible lleva?\n");
scanf("%d", &comb);
mf=comb+mi;
resultado=v[comp]*log(mi/mf);
printf("Delta-V estimada: %f m/s\n");
}
}
for ( i = 0; i < contador2; i++ )
{
    free(nombre[i]);
}

free(nombre);
for ( i = 0; i < contador2; i++ )
{
    free(codigo[i]);
}

free(codigo);
free(v);
free(isp);
free(power);
free(peso);
free(empuje);


}


Este es el txt a cragar 
Código (xml) [Seleccionar]
DAWN mission NSTAR, Resistojet, Radioisotope, ArcJet, Magneto Inertial Fusion (low), VASIMR (low gear), VASIMR (high gear), VASIMR (med gear), Space Shuttle RCS, Mirror Steamer, Solar Moth, Umbrella Ship, ArcJet, Hall Effect, Pulsed Plasmoid Thruster, Ponderomotive VASIMR, Ablative Laser, Tungsten Resistojet, NASA space tug, Mass Driver, Ion Drive, NERVA (CO or N2), NERVA (CO2), NERVA (H2O), NERVA (NH3), D-D Fusion Inertial, NERVA (CH4), Dusty Plasma (550AU), Colloid Thruster, NERVA (H2), Laser Thermal, Mass Driver, LANTR (high gear), Magneto Inertial Fusion (high), Aluminum/LOX rocket, NERVA (H), Vortex Confined (H2), LH2/LOX rocket, LANTR (low gear), Dual-mode Fission (H2), Cermet NERVA (H2), Bimodal NTR Solid (NASA), Ion, D-T Fusion, NERVA Deriv (H2), Antimatter Bottle, n-6Li Microfission, Pebble Bed (H2), Vapor Core (H2), Tokamak MC, Antimatter Solid max, Dusty Plasma (0.5LY), Proton RD-253 x1, NTR Gas/Closed (H2), ORION Fission, THS Fusion Pulse high gear, THS Fusion Pulse low gear, ORION Fusion, saturn V F-1 (x1), Space Shuttle SSME x3, Solid rocket, Proton RD-253 x6, VISTA, Project Orion, Nuclear DC-X NERVA, APCP Space Shuttle SRB x2, ORION USAF 10m, NTR Solid MAX, Gasdynamic Mirror, Nuclear DC-X LANTR, NTR Liquid max, Saturn-V F-1 x5, NTR Gas/Open (H2), NTR Gas/Open 2nd Gen, Mini-Mag Orion, NTR Gas MAX, NTR Gas/Coaxial (H2), He3-D Fusion, MC-Fusion MAX, ORION battleship, ORION 10k ton adv, ORION MAX, Antimatter Beam MAX, IC-Fusion MAX;ESTAT, ETHERM, NTR SOLID, ETHERM, EMAG, EMAG, EMAG, PULSE, EMAG, EMAG, EMAG,CHEM LIQUID, BEAM, BEAM, ESTAT, ETHERM, ESTAT, PULSE, EMAG, BEAM, ETHERM, CHEM LIQUID, OTHER, ESTAT, NTR SOLID, NTR SOLID, NTR SOLID, NTR SOLID, PULSE, NTR SOLID, NTR FRAG, ESTAT, NTR SOLID, BEAM, OTHER, NTR SOLID, PULSE, CHEM LIQUID, NTR SOLID, NTR GAS OP, CHEM LIQUID, NTR SOLID, NTR SOLID, NTR SOLID, NTR SOLID, ESTAT, FUSION, NTR SOLID, PULSE, PULSE, NTR SOLID, NTR VAPOR, FUSION, AM SOLID, NTR FRAG, CHEM LIQUI, NTR GAS CL, PULSE, PULSE, PULSE, PULSE, CHEM LIQUID, CHEM LIQUID, CHEM SOLID, CHEM LIQUID, PULSE, PULSE, NTR SOLID, CHEM SOLID,PULSE, NTR SOLID, FUSION, NTR SOLID, NTR GAS OP, CHEM LIQUID, NTR GAS OP, NTR GAS OP, PULSE, NTR GAS OP, NTR GAS OP, FUSION, FUSION, PULSE, PULSE, PULSE, AM BEAM, PULSE; 1.37e-06, 7.25e-04, 5.85e-03, 2.00e-02, 3, 6, 6, 6, 6, 13, 18, 20, 31, 32, 43, 44, 47, 49, 49, 51, 57, 65, 81, 99, 125, 126, 155, 165, 172, 198, 260, 300, 309, 348, 388, 392, 494, 540, 584, 612, 659, 898, 1,05, 1,188, 1,35, 1,362, 1,57, 1,59, 1,617, 2,231, 2,374, 2,58, 2,836, 4,54, 5,654, 6, 6, 10,658, 11,541, 12,115, 15, 16,228, 20,4, 21,731, 27,272, 31,2, 32,9, 42, 46,06, 49,206, 56, 58,054, 61,25, 125, 146,795, 147, 157,156, 192,08, 200, 1,560,000, 24,000,000, 39,200,000, 500,000,000, 500,000,000; 30,411, 2,9, 7,8, 20, 50,42, 29, 294, 147, 3,1 ,9,81, 9, 80,442, 19,62, 19,62, 78,48, 39,24, 39,24, 9,81, 4,4, 9,81, 78,48, 2,649, 3,306, 4,042, 5,101, 78,48, 6,318, 15,000,000, 43, 8,093, 40, 30, 9,221, 50,42, 2,649, 16, 19,62, 4,905, 6,347, 9,81, 9,81, 8,98, 210, 22, 8,085, 78,48, 156,96, 9,53 ,9,8, 66,8, 10,791, 15,000,000, 3,1, 20,405, 43, 300, 150, 73, 2,982, 4,444, 3, 3,1, 170, 19,62, 9,81, 2,6, 32,9, 12, 1,960,000, 5,9, 16, 3, 35, 50, 157, 98, 17,658, 7,840,000, 8,000,000, 39, 120, 9,800,000, 100,000,000, 10,000,000; 3,1, 296, 795, 2,039, 5,14, 2,956, 29,969, 14,985, 316, 1, 917, 8,2, 2, 2, 8, 4, 4, 1, 449, 1, 8, 270, 337, 412, 520, 8, 644, 1,529,052, 4,383, 825, 4,077, 3,058, 940, 5,14, 270, 1,631, 2, 500, 647, 1, 1, 915, 21,407, 2,243, 824, 8, 16, 971, 999, 6,809, 1,1, 1,529,052, 316, 2,08, 4,383, 30,581, 15,291, 7,441, 304, 453, 306, 316, 17,329, 2, 1, 265, 3,354, 1,223, 199,796, 601, 1,631, 306, 3,568, 5,097, 16,004, 9,99, 1,8, 799,185, 815,494, 3,976, 12,232, 998,981, 10,193,680, 1,019,368; 9.00e-05, 1, 2, 2, 103, 400, 40, 80, 3,87, 2,6, 4, 490, 3,2, 3,3, 1,1, 2,25, 2,4, 9,9, 22,4, 10,4, 1,444, 49, 49, 49, 49, 3,2, 49, 22, 8, 49, 13, 20, 67, 13,8, 292,6, 49, 50,4, 220, 184, 124,7, 134,4, 200, 10, 108, 334,061, 34,7, 20, 333,617, 330, 66,8, 440, 344, 1,830,000, 445, 263, 40, 80, 292, 7,740,500, 5,452,200, 10,000,000, 10,470,000, 240, 2,215,200, 5,560,000, 24,000,000, 2,000,000, 7,000,000, 47, 16,680,000, 7,000,000, 38,702,500, 3,500,000, 5,000,000, 1,870,000, 3,000,000, 17,800,000, 49, 50, 80,000,000, 400,000,000, 8,000,000, 10,000,000, 100,000,000; 26, N/A, N/A, N/A, N/A, 10, 10, 10, 4, 20,977, 100, N/A, 22,369, 85,469, 83,611, 43,796, 22,222, 42,601, 199,6, 163, 120,149, 10, 10, 10, 10, 243,333, 10, 9, 20, 10, 20, 150, N/A, N/A, 56, 10, 114,116, 26,667, N/A, 33, 32,546, 6,672, 400, 10, 10,1, 180, 106,667, 1,7, 6,83, 197, N/A, 9, 1,26, 56,8, 200, 4, 4, 200, 9,153, 9,531, N/A, 7,56, N/A, 203,68, 199,6, 1,180,000, 107,9, 15, N/A, 199,6, 70, 45,765, 200, 200, 199,6, 15, 127, 1,200,000, 600, 1,700,000, 3,250,000, 8, 10, 1,000,000;
#4
Programación C/C++ / Re: Buscador (C)
20 Mayo 2017, 19:48 PM
Código (xml) [Seleccionar]
A continuacion, indique los criterios de busqueda
Introduzca 1 para buscar por el nombre del sistema
Introduzca 2 para buscar por el c├│digo del sistema de propulsion
Introduzca 3 para buscar seg├║n la energia del sistema (en MW)
Introduzca 4 para buscar en terminos de velocidad de escape de la masa de reaccion
Introduca 5 para buscar segun el Impulso especifico (en segundos)
Pulse 6 para buscar seg├║n el empuje (en Newtons)
Con el 7, buscará según la masa del motor(se mostraran los valores iguales o mas pequeños)
Pulse 0 para salir
5
Seleccione el contenido a buscar. tenga en cuenta que para valores numericos distintos del peso,
se mostraran cantidades iguales o SUPERIORES
Se ha completado la carga del archivo

y ahí "programa.exe ha dejado de funcionar".
He tomado nota y corregido vuestras indicaciones, sustituyendo por ejemplo
for(contadorf[contador] != ';'; contador=0; contador++)//Aquí se realiza la cuenta para saber los elementos de char.
{
if (contadorf[contador]==', ')
{
contador2++;
}
}

if (fent==NULL)
{
printf("ERROR DE APERTURA DE %d\n",field);//Comprobación de errores en apertura.
exit(0);
}
#5
Programación C/C++ / Re: Buscador (C)
20 Mayo 2017, 19:19 PM
Bueno, pues ya está. Un programa de 628 lineas de codigo, todas ellas dentro de la función principal hasta que me funcione bien y vea qué puedo separar... Y se atasca en la 39.
El programa se cuelga y windows me lo cierra. Y es entre la linea 39 y 51. Y ya no sé qué hacer.
Asíque acudo aquí a ver si a alguien se le ocure algo.
Sí. Probablemente sea el codigo más basura que hayáis visto, incluso a mi me parece feo a la vista. Pero...
(Y si alguen me dice a que se debe o como solucionar los warning de "comparision between pointer and integeer" (lineas de la 41 a la 385) ya me salava del todo)
#include <stdio.h>
#include <string.h>
#include <stdlib.h>  
#include <windows.h>
#include <math.h>
int main (int argc, char *argv[])
{
char field [5000];
int buscador=0;


printf("A continuacion, indique los criterios de busqueda\n");
printf("Introduzca 1 para buscar por el nombre del sistema\n");
printf("Introduzca 2 para buscar por el código del sistema de propulsion\n");
printf("Introduzca 3 para buscar según la energia del sistema (en MW)\n");
printf("Introduzca 4 para buscar en terminos de velocidad de escape de la masa de reaccion\n");
printf("Introduca 5 para buscar segun el Impulso especifico (en segundos)\n");
printf("Pulse 6 para buscar según el empuje (en Newtons)\n");
printf("Con el 7, buscará según la masa del motor(se mostraran los valores iguales o mas pequeños)\n");
printf("Pulse 0 para salir\n");
scanf("%d", &buscador);
printf("Seleccione el contenido a buscar. tenga en cuenta que para valores numericos distintos del peso,\n se mostraran cantidades iguales o SUPERIORES\n");

int contador=1;
int contador2=0;
char contadorf[500000];

int objetivo;
strcpy(field, argv[1]);
FILE *fent;//Apertura de archivo.
fent=fopen (field, "r");



if (fent==NULL)
{
printf("ERROR DE APERTURA DE %d\n",field);//Comprobación de errores en apertura.
}
printf("Se ha completado la carga del archivo\n");

fgets(contadorf, 5000, fent)
for(contadorf[contador] != ";"; contador=0; contador++)//Aquí se realiza la cuenta para saber los elementos de char.
{
if (contadorf[contador]==",")
{
contador2++;
}
}


printf("Se ha completado comprobación de longitud\n");

int i=0;
char **nombre = (char**) calloc(contador2, sizeof(char*));

for ( i = 0; i < contador2; i++ )
{
   nombre[i] = (char*) calloc(500, sizeof(char));
}
char **codigo = (char**) calloc(contador2, sizeof(char*));

for ( i = 0; i < contador2; i++ )
{
   codigo[i] = (char*) calloc(500, sizeof(char));
}

float * power = malloc(contador2 * sizeof(float));
float * v = malloc(contador2 * sizeof(float));
float * isp = malloc(contador2 * sizeof(float));
float * empuje = malloc(contador2 * sizeof(float));
float * peso = malloc(contador2 * sizeof(float));
int x=0, y=0, z=0, xx=0, yy=0, zz=0;
char auxiliar[40];
float suma=0;

printf("Asignacion de memoria completada\n");

for(fgets(contadorf, contador2, fent)!=EOF; contador=0; contador++)
{
for(contadorf[x]!=";"; x=0; x++)

{
while (contadorf[x]!=" ,")
{
y=0;
nombre[x][y]=contadorf[x+y];
y++;
}
}
for(contadorf[x]!=";"; x; x++)
{

while (contadorf[x]!=" ,")
{
y=0;
codigo[z][y]=contadorf[x+y];
y++;
}
z++;
}
for(contadorf[x]!=";"; x; x++)
{
{

while (contadorf[xx]!=" ,")
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
if (auxiliar[xx]=="1")
{
auxiliar[xx]=1;
}
if (auxiliar[xx]=="2")
{
auxiliar[xx]=2;
}
if (auxiliar[xx]=="3")
{
auxiliar[xx]=3;
}
if (auxiliar[xx]=="4")
{
auxiliar[xx]=4;
}
if (auxiliar[xx]=="5")
{
auxiliar[xx]=5;
}
if (auxiliar[xx]=="6")
{
auxiliar[xx]=6;
}
if (auxiliar[xx]=="7")
{
auxiliar[xx]=7;

}
if (auxiliar[xx]=="8")
{
auxiliar[xx]=8;
}
if (auxiliar[xx]=="9")
{
auxiliar[xx]=9;
}
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=power[zz];
zz++;
}
suma=0;
zz=0;
for(contadorf[x]!=";"; x; x++)
{
{

while (contadorf[xx]!=" ,")
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
if (auxiliar[xx]=="1")
{
auxiliar[xx]=1;
}
if (auxiliar[xx]=="2")
{
auxiliar[xx]=2;
}
if (auxiliar[xx]=="3")
{
auxiliar[xx]=3;
}
if (auxiliar[xx]=="4")
{
auxiliar[xx]=4;
}
if (auxiliar[xx]=="5")
{
auxiliar[xx]=5;
}
if (auxiliar[xx]=="6")
{
auxiliar[xx]=6;
}
if (auxiliar[xx]=="7")
{
auxiliar[xx]=7;

}
if (auxiliar[xx]=="8")
{
auxiliar[xx]=8;
}
if (auxiliar[xx]=="9")
{
auxiliar[xx]=9;
}
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=v[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=";"; x; x++)
{
{

while (contadorf[xx]!=" ,")
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
if (auxiliar[xx]=="1")
{
auxiliar[xx]=1;
}
if (auxiliar[xx]=="2")
{
auxiliar[xx]=2;
}
if (auxiliar[xx]=="3")
{
auxiliar[xx]=3;
}
if (auxiliar[xx]=="4")
{
auxiliar[xx]=4;
}
if (auxiliar[xx]=="5")
{
auxiliar[xx]=5;
}
if (auxiliar[xx]=="6")
{
auxiliar[xx]=6;
}
if (auxiliar[xx]=="7")
{
auxiliar[xx]=7;

}
if (auxiliar[xx]=="8")
{
auxiliar[xx]=8;
}
if (auxiliar[xx]=="9")
{
auxiliar[xx]=9;
}
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=isp[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=";"; x; x++)
{
{

while (contadorf[xx]!=" ,")
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
if (auxiliar[xx]=="1")
{
auxiliar[xx]=1;
}
if (auxiliar[xx]=="2")
{
auxiliar[xx]=2;
}
if (auxiliar[xx]=="3")
{
auxiliar[xx]=3;
}
if (auxiliar[xx]=="4")
{
auxiliar[xx]=4;
}
if (auxiliar[xx]=="5")
{
auxiliar[xx]=5;
}
if (auxiliar[xx]=="6")
{
auxiliar[xx]=6;
}
if (auxiliar[xx]=="7")
{
auxiliar[xx]=7;

}
if (auxiliar[xx]=="8")
{
auxiliar[xx]=8;
}
if (auxiliar[xx]=="9")
{
auxiliar[xx]=9;
}
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=empuje[zz];
zz++;
}

}
suma=0;
zz=0;
for(contadorf[x]!=";"; x; x++)
{
{

while (contadorf[xx]!=" ,")
{
y=0;
auxiliar[y]=contadorf[x+y];
y++;
}
xx = strlen(auxiliar);
while (xx>=0)
{
if (auxiliar[xx]=="1")
{
auxiliar[xx]=1;
}
if (auxiliar[xx]=="2")
{
auxiliar[xx]=2;
}
if (auxiliar[xx]=="3")
{
auxiliar[xx]=3;
}
if (auxiliar[xx]=="4")
{
auxiliar[xx]=4;
}
if (auxiliar[xx]=="5")
{
auxiliar[xx]=5;
}
if (auxiliar[xx]=="6")
{
auxiliar[xx]=6;
}
if (auxiliar[xx]=="7")
{
auxiliar[xx]=7;

}
if (auxiliar[xx]=="8")
{
auxiliar[xx]=8;
}
if (auxiliar[xx]=="9")
{
auxiliar[xx]=9;
}
suma=suma+auxiliar[xx]*pow(10, strlen(auxiliar)-xx);
xx--;
}
suma=peso[zz];
zz++;
}
}
}
printf("%c",*nombre);
printf("%c",*codigo);
}
fclose (fent);

printf("Carga de datos a programa completada");

int * resultados = malloc(contador2 * sizeof(int));
i=0;
int j=0;
char objetivof[50];
switch(buscador)
{

case 1:

printf("Ha pulsado el 1\n");
printf("Introduzca el contenido a buscar.");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(nombre[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;

case 2:

printf("Ha pulsado el 2\n");
printf("Introduzca el contenido a buscar.");
scanf("%c", &objetivof);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if (strstr(codigo[i], objetivof) != NULL);
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 3:
printf("Ha pulsado el 3\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((power[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}
break;


case 4:
printf("Ha pulsado el 4\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((v[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}


break;


case 5:
printf("Ha pulsado el 5\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((isp[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 6:
printf("Ha pulsado el 6\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((empuje[i])>=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;


case 7:
printf ("Ha pulsado el 7\n");
printf("Introduzca el contenido a buscar.");

scanf("%d", &objetivo);
printf("Los siguientes resultados concuerdan con los criterios de busqueda:\n");
while(i<contador2)
{
if((peso[i])<=objetivo)
{
resultados[j]=i;
j++;
}
i++;
}

break;

case 0:
exit(0);


default:
{
printf("Ha introducido un caracter no incluido en el menu\n");
}
break;
}

printf("Busqueda y comparacion completada\n");

if(j != 0)
{
printf("Se han encontrado los siguientes resultados que concuerdan con el criterio:\n");
for(i=0; i!=j; i++)
{
printf("%c\n", *nombre[resultados[i]]);
printf("[%d]\n",i);
}
}
if (j != 0)
{
int sino=0;
int comp=1;
printf("¿Desea ver los datos de alguno de los sistemas presentados? [1 si, 0 no]\n");
scanf("%c", &sino);
if(sino==1)
{
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, insertelo a continuacion.\n");
printf("Para salir, presione el [0].\n");
while(comp!=0)
{ scanf("%d", &comp);
printf("Nombre: %c", *nombre[comp]);
printf("Tipo: %c", *codigo[comp]);
printf("Energia: %f", power[comp]);
printf("velocidad de escape: %f", v[comp]);
printf("ISP: %f", isp[comp]);
printf("Empuje: %f", empuje[comp]);
printf("Peso: %f", peso[comp]);
printf("Introduzca más datos, o pulse 0 para salir.\n");
}
}
}
if(j != 0)
{
int sino=0;
int comp=0;
printf("¿Desea iniciar la funcion calculadora? [1 si, 0 no]");
scanf("%c", &sino);
if(sino==1)
{
int mf=0;
int mi=0;
int comb=0;
float resultado=0;
printf("A cada resultado anterior se le ha asignado un numero identificativo que figura bajo cada resultado. Por favor, insertelo a continuacion.\n");
scanf("%d",&comp);
printf("¿Cuanto pesa el vehiculo?(en kg)\n");
scanf("%d",&mi);
printf("¿Cuantos kilos de combustible lleva?\n");
scanf("%d", &comb);
mf=comb+mi;
resultado=v[comp]*log(mi/mf);
printf("Delta-V estimada: %f m/s\n");
}
}
for ( i = 0; i < contador2; i++ )
{
   free(nombre[i]);
}

free(nombre);
for ( i = 0; i < contador2; i++ )
{
   free(codigo[i]);
}

free(codigo);
free(v);
free(isp);
free(power);
free(peso);
free(empuje);


}


Muchas gracias a cualquiera que se tome su tiempo en ayudar a gente como yo.
#6
Programación C/C++ / Re: Buscador (C)
17 Mayo 2017, 12:42 PM
Probablemente esté esto mal definido hasta la saciedad, pero no se me ocurre como salir de este berenjenal, esto está bastante más lejos de lo que yo controlo.

int objetivo;
char nombre[][255], char codigo[][255], float power[], float v[], float isp[], float empuje[], float peso[];

FILE *fent;//Apertura de archivo.
fent=fopen (field, "r");
if (fent==NULL)

{
printf("ERROR DE APERTURA DE %d\n",field);//Comprobación de errores en apertura.
}
if (fent != 0)
{
while (fgets (contadorf, 5000 , fent) != ";")//Aquí se realiza la cuenta para saber los elementos de char.
{
if (contadorf[contador]==",")
{contador2++;
}
contador++;
}
nombre=(int*)malloc(sizeof(char)contador2);//Especificamos que el puntero contiene las cadenas especificadas por contador2
codigo=(int*)malloc(sizeof(char)contador2);//Lo mimso
int *ppower
ppower=(int*)malloc(sizeof(int)contador2);//Especificamos que el array contiene contador2 enteros
int *pv
pv=(int*)malloc(sizeof(int)contador2);
int *pisp
pisp=(int*)malloc(sizeof(int)contador2);
int *pempuje
pempuje=(int*)malloc(sizeof(int)contador2);
int *ppeso
ppeso=(int*)malloc(sizeof(int)contador2);
#7
Programación C/C++ / Re: Buscador (C)
16 Mayo 2017, 16:20 PM
La verdad es que desconocía que podías jugar con los char de esa manera, muchas gracias.
#8
Programación C/C++ / Re: Buscador (C)
16 Mayo 2017, 13:08 PM
El archivo de texto a cargar es este. He separado cada elemento medinate una coma y un espacio (planeo usar alguna variante de función while para cargar los vectores) y terminan en un ";". Es una version resumida (cada array tiene unos 100 elementos).
Código (xml) [Seleccionar]

DAWN mission NSTAR, Resistojet, Radioisotope;  (Este sería el nombre)
ESTAT, ETHERM, NTR SOLID; (codigo)
1.37e-06, 7.25e-04, 5.85e-03; (energía)
3,1, 296; (eficiencia)
9.00e-05, 1, 2; (empuje)
26, N/A, N/A; (peso)


En cuanto al codigo, aun no lo he implementado, por lo que he explicado anteriormente. Solo he porgramado un menú switchcase para seleccionar el criterio de busqueda (nombre, eficiencia, etc).
#9
Programación C/C++ / Buscador (C)
16 Mayo 2017, 12:25 PM
Estoy desarrollando un programa. La clave del programa es leer de un txt una serie de vectores.
EL primer problema es que esos vectores, dos de ellos deberían de ser vectores, y cada uno d elos elementos de ese vector deberían de ser cadenas de caracteres.Y no sé muy bien como implementar eso.

Es mi primer post. Espero no incumplir ninguna norma.
Me han sugerido que sea un vector de punteros, y cada puntero apunte a una cadena de caracteres. No sé muy bien si eso es viable.

En segundo lugar. Cada uno de los vectores mencionado correponde a una categoría de datos(de forma que los 7 vectores, el elemento [1] correponde a diferentes caracteristicas de un elemento).
El funcionamiento del porgrama sería "yo quiero buscar todos los elementos que tienen un rendimiento mayor que 85%". Ese 85% estaría colocoado en el vector "Rendimeintos" y te mostraría las demas carcateristicas (es decir, todos las posiciones [a] de los vectores, en los cuales el vector 7 (rendimeinto) tuviera la posicion [a] mayor de 85).

Para ello se me ocurre utilizar punteros, apuntado a cada uno de los vectores. Así, si selecciono "Potencia", se buscara en el vector potencia a traves de su puntero.
Me parece que los conceptos son buenos. De cualquier forma, cualquier recomendación o consejo sería muy de agradecer.
Muchas gracias a todos.