Club Delphi  
    Paypal   FTP   CCD     Buscar   Trucos   Trabajo   Foros

Retroceder   Foros Club Delphi > Otros entornos y lenguajes > C++ Builder
Registrarse FAQ Miembros Calendario Guía de estilo Temas de Hoy

Respuesta
 
Herramientas Buscar en Tema Desplegado
  #1  
Antiguo 13-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Problemas con memoria dinamica

Hola amigos, esto es C pero no sabia donde ponerlo.
El caso es que estoy intentando crearme un pequeño codigo al que le diga el numero de columnas y filas y las palabras a colocar y que me cree una sopa de letras con ellas. El codigo lo encontre por internet pero no usaba memoria dinamica asi que lo he modificado y antes de modificarlo iba bien pero ahora me da errores al intentar añadir las palabras y al intentar rellenar la sopa de letras y estoy seguro de que estoy haciendo algo mal al trabajar con los punteros de la memoria que he obtenido pero no se que. ¿pueden ayudarme?
Este es el codigo:
Código PHP:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#define LARGOMAX 21

// Llena la matriz con caracteres /0
void inicializa(char **mint filasint columnas) {
    
int ij;

    for (
0filasi++)
        for (
0columnasj++)
            
m[i][j] = '\0';
}

void PedirPalabras(char **palabrasint nPalabras){
   
int i,x;

   for (
0nPalabrasi++){
      
printf("Introduce una palabra: ");
      
scanf("%s"palabras[i]);
      for (
0LARGOMAXx++){
         
palabras[i][x]=toupper(palabras[i][x]);
      }
   }
}

// Llena los espacios vacíos con caracteres al azar
void rellena(char **mint filasint columnas) {
    
int ij;

    for (
0filasi++)
        for (
0columnasj++)
            if (
m[i][j] == '\0')
                
m[i][j] = rand() % 26 65;
}

// Muestra la sopa de letras
void muestra(char **mint filasint columnas) {
    
int ij;

    
printf("\n\n");
    for (
0filasi++) {
        for (
0columnasj++)
            
printf("%c "m[i][j]);
        
printf("\n");
    }
}

// Valida que la palabra s se pueda agregar a la matriz m
// en la posición (x, y) y en la dirección (dx, dy)
int valida(char **mint filasint columnas, const char *sint xint yint dxint dy) {
    
int i1;

    for (
0< (int)strlen(s); i++, += dx+= dy){
        if (
|| || >= columnas || >= filas || (m[y][x] != s[i] && m[y][x] != '\0')){
            
0;
            break;
        }
    }
    if(
v==1)
      
printf("\n%s puede agregarse (x%d, y%d, dx%d, dy%d): %d"sxydxdyv);

    return 
v;
}

// Agrega la palabra s a la sopa de letras
void agrega(char **mint filasint columnas, const char *s) {
    
int ixydxdy;

    
dx rand() % 1;
    
dy rand() % 1;
    
dx dx == dx;
    while (!
valida(mfilascolumnassrand() % columnasrand() % filasdxdy)) ;
    for (
0< (int)strlen(s); i++, += dx+= dy)
        
m[y][x] = s[i];
}

int main() {
    
// Las palabras que se van a agregar a la sopa de letras
    // Deben ser tantas palabras como la definción de PAL
    // Escritas en mayúsculas para que se vean bien
    
char **m, **palabras;
    
int i;
    
int filascolumnasnPalabras;
    
srand(time(0));

    
printf("Introduce el numero de caracteres horizontales: ");
    
scanf("%d",&columnas);
    
printf("Introduce el numero de caracteres verticales: ");
    
scanf("%d",&filas);

    
//Obtengo la memoria suficiente para el array que contendrá la sopa de letras
    
if (( mallocfilas*sizeofchar* ))) == NULL )
    {
      
/* error */
    
}else{

      for ( 
0filasi++ )
      {
         if (( 
m[i] = malloccolumnas )) == NULL )
         {
            
/* error */
         
}else{
            
//Obtengo la memoria suficiente para el array que contendrá las palabras a colocar en sopa de letras
            
printf("Introduce el numero de palabras a colocar: ");
            
scanf("%d",&nPalabras);

            if (( 
palabras mallocnPalabras*sizeofchar* ))) == NULL )
            {
               
/* error */
            
}else{
               for ( 
0nPalabrasi++ )
               {
                  if (( 
palabras[i] = mallocLARGOMAX )) == NULL )
                  {
                     
/* error */
                  
}else{
                     
//Obtengo las palabras y las almaceno en el array
                     
PedirPalabras(palabrasnPalabras);

                     
//Lleno la sopa de letra con \0's
                     
inicializa(m,filas,columnas);

                     
//Coloco las palabras en la sopa de letra
                     
for (0nPalabrasi++)
                        
agrega(mfilascolumnaspalabras[i]);

                     
//Muestro como quedan las palabras
                     
muestra(mfilascolumnas);
                     
getchar();

                     
//Relleno los huecos de la sopa de letra
                     
rellena(mfilascolumnas);
                     
getchar();

                     
//Muestro como queda la sopa de letra
                     
muestra(mfilascolumnas);
                     
getchar();
                  }
               }
            }
         }
      }
    }

    
//Libero la memoria de la matriz de la sopa de letras
    
if( != NULL ){
      for ( 
0filasi++ )
      {
         if (
m[i] != NULL)
         {
            
free(m[i]);
         }
      }
    }
    
free(m);

    
//Libero la memoria de la matriz de las palabras
    
if( palabras != NULL ){
      for ( 
0nPalabrasi++ )
      {
         if (
palabras[i] != NULL)
         {
            
free(palabras[i]);
         }
      }
    }
    
free(palabras);
    return 
0;

Responder Con Cita
  #2  
Antiguo 13-09-2015
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Cita:
Empezado por aguml Ver Mensaje
... lo he modificado y antes de modificarlo iba bien pero ahora me da errores
¿Qué errores?
No estaría mal que pusieras el código original también.

Última edición por Casimiro Noteví fecha: 13-09-2015 a las 20:00:52.
Responder Con Cita
  #3  
Antiguo 13-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Lo saque de aqui pero vamos que lo que hice fue cambiar por memoria dinamica los arrais y permitir decidir al usuario el tamaño de la sopa de letras, el numero de palabras a colocar, y cuales serán esas palabras y de paso quité alguna variable global:
¿Como crear una sopa de letras en C? | Yahoo Respuestas
Responder Con Cita
  #4  
Antiguo 13-09-2015
Avatar de Casimiro Noteví
Casimiro Noteví Casimiro Noteví is offline
Merodeador
 
Registrado: sep 2004
Ubicación: En algún lugar.
Posts: 32.671
Poder: 10
Casimiro Noteví Tiene un aura espectacularCasimiro Noteví Tiene un aura espectacular
Vale, pero ¿qué error tiene y dónde?
Responder Con Cita
  #5  
Antiguo 13-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Cita:
Empezado por Casimiro Notevi Ver Mensaje
Vale, pero ¿qué error tiene y dónde?
Pues de momento si pongo que la sopa será de 8x8 y que colocaré 3 palabras, al meter la tercera palabra crashea y si no lo hace lo hace al inicializar con \0 la sopa. Son fallos seguro porque no estoy haciendo algo bien con el tema de punteros o con la memoria dinamica.
Responder Con Cita
  #6  
Antiguo 13-09-2015
Avatar de escafandra
[escafandra] escafandra is offline
Miembro Premium
 
Registrado: nov 2007
Posts: 2.210
Poder: 22
escafandra Tiene un aura espectacularescafandra Tiene un aura espectacular
En tu bucle principal pides palabras sin haber seresvado el espacio para todas elles y "peta"

Mira esta modificación a tu código respetando más o menos su estructura:

Código PHP:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#define LARGOMAX 21

// Llena la matriz con caracteres /0
void inicializa(char **mint filasint columnas) {
    
int ij;

    for (
0filasi++)
        for (
0columnasj++)
            
m[i][j] = '\0';
}

void PedirPalabras(char **palabrasint nPalabras){
   
int i,x;

   for (
0nPalabrasi++){
      
printf("Introduce una palabra: ");
      
scanf("%s"palabras[i]);
      for (
0strlen(palabras[i]); x++){
         
palabras[i][x]=toupper(palabras[i][x]);
      }
   }
}

// Llena los espacios vacíos con caracteres al azar
void rellena(char **mint filasint columnas) {
    
int ij;

    for (
0filasi++)
        for (
0columnasj++)
            if (
m[i][j] == '\0')
                
m[i][j] = rand() % 26 65;
}

// Muestra la sopa de letras
void muestra(char **mint filasint columnas) {
    
int ij;

    
printf("\n\n");
    for (
0filasi++) {
        for (
0columnasj++)
            
printf("%c "m[i][j]);
        
printf("\n");
    }
}

// Valida que la palabra s se pueda agregar a la matriz m
// en la posición (x, y) y en la dirección (dx, dy)
int valida(char **mint filasint columnas, const char *sint xint yint dxint dy) {
    
int i1;

    for (
0< (int)strlen(s); i++, += dx+= dy){
        if (
|| || >= columnas || >= filas || (m[y][x] != s[i] && m[y][x] != '\0')){
            
0;
            break;
        }
    }
    if(
v==1)
      
printf("\n%s puede agregarse (x%d, y%d, dx%d, dy%d): %d"sxydxdyv);

    return 
v;
}

// Agrega la palabra s a la sopa de letras
void agrega(char **mint filasint columnas, const char *s) {
    
int ixydxdy;

    
dx rand() % 1;
    
dy rand() % 1;
    
dx dx == dx;
    while (!
valida(mfilascolumnassrand() % columnasrand() % filasdxdy)) ;
    for (
0< (int)strlen(s); i++, += dx+= dy)
        
m[y][x] = s[i];
}

int main() {
    
// Las palabras que se van a agregar a la sopa de letras
    // Deben ser tantas palabras como la definción de PAL
    // Escritas en mayúsculas para que se vean bien
    
char **m, **palabras;
    
int i;
    
int filascolumnasnPalabras;
    
srand(time(0));

    
printf("Introduce el numero de caracteres horizontales: ");
    
scanf("%d",&columnas);
    
printf("Introduce el numero de caracteres verticales: ");
    
scanf("%d",&filas);

   
bool Error false;

   
//Obtengo la memoria suficiente para el array que contendrá las palabras a colocar en sopa de letras
   
printf("Introduce el numero de palabras a colocar: ");
   
scanf("%d",&nPalabras);
   if(( 
palabras = (char**)malloc(nPalabras*sizeof(char*))) == NULL){
      
Error != true;
   }else{
      for ( 
0nPalabrasi++ ){
        if(( 
palabras[i] = (char*)malloc(LARGOMAX+1)) == NULL )
           
Error != true;
      }
    }


    
//Obtengo la memoria suficiente para el array que contendrá la sopa de letras
    
if (!Error && ( = (char**)malloc(filas*sizeof(char*))) == NULL )
    {
      
Error != true;
    }else{
      for (
0filasi++){
         if (( 
m[i] = (char*)malloc(columnas)) == NULL )
            
Error != true;
      }
    }

    if(!
Error){
      
PedirPalabras(palabrasnPalabras);
      
//Lleno la sopa de letra con \0's
      
inicializa(m,filas,columnas);

      
//Coloco las palabras en la sopa de letra
      
for (0nPalabrasi++)
        
agrega(mfilascolumnaspalabras[i]);

      
//Muestro como quedan las palabras
      
muestra(mfilascolumnas);
      
getchar();

      
//Relleno los huecos de la sopa de letra
      
rellena(mfilascolumnas);
      
getchar();

      
//Muestro como queda la sopa de letra
      
muestra(mfilascolumnas);
      
getchar();
    }

    
//Libero la memoria de la matriz de la sopa de letras
    
if( != NULL ){
      for ( 
0filasi++ )
      {
         if (
m[i] != NULL)
         {
            
free(m[i]);
         }
      }
    }
    
free(m);

    
//Libero la memoria de la matriz de las palabras
    
if( palabras != NULL ){
      for ( 
0nPalabrasi++ )
      {
         if (
palabras[i] != NULL)
         {
            
free(palabras[i]);
         }
      }
    }
    
free(palabras);
    return 
0;

Saludos.
Responder Con Cita
  #7  
Antiguo 13-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
tienes razon, el codigo donde acomodo las palabras estaba ejecutandose antes de terminar de allocar toda la memoria jajaja.
Ahora me queda crear algo asi como un RandomSuffle que vaya probando todas las combinaciones posibles hasta encontrar una y si las prueba todas y no da con una valida pues que avise con un error. Prueben a crear una sopa de por ejemplo 5x5 y agregen una palabra de 6 letras y veran que no sale nunca del while:
Código PHP:
while (!valida(mfilascolumnassrand() % columnasrand() % filasdxdy)) ; 
de la funcion agrega.

Mi idea es algo asi:
Código PHP:
largo=rows*columns;
int *lista=malloc (largo*sizeof (int));
for(
int x=0;<largo;x++)
    
lista[x]=x;
lista RandomSuffle (listalargo);

intRandomSuffle(int *listaint largo){
   
//en un for voy recorriendo todos y calculo con rand la nueva posición y lo intercambio.
   
int posaux;
   for(
int x=0;x<largo;x++){
      
pos=rand ()%largo;
      if(
pos != x){
         
aux=lista [pos];
         
lista[pos]=lista[x];
         
lista[x]=aux;
     }
   }

Luego ya fuera de randomsuffle para saber cual es cada posición lo divido entre el número de columnas y me dará la columna y calculo el residuo y me dará la fila.
Código PHP:
void ObtenerPosicion (int valorint *posxint *posy){
   *
posx=valor cols;
   *
posy=valor cols;
}

for(
int x=0x<largox++){
   
ObtenerPosicion(lista[x], &posx, &posy);
   ...
   ... 
Luego:
Uso el mismo método para la orientacion.
Código PHP:
largo=8//son las 8 posibles orientaciones
int orientacion=malloc (largo*sizeof (int));
for(
int x=0;<largo;x++)
    
orientacion[x]=x;
orientacion RandomSuffle (orientacionlargo);
for(
int x=0x<largox++){
   switch (
orientacion[x]){
      case 
0//norte
         
...
         break;
      case 
1//noroeste
         
...
         break;
      case 
2//oeste
         
...
         break;
      case 
3//suroeste
         
...
         break;
      case 
4//sur
         
...
         break;
      case 
5//sureste
         
...
         break;
      case 
6//este
         
...
         break;
      case 
7//noreste
         
...
         break;
   }

Si no cabe de ninguna manera cojo una nueva posición y repito hasta encontrar donde cabe o hasta usar la última opción posible.
Si cabe tengo que comprobar que case con las letras que ya haya de otras palabras. Para ello tengo que comprobar con un for si hay alguna letra y comprobar que se corresponda. Dependiendo de la orientacion tendré que comprobar que no desborde el array tampoco.

Todo eso está hecho en el movil y aun no lo he probado, solo fue una idea que me vino estando fuera y lo hice en el movil para no olvidarlo pero ¿que opinais? ¿algo mejor que eso?
Responder Con Cita
  #8  
Antiguo 14-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
barajar filas de un array multidimensional

Buenas amigos, estoy intentando barajar las filas de un array multidimensional y no soy capaz de dar con el modo. Ahora mismo lo tengo asi:
Código PHP:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

void RandomSuffle(int **listaint nElements){
   
//en un for voy recorriendo todos y calculo con rand la nueva posición y lo intercambio.
   
int xypos, *aux;
   for(
y=0;y<nElements;y++){
      
pos=rand()%nElements;
      if(
pos != y){
            
aux=lista[pos];
            
lista[pos]=lista[y];
            
lista[y]=aux;
     }
   }
}

int main()
{
    
int zxi=0deltas[8][2];
   
srand(time(0));
    for (
= -1<= 1z++){
      for(
= -1<= 1x++){
         if(
== && == 0){
         }else{
            
deltas[i][0]=z;
            
deltas[i][1]=x;
            
i++;
         }
      }
   }

   for (
08i++){
      
printf("%2i,",deltas[i][0]);
      
printf("%2i\n",deltas[i][1]);
   }

   
RandomSuffle(deltas8);
   
printf("\n");
   for (
08i++){
      
printf("%2i,",deltas[i][0]);
      
printf("%2i\n",deltas[i][1]);
   }
   
getchar();
    return 
0;

lo que pretendo barajar son los punteros de las filas, o sea, si deltas[0][0]={-1,-1} y la direccion de la fila es 0x12ff00 y deltas[1][0]={1,0} y su direccion es 12ee00 (por decir una), Se suponge que si intercambio esos punteros cambio el orden de la lista sin necesidad de saber cuantas columnas tiene la fila ¿no?
Estoy muy perdido en esto ¿alguien puede ayudarme?
Responder Con Cita
  #9  
Antiguo 14-09-2015
Avatar de ecfisa
ecfisa ecfisa is offline
Moderador
 
Registrado: dic 2005
Ubicación: Tres Arroyos, Argentina
Posts: 10.508
Poder: 38
ecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to beholdecfisa is a splendid one to behold
Hola aguml.
Cita:
Empezado por aguml Ver Mensaje
...
lo que pretendo barajar son los punteros de las filas, o sea, si deltas[0][0]={-1,-1} y la direccion de la fila es 0x12ff00 y deltas[1][0]={1,0} y su direccion es 12ee00 (por decir una), Se suponge que si intercambio esos punteros cambio el orden de la lista sin necesidad de saber cuantas columnas tiene la fila ¿no?
El arreglo está declarado como estático por lo que podrás modificar sus valores pero no el arreglo en sí mismo.
Por otro lado, si envias un arreglo bidimensional como argumento, deberás especificar al menos el tamaño de la segunda dimensión.

Pero sinceramente no sé si interpreté correctamente lo que queres hacer...

Saludos
__________________
Daniel Didriksen

Guía de estilo - Uso de las etiquetas - La otra guía de estilo ....
Responder Con Cita
  #10  
Antiguo 14-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Tenias razón, al crearlo con memoria dinámica ya va perfecto.
Eso cuando lo termine formará parte del código de lo de la sopa de letras. Actualmente hay un bucle en el que dx y dy que son los deltas se calculan con rand. Con esto que he hecho la idea es que pruebe todas las combinaciones válidas sin repetirlas. Esto lo tendría que hacer con todas las coordenadas x e y de la sopa de letras hasta que encuentre una válida o hasta que las pruebe todas y si no se encuentra una válida avise. Actualmente como esta en el código de la sopa de letras se podría quedar en un bucle infinito si no existiese una posición válida.
Responder Con Cita
  #11  
Antiguo 14-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Asi ha quedado:
Código PHP:
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

enum booleanos {false,true};

void RandomSuffle(int **listaint nElements){
   
//en un for voy recorriendo todos y calculo con rand la nueva posición y lo intercambio.
   
int xypos, *aux;
   for(
y=0;y<nElements;y++){
      
pos=rand()%nElements;
      if(
pos != y){
            
aux=lista[pos];
            
lista[pos]=lista[y];
            
lista[y]=aux;
     }
   }
}

void RellenarDeltas(int **deltas){
   
int yxi=0;

   for (
= -1<= 1y++){
      for(
= -1<= 1x++){
         if(!(
== && == 0)){
            
deltas[i][0]=y;
            
deltas[i][1]=x;
            
i++;
         }
      }
   }
}

int main()
{
    
int zxi=0nProbados, **deltas, **coordenadasnFilasnColumnasError=false;
   
struct{
      
int x;
      
int y;
   }
posicion;

   
srand(time(0));

   
nFilas=8;
   
nColumnas=2;
   
   
//Obtengo memoria dinamicamente para el array que contendrá los deltas
   
if(( deltas = (int**)malloc(nFilas*sizeof(int*))) == NULL){
      
Error true;
   }else{
      for ( 
0nFilasi++ ){
        if(( 
deltas[i] = (int*)malloc(nColumnas*sizeof(int))) == NULL )
           
Error true;
      }
   }

   if(!
Error){
      
i=0;
      
nFilas=10;
      
nColumnas=8;

      
nFilas *= nColumnas;
      
nColumnas=1;
      if(( 
coordenadas = (int**)malloc(nFilas*sizeof(int*))) == NULL){
         
Error true;
      }else{
         for ( 
0nFilasi++ ){
            if(( 
coordenadas[i] = (int*)malloc(nColumnas*sizeof(int))) == NULL ){
               
Error true;
            }
         }
      }

      if(!
Error){
         for(
i=0i<nFilasi++)
            
coordenadas[i][0]=i;

         
//Barajo las coordenadas posibles
         
RandomSuffle(coordenadas,nFilas*nColumnas);

         
nFilas=10;
         
nColumnas=8;
         
nProbados=0;

         
//Obtengo las coordenadas para X e Y
         
for(i=0i<nColumnas*nFilasi++){
            
posicion.coordenadas[i][0]%nColumnas;
            
posicion.coordenadas[i][0]/nColumnas;

            
RellenarDeltas(deltas);
            
RandomSuffle(deltas8);

            for(
z=0z<8z++){
               
//Aqui tengo que llamar a la funcion que haga uso de los deltas y de las coordenadas ya barajados
               
printf("X=%i, Y=%i, deltaX=%i, deltaY=%i\n"posicion.xposicion.ydeltas[z][0], deltas[z][1]);
               
nProbados++;
            }
         }
         
printf("\nProbados %i opciones"nProbados);
      }
   }
   
getchar();
    return 
0;

Para ese caso en concreto probaria 640 posibilidades sin repetir ninguna y digamos que seria aleatorio el orden. Son 10 filas, 8 columnas y por cada posicion se pueden dar 8 combinaciones de deltas diferentes con lo que seria 8*10*8=640. Eso es lo que queria conseguir. Ahora me queda acomodarlo con el de la sopa de letras para que repita eso con cada palabra y listo. Se que tiene un coste de procesado y memoria elevados pero se acaba el problema del bucle infinito cuando no pueda acomodar la palabra.
Responder Con Cita
  #12  
Antiguo 16-09-2015
Avatar de aguml
aguml aguml is offline
Miembro
 
Registrado: may 2013
Posts: 885
Poder: 14
aguml Va por buen camino
Bueno amigos, ya tengo el codigo funcionando y va mejor de lo que pensaba jajaja. Solo tengo una duda y es que para obtener memoria y para liberarla uso unas funciones que son copias casi identicas a excepcion del tipo de retorno y del tipo de un parametro de entrada.
Aqui las funciones:
Código PHP:
//Libera la memoria de un array de enteros
int** LiberarMemoria(int **dirint nFilasint nColumnas)
{
   
int i;

   if( 
dir != NULL ){
      for ( 
0nFilasi++ )
      {
         if (
dir[i] != NULL)
         {
            
free(dir[i]);
         }
      }
    }
    
free(dir);
    
dir=NULL;

    return 
dir;
}

//Libera la memoria de un array de cadenas
char** LiberarMemoriaCadenas(char **dirint nFilasint nColumnas){
   
int i;

   if( 
dir != NULL ){
      for ( 
0nFilasi++ )
      {
         if (
dir[i] != NULL)
         {
            
free(dir[i]);
         }
      }
    }
    
free(dir);
    
dir=NULL;

    return 
dir;
}

//Obtiene memoria para almacenar un array de cadenas
char** ObtenerMemoriaCadenas(char **dirint nFilasint nColumnas){
   
int Error=falsei;
   if(( 
dir = (char**)malloc(nFilas*sizeof(char*))) == NULL){
      
Error true;
   }else{
      for ( 
0nFilasi++ ){
        if(( 
dir[i] = (char*)malloc(nColumnas)) == NULL )
           
Error true;
      }
   }

   if(
Error){
      
dir LiberarMemoriaCadenas(dirnFilasnColumnas);
   }
   
   return 
dir;
}

//Obtiene memoria para almacenar un array de punteros a enteros
int** ObtenerMemoria(int **dirint nFilasint nColumnas){
   
int Error=falsei;
   if(( 
dir = (int**)malloc(nFilas*sizeof(int*))) == NULL){
      
Error true;
   }else{
      for ( 
0nFilasi++ ){
        if(( 
dir[i] = (int*)malloc(nColumnas)) == NULL )
           
Error true;
      }
   }

   if(
Error){
      
dir LiberarMemoria(dirnFilasnColumnas);
   }
   
   return 
dir;

¿alguna manera sencilla de hacer que una funcion sirva para ambos casos al obtener memoria y otra sola funcion sirva para liberarla?
Responder Con Cita
Respuesta



Normas de Publicación
no Puedes crear nuevos temas
no Puedes responder a temas
no Puedes adjuntar archivos
no Puedes editar tus mensajes

El código vB está habilitado
Las caritas están habilitado
Código [IMG] está habilitado
Código HTML está deshabilitado
Saltar a Foro

Temas Similares
Tema Autor Foro Respuestas Último mensaje
Array dentro de un Array Holger PHP 4 03-01-2012 17:27:44
Multidimensional arrays nemesis JAVA 1 12-10-2008 01:07:42
problemas con array o array noodle_ OOP 7 19-06-2008 22:30:57
Como Asignar Variable Tipo Array de Tform a otro Array del Mismo tipo morfeo21 Varios 5 17-08-2004 17:39:51
FFT multidimensional i.larranaga Varios 0 04-02-2004 11:51:49


La franja horaria es GMT +2. Ahora son las 18:22:32.


Powered by vBulletin® Version 3.6.8
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Traducción al castellano por el equipo de moderadores del Club Delphi
Copyright 1996-2007 Club Delphi